單獨的使用Samba掛載gluster volume并不能實現(xiàn)High Availability,有了CTDB就可以解決這個問題了.
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),西崗企業(yè)網(wǎng)站建設(shè),西崗品牌網(wǎng)站建設(shè),網(wǎng)站定制,西崗網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,西崗網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
1 準備環(huán)境
我已經(jīng)提前準備好了一個gluster環(huán)境,創(chuàng)建好了一個volume repvol,并且此volume已經(jīng)配置為可使用samba client掛載,有關(guān)詳細配置請參考我前面的博文。
[root@node02 /]# gluster pool list UUID Hostname State e967c77f-ff39-4927-9645-606294d42751 node01.lab.example.com Connected 98ef6fd9-9fa1-4005-b8ec-5480d6c04f46 localhost Connected
[root@node02 /]# gluster volume list repvol
[root@node02 ~]# smbclient -L node01.lab.example.com -U%
Domain=[SAMBA] OS=[Windows 6.1] Server=[Samba 4.4.4]
Sharename Type Comment
--------- ---- -------
print$ Disk Printer Drivers
gluster-repvol Disk For samba share of volume repvol
IPC$ IPC IPC Service (Samba 4.4.4)
Domain=[SAMBA] OS=[Windows 6.1] Server=[Samba 4.4.4]
Server Comment
--------- -------
Workgroup Master
--------- -------
[root@node02 mnt]# mount -t cifs -o username=smbuser,password=redhat //node01.lab.example.com/gluster-repvol /mnt/samba-test/
[root@node02 /]# df -h | grep samba //node01.lab.example.com/gluster-repvol 2.0G 33M 2.0G 2% /mnt/samba-test
從上面可以看到,我這里有兩個gluster server,依次為
192.168.133.144 node01.lab.example.com
192.168.133.149 node02.lab.example.com
而掛載的時候,我使用的是//node01.lab.example.com/gluster-repvol,這樣有一個問題,雖然我這里的gluster volume repvol是一個2副本的復(fù)制卷,但一旦node01.lab.example.com出現(xiàn)故障,雖然node02.lab.example.com上還保留一份數(shù)據(jù)在,但是卻不能直接被client使用,不能夠?qū)崿F(xiàn)自動切換。
2 在兩臺gluster server上安裝配置ctdb
2.1使用yum安裝ctdb
[root@node01 ~]# yum install -y ctdb
為ctdb放開防火墻限制
[root@node01 ~]# firewall-cmd --add-port=4379/tcp
2.2更新volume設(shè)置
[root@node01 ~]# gluster volume stop repvol [root@node01 post]# cd /var/lib/glusterd/hooks/1/start/post [root@node01 post]# vi S29CTDBsetup.sh
META="all" 修改前
META="ctdbmeta" 修改后
2.3更新Samba配置
編輯/etc/samba/smb.conf文件,并在[global]選項下添加 clustering=yes
[root@node01 post]# cat /etc/samba/smb.conf ... [global] clustering = yes ....
2.4start volume,此時會發(fā)現(xiàn)volume 會自動掛載到server的/gluster/lock 下
[root@node01 post]# gluster volume start repvol volume start: repvol: success
[root@node01 post]# df -h | grep repvol node01.lab.example.com:/repvol.tcp 2.0G 33M 2.0G 2% /gluster/lock
2.5添加/etc/ctdb/nodes 和 /etc/ctdb/public_address文件
[root@node01 post]# vi /etc/ctdb/nodes 192.168.133.144 192.168.133.149
###這里的ip為gluster server節(jié)點的ip
[root@node01 post]# vi /etc/ctdb/public_addresses 192.168.133.100/24 ens33
###這里的ip是浮動ip, ens33為interface name
2.6啟動并驗證ctdb service
[root@node01 post]# systemctl start ctdb
[root@node01 post]# ctdb pnn PNN:0
[root@node01 post]# ctdb ping -n all response from 0 time=0.000049 sec (2 clients) response from 1 time=0.008014 sec (1 clients)
[root@node01 post]# ctdb status Number of nodes:2 pnn:0 192.168.133.144 OK (THIS NODE) pnn:1 192.168.133.149 OK Generation:2009096591 Size:2 hash:0 lmaster:0 hash:1 lmaster:1 Recovery mode:RECOVERY (1) Recovery master:1 [root@node01 post]# ctdb ip Public IPs on node 0 192.168.133.100 0
[root@node01 post]# ctdb ip info 192.168.133.100 Public IPs on node 0 192.168.133.100 0
2.7使用浮動ip掛載gluster volume
[root@node02 post]# mount -t cifs -o username=smbuser,password=redhat //192.168.133.100/gluster-repvol /mnt/samba-test/