以前學習的時候還是3版本,如今已經是8版本了
https://cn.pingcap.com/product-community/?_gl=1ujh2l9_gcl_auMTI3MTI3NTM3NC4xNzM5MjU3ODE2_gaMTYwNzE2NTI4OC4xNzMzOTA1MjUz_ga_3JVXJ41175MTc0MTk1NTc1OC4xMS4xLjE3NDE5NTU3NjIuNTYuMC41NDk4MTMxNTM._ga_CPG2VW1Y41*MTc0MTk1NTc2MC4xMS4xLjE3NDE5NTU3NjMuMC4wLjA.
不過現在這個版本為長期支持版本 (Long-Term Support Release, LTS)那么就不用擔心迭代太快的問題了。而且現在的安裝應該比較友好(事實也是如此)一天安裝了兩套總結了一下過程。有些問題(主要是注釋)在文檔中沒有解釋,我來解釋一下。
順便說一下,我這里是麒麟的操作系統,TiDB這個是適配的。整個過程中沒有因為操作系統的問題出現問題。
將這兩個下載后上傳到一臺(注意是一臺就夠了,即使你的TiDB是滿配置的十幾臺機器,只要上傳一臺剩下的交給TiUP)
第一步修改密碼復雜度并創建用戶
用vim修改/etc/pam.d/system-auth文件
找到 password requisite pam_cracklib.so這么一行替換成如下:
password requisite pam_cracklib.so retry=5 difok=3 minlen=10 ucredit=-1 lcredit=-3 dcredit=-3 dictpath=/usr/share/cracklib/pw_dict
之所以把這步加進來是因為免得復雜密碼影響心情以及后續維護工作量增加。
useradd tidb
passwd tidb
創建tidb用戶,并且設置密碼。(現在知道上面那步的用意了吧)
(注意是一臺就夠了,即使你的TiDB是滿配置的十幾臺機器,只要設置一臺剩下的交給TiUP)
在操作系統命令行執行visudo
加入以下內容:
tidb ALL=(ALL) NOPASSWD: ALL
在主控機上生成密鑰,為了和其他機器做免密登錄
ssh-keygen -t rsa
執行復制發送密碼(主控機自己給自己的IP也要發一遍)
ssh-copy-id root@10.60.143.154
ssh-copy-id root@10.60.143.155
ssh-copy-id root@10.60.143.156
第二步上傳安裝介質并解壓執行命令
將下載完的
tidb-community-server-v8.5.1-linux-amd64.tar.gz
tidb-community-toolkit-v8.5.1-linux-amd64.tar.gz
上傳到主控機(TiDB集群中的一臺機器上,可以任意選擇。我一般選擇IP地址最靠前的那個)
在主控機上用root用戶建立一個目錄,我通常叫/setup。集中管理。
建立好以后要執行
chown tidb:tidb -R /setup
這是為了等下tidb用戶可以在這個目錄中大有可為。
將文件上傳到這個目錄一下。
su - tidb
在tidb用戶下執行
tar -zxvf tidb-community-server-v8.5.1-linux-amd64.tar.gz
tar -zxvf tidb-community-toolkit-v8.5.1-linux-amd64.tar.gz
解壓完成后。切換到tidb-community-server-v8.5.1-linux-amd64目錄。
cd tidb-community-server-v8.5.1-linux-amd64
執行下面的命令,并且得到下面的結果。
sh local_install.sh
Disable telemetry success
Successfully set mirror to /setup/tidb-community-server-v8.5.1-linux-amd64
Detected shell: bash
Shell profile: /home/tidb/.bash_profile
/home/tidb/.bash_profile has been modified to to add tiup to PATH
open a new terminal or source /home/tidb/.bash_profile to use it
Installed path: /home/tidb/.tiup/bin/tiup
===============================================
- source /home/tidb/.bash_profile
- Have a try: tiup playground
===============================================
官方的工具也算是保姆級了,讓用戶執行一下上面的命令。
source /home/tidb/.bash_profile
不過我覺得是不是如果工具能順便也做了就更好了。
第三步生成配置模版預安裝
執行下面命令獲得模板
tiup cluster template > topology.yaml
然后vim 這個yaml文件。里面主要是配置各個組件的地址。
這點上官方文檔上倒是可以參考。
global:
user: “tidb”
ssh_port: 22
deploy_dir: “/tidb-deploy”
data_dir: “/tidb-data”
server_configs: {}
pd_servers:
- host: 10.0.1.4
- host: 10.0.1.5
- host: 10.0.1.6
tidb_servers: - host: 10.0.1.7
- host: 10.0.1.8
- host: 10.0.1.9
tikv_servers: - host: 10.0.1.1
- host: 10.0.1.2
- host: 10.0.1.3
monitoring_servers: - host: 10.0.1.4
grafana_servers: - host: 10.0.1.4
alertmanager_servers: - host: 10.0.1.4
每個host寫自己的規劃IP。如果這個組件只打算安裝一個,那么就寫一個地址。其他的注釋掉。
如果注釋不干凈,在安裝時候還有問題。所以推薦大家不用的就刪除吧。
預安裝檢查
tiup cluster check /setup/tidb-community-server-v8.5.1-linux-amd64/topology.yaml --user tidb -p
然后讓你輸入tidb的密碼
他會告訴你,還有哪些問題影響安裝的。
看著有問題不用害怕。下面是一個亮點
tiup cluster check /setup/tidb-community-server-v8.5.1-linux-amd64/topology.yaml --apply --user tidb -p
執行這個命令后,遇到的問題tiup幫你修復,不用我們干預。這個就非常友好了。最后剩下numactl的錯誤無法修復但是不影響安裝。
第四步 安裝和測試
前面的準備工作做完了,就可以執行安裝了。 注意deploy 后面一定是兩個字符串,一個是集群名字(自定義) 還有一個是版本號。這是為了日后維護好。請如實填寫。
tiup cluster deploy tidbtest v8.5.1 /setup/tidb-community-server-v8.5.1-linux-amd64/topology.yaml --user tidb -p
最后經過一些操作,出現了sccuess的字樣說明安裝成功。并且隨機生成了一個管理員密碼。相比較之前都是空密碼登錄,在安全上多了一步。
執行下面兩個命令檢查集群狀況
tiup cluster list
tiup cluster display tidbtest
至此完成。找一個MySQL的客戶端進行登錄驗證就可以了。