0. 前言
因應行政部門關鍵民生系統韌性(關鍵民生系統精進雲端備份及回復計畫),以下為Tahoe-LAFS的安裝步驟。
1. 準備三台安裝好Ubuntu 22.04 的虛擬機或實體機
這邊以三台VM演示,使用的規格為 4 vCPU, 4GB RAM, Storage: 100G。
data:image/s3,"s3://crabby-images/9b376/9b3766e88244f519f9e8f354be46801f0600a961" alt="install-ubuntu-2204"
2. 更新套件清單與升級套件
更新完後請重啟作業系統,本文指令接需使用root身分執行。
data:image/s3,"s3://crabby-images/1de7a/1de7af64f0e5dfba39190902b9df17193daf2394" alt="sudo-i-and-apt-update-upgrade"
sudo -i
apt update
apt upgrade -y
reboot
3. 安裝Python與其他套件
data:image/s3,"s3://crabby-images/0c252/0c252c41fd107478a35830862dae2201e7256d59" alt="use-ssh-connect-to-ubuntu"
data:image/s3,"s3://crabby-images/ff692/ff69216c0a4e00808b11d82b1e9ee08d7bd88d09" alt="install-python-and-other-packets"
sudo -i
apt install python3-pip python3-dev libffi-dev libssl-dev -y
4. 安裝 pyopenssl
data:image/s3,"s3://crabby-images/278a8/278a83a119b52142aa22483e65aead0264a8d617" alt="install-pyopenssl"
pip install pyopenssl
5. 升級 attrs
data:image/s3,"s3://crabby-images/ed086/ed086d05d0442cf6fdea9a5f463187d0a47ad915" alt="pip-upgrade-attrs"
pip install --upgrade attrs
6. 安裝 tahoe-lafs
data:image/s3,"s3://crabby-images/551b6/551b6a921cd6db4d64ad9bd14d5d4488ca3f3586" alt="pip-install-tahoe-lafs"
pip install tahoe-lafs
7. 檢查Ubuntu、Python、Tahoe-LAFS版本
data:image/s3,"s3://crabby-images/c3e4e/c3e4eb192538d318e135fc4d312894b41a4a6388" alt="check-ubuntu-python-tahoe-lafs-version"
lsb_release -a
python3 --version
tahoe --version
8. 編輯hosts
data:image/s3,"s3://crabby-images/0c15b/0c15b863716088051fed8117922ad03fed86c73a" alt="edit-hosts"
nano /etc/hosts
10.100.101.191 node1.test.example
10.100.101.190 node2.test.example
10.100.101.189 node3.test.example
9. 在第一個節點建立介紹者(introducer)
data:image/s3,"s3://crabby-images/7c187/7c1872a8f49bfb2689d667ab697577b429efb670" alt="node1-create-introducer"
#建立目錄
mkdir -p /opt/tahoe-lafs/intro-test;
#進入目錄
cd /opt/tahoe-lafs/intro-test;
#建立介紹者
tahoe create-introducer --hostname=server1-domain .
tahoe create-introducer --hostname=node1.test.example .
#運行介紹者
tahoe run /opt/tahoe-lafs/intro-test &
#查看furl
cat private/introducer.furl
cat private/introducer.furl 之後會出現 pb 連結,這個要記好,後面步驟會用到。
pb://i5pyrfw3k5fbdtkz7bkkvco2zgh52qnf@tcp:node1.test.example:44421/nlchhrixoavrenvzyrju4rqil4lgg6cv
10. 在第一個節點建立Client Web(Gateway)
data:image/s3,"s3://crabby-images/0549f/0549f3d7ceae4adf40646ce33ec04e864646fef5" alt="node1-create-gateway"
data:image/s3,"s3://crabby-images/6e016/6e01646ad5b4e0e1967ca0c4ee856d1b03fa90b4" alt="node1-edit-gateway-config"
data:image/s3,"s3://crabby-images/85f01/85f01f05b73ca7100c2fb902e374ebabf8fa8d14" alt="node1-edit-gateway-share-config"
#建立目錄
mkdir -p /opt/tahoe-lafs/clientGWNode1;
#進入目錄
cd /opt/tahoe-lafs/clientGWNode1;
#建立 Gateway 節點
tahoe create-node --hostname=自訂HostName --introducer=取得的PD連捷 .
tahoe create-node --hostname=node1.test.example --introducer=pb://i5pyrfw3k5fbdtkz7bkkvco2zgh52qnf@tcp:node1.test.example:44421/nlchhrixoavrenvzyrju4rqil4lgg6cv .
#編輯 tahoe.cfg
nano tahoe.cfg
#新增暱稱
nickname = clientGWNode1
#將 interface 修改為 0.0.0.0
web.port = tcp:3456:interface=0.0.0.0
#修改共享參數
shares.needed = 2
shares.happy = 3
shares.total = 3
11. 在第二台伺服器建立儲存節點 (Storage)
data:image/s3,"s3://crabby-images/a62a7/a62a7563aac390d7b3526645909c6de9c2e017b5" alt="node2-create-storage"
data:image/s3,"s3://crabby-images/30601/3060185949ded60ecac158412ef1bc3b442127f6" alt="node2-edit-storage-config"
#建立目錄
mkdir -p /opt/tahoe-lafs/Node2;
#進入目錄
cd /opt/tahoe-lafs/Node2;
#建立儲存節點
tahoe create-node --hostname=自訂HostName --introducer=取得的PD連捷 .
tahoe create-node --hostname=node2.test.example --introducer=pb://i5pyrfw3k5fbdtkz7bkkvco2zgh52qnf@tcp:node1.test.example:44421/nlchhrixoavrenvzyrju4rqil4lgg6cv .
#編輯 tahoe.cfg
nano tahoe.cfg
#新增暱稱
nickname = Node2
#將這兩行註解掉
#web.port = tcp:3456:interface=127.0.0.1
#web.static = public_html
12. 在第三台伺服器建立儲存節點 (Storage)
data:image/s3,"s3://crabby-images/37df2/37df2ccc05ebef67d9d077391dbadbcff1eb53c8" alt="node3-create-storage"
data:image/s3,"s3://crabby-images/fecb7/fecb77c0ca4304b947f8cba4c84cc159cb44075d" alt="node3-edit-storage-config"
#建立目錄
mkdir -p /opt/tahoe-lafs/Node3;
#進入目錄
cd /opt/tahoe-lafs/Node3;
#建立儲存節點
tahoe create-node --hostname=自訂HostName --introducer=取得的PD連捷 .
tahoe create-node --hostname=node3.test.example --introducer=pb://i5pyrfw3k5fbdtkz7bkkvco2zgh52qnf@tcp:node1.test.example:44421/nlchhrixoavrenvzyrju4rqil4lgg6cv .
#編輯 tahoe.cfg
nano tahoe.cfg
#新增暱稱
nickname = Node3
#將這兩行註解掉
#web.port = tcp:3456:interface=127.0.0.1
#web.static = public_html
13. 啟動第一台伺服器上的 Gateway 並建立起始文件目錄 (rootcap)
data:image/s3,"s3://crabby-images/ae76d/ae76d686d68333282a735c103e00f8969396bb61" alt="create-rootcap-and-get-uri"
#建立資料夾用來儲存 alias.tmp
mkdir -p /root/.tahoe/private/
#啟動第一台伺服器上的 Gateway
tahoe run /opt/tahoe-lafs/clientGWNode1 &
#建立名為"dir1"的起始文件目錄 (rootcap)
tahoe create-alias --node-url=http://node1-ip:3456 自訂DirName
tahoe create-alias --node-url=http://10.100.101.191:3456 dir1
#取得所有目錄的 DRI
tahoe list-aliases --node-url=http://node1-ip:3456
tahoe list-aliases --node-url=http://10.100.101.191:3456
#URI格式如下
dir1: URI:DIR2:t4uk6xflrjqsgjydowdbzfgypq:p55vyewexnovxjy2dl7dinupzzf3do23dbdxym2eu3ltevjakvla
14. 啟動第二台、第三台上的儲存節點
data:image/s3,"s3://crabby-images/977f0/977f09588d4d7f790365cdabea7ecfb5f3641d08" alt="node2-run-tahoe"
data:image/s3,"s3://crabby-images/68ad2/68ad24441e464056118e1e813abc30418eb2db13" alt="node3-run-tahoe"
#啟動第二台伺服器上的儲存節點 (需在第二台下指令)
tahoe run /opt/tahoe-lafs/Node2 &
#啟動第三台伺服器上的儲存節點 (需在第三台下指令)
tahoe run /opt/tahoe-lafs/Node3 &
15. 打開網頁即可使用
#瀏覽器開啟
http://server1-ip:3456
data:image/s3,"s3://crabby-images/0b347/0b347113e146d03972fc34f3b13d993c420b14a9" alt="tahoe-lafs-web-ui"
16. 瀏覽起始文件目錄 (rootcap)
將前面取得的URI填入後按下 “View File or Directory »”,即可瀏覽目錄。
dir1:URI:DIR2:t4uk6xflrjqsgjydowdbzfgypq:p55vyewexnovxjy2dl7dinupzzf3do23dbdxym2eu3ltevjakvla
data:image/s3,"s3://crabby-images/dd4c7/dd4c79fc175e055d3c1ec932c77dba42d0d977d1" alt="tahoe-lafs-web-ui-insert-rootcap-uri"
data:image/s3,"s3://crabby-images/46deb/46deb98d56e321e7d2772aa75a6ec00b5c6b8ff9" alt="tahoe-lafs-web-ui-rootcap-view"
17. 中斷執行第一台伺服器上的 Gateway
data:image/s3,"s3://crabby-images/bcdfd/bcdfd154e7c316677332b5f9eb0469cfba753811" alt="break-clientGWNode1"
#列出所有後台執行的工作
jobs
#fg num 將後台執行的叫回前台
fg 2
# Ctrl + C 停止程式執行
Ctrl + C
18. 產生 SSH 公鑰、私鑰
data:image/s3,"s3://crabby-images/b3b71/b3b71699ae61d32d7b8dd77ed9a3ae277de8f725" alt="generate-ssh-privite-and-public-key"
#進入目錄
cd /opt/tahoe-lafs/clientGWNode1;
#產生公鑰、私鑰 (出現要輸入passphare時,直接按Enter。)
ssh-keygen -f private/ssh_host_rsa_key
#查看產生出來的公鑰
cat private/ssh_host_rsa_key.pub
#先記下 ssh-ras 開始到 username@hostname 這段前面
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cj67pxqo0v0TBK6g6WR0gkon9MvdH/zsrt6W6A0MNVUhnPCV2F2aFodojwTAvkEai+gWb/InXptCf8MBYXzrF9Tfftb59JSxbQ0bk49G9CxjSBGBrqtMVpW6R7DrI4jJOCiBywQonHr6YhqHZkXIIi7AZCfu2DKNK+xLWtlJKAOxR4xC51YQEs/wCCYZov0uSV0ccfgUEgEszz/bD/EqNZKiH/yzqXn1BBbOBig423jYJxGZJKwfcjMbcuIWA9QWIUNnVwd4p+l8u7Z/m3na6yC8L9Ogh34odOHkfXXxSpsooeQCM5d+c8ABIpLJTaKPuAbAqf5nbBp9HMp9D+lPLsChBNlejwlnpNyeSHyrKsfzRTLpL4/x4ewfbNuoUiZW5sT3GLPOfq1vrCHwSQRfIib9hpYntOAqKULi3qf7njk0BTQwsaWcUZremsNdbGOZd4adEjthlEFGPsdkw+wT1VSI7r2tnlyyl99N3F1eqb2reK8rxz7Szb+UNQ6UN20=
#複製一份私鑰到根目錄下
cp /opt/tahoe-lafs/clientGWNode1/private/ssh_host_rsa_key /ssh_host_rsa_key
#修改權限,讓非root用戶也可以讀取
chmod 775 /ssh_host_rsa_key
19. 新增 Tahoe-LAFS SFTP 帳號
data:image/s3,"s3://crabby-images/9f136/9f136c17c8c08bdbe7f77ea6fe40ffdda87c6c58" alt="edit-sftp-accounts-list"
data:image/s3,"s3://crabby-images/daf97/daf97e975f574359f616daeb8deb88cfae32e2a5" alt="edit-sftp-accounts"
#編輯帳號
nano private/accounts
#SFTP 帳號格式
username ssh-rsa public-key 之前取得的URI
#新增一行
root ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cj67pxqo0v0TBK6g6WR0gkon9MvdH/zsrt6W6A0MNVUhnPCV2F2aFodojwTAvkEai+gWb/InXptCf8MBYXzrF9Tfftb59JSxbQ0bk49G9CxjSBGBrqtMVpW6R7DrI4jJOCiBywQonHr6YhqHZkXIIi7AZCfu2DKNK+xLWtlJKAOxR4xC51YQEs/wCCYZov0uSV0ccfgUEgEszz/bD/EqNZKiH/yzqXn1BBbOBig423jYJxGZJKwfcjMbcuIWA9QWIUNnVwd4p+l8u7Z/m3na6yC8L9Ogh34odOHkfXXxSpsooeQCM5d+c8ABIpLJTaKPuAbAqf5nbBp9HMp9D+lPLsChBNlejwlnpNyeSHyrKsfzRTLpL4/x4ewfbNuoUiZW5sT3GLPOfq1vrCHwSQRfIib9hpYntOAqKULi3qf7njk0BTQwsaWcUZremsNdbGOZd4adEjthlEFGPsdkw+wT1VSI7r2tnlyyl99N3F1eqb2reK8rxz7Szb+UNQ6UN20= URI:DIR2:2utf3uohyx6hx557yr77cjlalm:s5nn5cit3j5vlkyxeg3pwt6tiaal2z4zcuow43sqvxso6fau3yua
20. 修改 tahoe.cfg
data:image/s3,"s3://crabby-images/7ebdd/7ebddfecd954845aa8ace4d977fd8567abe290ee" alt="node1-edit-gateway-tahoe-cfg"
data:image/s3,"s3://crabby-images/4118d/4118dbf0039cd8d0a9a559abd83bb2a1f4da477e" alt="node1-edit-gateway-sftp-config"
#編輯 tahoe.cfg
nano tahoe.cfg
#將以下幾行新增至 tahoe.cfg 最後面
[sftpd]
enabled = true
port = tcp:8022:interface=0.0.0.0
host_pubkey_file = private/ssh_host_rsa_key.pub
host_privkey_file = private/ssh_host_rsa_key
accounts.file = private/accounts
21. 啟動第一台伺服器上的 Gateway
data:image/s3,"s3://crabby-images/66705/667053162867fd0fa3d1c7acabb54ee3de65b2fe" alt="node1-run-tahoe-gateway"
#啟動第一台伺服器上的 Gateway
tahoe run /opt/tahoe-lafs/clientGWNode1 &
22. 透過 WinSCP 將私鑰匯出
data:image/s3,"s3://crabby-images/d7c85/d7c85c560e31e81bcc1a86481e506ed01f2ca251" alt="sftp-login"
data:image/s3,"s3://crabby-images/a6770/a67709323eb999718cf8993933a3743b409f17a0" alt="sftp-download-ssh-rsa-private-key"
23. WinSCP 開啟新工作階段,連線Tahoe-LASF SFTP。
data:image/s3,"s3://crabby-images/38c0f/38c0f8b57a3570914ca86cbaefb803d7fbaae71a" alt="tahoe-sftp-login-1"
data:image/s3,"s3://crabby-images/11523/115230d5d1552fd05f022282db4ab0dac2a78764" alt="tahoe-sftp-enable-utf8"
data:image/s3,"s3://crabby-images/3ce9e/3ce9e59e790cf559cd371e788abcf79b39647568" alt="tahoe-sftp-edit-timeout-timer"
data:image/s3,"s3://crabby-images/8505f/8505fa9d8f939a6458ef8a1f1df271d1d04d4db7" alt="tahoe-sftp-select-private-key"
data:image/s3,"s3://crabby-images/89dff/89dff2f425d637b663d959f5214683d2285bb3a6" alt="tahoe-sftp-select-private-key-2"
data:image/s3,"s3://crabby-images/8fd26/8fd26a3ca42d1c1519f07f937ce40709d222ab22" alt="tahoe-sftp-convert-private-key-format"
data:image/s3,"s3://crabby-images/1c8a0/1c8a007c9b8e9e028c2d7f0823cdb65a41cb36b9" alt="tahoe-sftp-convert-private-key-format-save-success"
data:image/s3,"s3://crabby-images/27fc4/27fc4adb04ffaa630e648496c6ecb2d5db7e4481" alt="tahoe-sftp-set-advanced-setting-complet"
data:image/s3,"s3://crabby-images/b9002/b90022f9ec9ff2d7dfb8694bb260d7b3c3d0e467" alt="tahoe-sftp-connecting"
data:image/s3,"s3://crabby-images/a211b/a211b69988b9ae48db6bd232244967c487196d6e" alt="tahoe-sftp-connecting-input-username"
data:image/s3,"s3://crabby-images/2a26b/2a26be0579e299030e04a5552ebe15f033ade5f0" alt="tahoe-sftp-connected"
24. 設定Tahoe-LAFS開機自動啟動
#編輯 tahoe-introducer.service
nano /etc/systemd/system/tahoe-introducer.service
#填入以下內容並儲存離開
[Unit]
Description=Tahoe-LAFS autostart introducer
After=network.target
[Service]
Type=simple
User=root
WorkingDirectory=/opt/tahoe-lafs/intro-test/
ExecStart=tahoe run /opt/tahoe-lafs/intro-test/ --logfile=logs/introducer.log
[Install]
WantedBy=multi-user.target
#開機自動啟動服務
systemctl enable tahoe-introducer.service
#查看服務狀態
systemctl status tahoe-introducer.service
#編輯 tahoe-gateway.service
nano /etc/systemd/system/tahoe-gateway.service
#填入以下內容並儲存離開
[Unit]
Description=Tahoe-LAFS Storage Node1
After=network.target
[Service]
Type=simple
User=root
WorkingDirectory=/opt/tahoe-lafs/clientGWNode1
ExecStart=tahoe run /opt/tahoe-lafs/clientGWNode1 --logfile=logs/introducer.log
[Install]
WantedBy=multi-user.target
#開機自動啟動服務
systemctl enable tahoe-gateway.service
#查看服務狀態
systemctl status tahoe-gateway.service
#Node2 Tahoe Storage 自動啟動
#編輯 tahoe-gateway.service
nano /etc/systemd/system/tahoe-storage.service
#填入以下內容並儲存離開
[Unit]
Description=Tahoe-LAFS Storage Node2
After=network.target
[Service]
Type=simple
User=root
WorkingDirectory=/opt/tahoe-lafs/Node2
ExecStart=tahoe run /opt/tahoe-lafs/Node2 --logfile=logs/introducer.log
[Install]
WantedBy=multi-user.target
#開機自動啟動服務
systemctl enable tahoe-storage.service
#查看服務狀態
systemctl status tahoe-storage.service
#Node3 Tahoe Storage 自動啟動
#編輯 tahoe-gateway.service
nano /etc/systemd/system/tahoe-storage.service
#填入以下內容並儲存離開
[Unit]
Description=Tahoe-LAFS Storage Node3
After=network.target
[Service]
Type=simple
User=root
WorkingDirectory=/opt/tahoe-lafs/Node3
ExecStart=tahoe run /opt/tahoe-lafs/Node3 --logfile=logs/introducer.log
[Install]
WantedBy=multi-user.target
#開機自動啟動服務
systemctl enable tahoe-storage.service
#查看服務狀態
systemctl status tahoe-storage.service