yum install zookeeper -y (版本:zookeeper.x86_64 3.4.6-1)
yum install zookeeper-lib -y
(版本:zookeeper-lib.x86_64 3.4.6-1)java
做以下修改:vim
maxClientCnxns=50
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/var/lib/zookeeper/data //保證目錄存在,不然啓動出錯。
dataLogDir=/var/lib/zookeeper/dateLogDir
clientPort=2181
autopurge.purgeInterval=3
autopurge.SnapRetainCount=3
server.1=節點1存儲網IP:2888:3888 //1,2,3對於在myid中寫入
server.2=節點2存儲網IP:2888:3888
server.3=節點3存儲網IP :2888:3888
做以下修改:函數
# zk buffer size 64M
export JVMFLAGS="-Djute.maxbuffer=0x3FFFFC0 $JVMFLAGS"
# java heap size 16GB
export JVMFLAGS="-Xms16g -Xmx16g $JVMFLAGS" //注意兩個16G要改
注:設置爲內存的1/4,測試域設置爲16G測試
作以下修改:spa
export JAVA_HOME=/usrcode
內容以下:orm
根據/etc/zookeeper/zoo.cfg中server.X設置,通常值爲1或者2或者3。server
#現行方案中,單獨掛載一個SATA硬盤。(部署環境中選擇zk節點上的/dev/sdl)blog
#mkfs.ext4 -T largefile /dev/*** (選擇一塊獨立磁盤)ip
#mkdir /var/lib/zookeeper/dateLogDir
#mount /dev/*** /var/lib/zookeeper/dateLogDir
#blkid /dev/*** 獲取UUID
#設置/etc/fstab,用vim /etc/fstab在最後添加以下行
#UUID=046498f8-a077-40b9-af84-7f8e9eed9afd /var/lib/zookeeper/dateLogDir ext4 defaults 0 0
註釋掉:#source /etc/rc.d/init.d/functions
修改#daemon -user zookeeper zkServer.sh start爲zkServer.sh start
修改#daemon -user zookeeper zkServer.sh stop爲zkServer.sh stop
修改
checkstatus() {
status –p $PIDFILE ${JAVA_HOME} /bin/java
RETVAL=$?
}
爲
status() {
zkServer.sh status
RETVAL=$?
return $RETVAL
}
並修改service status的函數入口:
status)
status
;;
檢查zk狀態命令
# service zookeeper start
# service zookeeper status
# yum install nmap-ncat -y
#echo stat|nc localhost 2181
sheepdog
yum install automake.noarch -y (版本:automake.noarch 1.13.4-3.el7)
yum install libtool -y (版本:libtool.x86_64 2.4.2-21.el7_2)
yum install userspace-rcu -y (版本:userspace-rcu.x86_64 0.7.9-1.el7)
yum install userspace-rcu-devel -y (版本:userspace-rcu-devel.x86_64 0.7.9-1.el7)
yum install yasm -y (版本:yasm.x86_64 1.2.0-4.el7)
cd sheepdog
./autogen.sh
./configure --enable-zookeeper --disable-corosync
make
make install
groupadd ebsadmin
useradd -g ebsadmin ebsadmin
mkdir /home/ebsadmin/serNode
chown ebsadmin:ebsadmin serNode -R
vim serNode/pc_san_conf.ini
注:看掛載了幾個盤,根據掛載的盤,來寫下面的文件
文件內容以下:
[RAID]
storage.path =/shd/meta,/shd/obj1,/shd/obj2,/shd/obj3,/shd/obj4,/shd/obj5,/shd/obj6,/shd/obj7,/shd/obj8,/shd/obj9,/shd/obj10,/shd/obj11,/shd/obj12
level =0
[SHEEPDOG]
shdcmds =/shd/meta,/shd/obj1,/shd/obj2,/shd/obj3,/shd/obj4,/shd/obj5,/shd/obj6,/shd/obj7,/shd/obj8,/shd/obj9,/shd/obj10,/shd/obj11,/shd/obj12 -p 7000-c zookeeper:172.18.12.144:2181,172.18.12.53:2181,172.18.12.17:2181-ldir=/var/log -z 1-i host=172.18.12.5,port=7001-y 172.16.172.5--nosync
建立sheepdog文件:[root@lrr2 serNode]# touch sheepdog
文件內容以下:
ulimit -n 409600
cmds=`grep "shdcmds"/home/ebsadmin/serNode/pc_san_conf.ini`&& SHEEP_OPTS=${cmds#shdcmds =}
/usr/sbin/sheep --pidfile /var/run/sheep.pid $(if[-z "$SHEEP_OPTS"]; then echo "--cluster local --log dst=syslog --upgrade /var/lib/sheepdog";else echo $SHEEP_OPTS; fi)
修改文件權限chmod +x /home/ebsadmin/serNode/sheepdog
文件內容以下:
[Unit]
Description=Sheepdog QEMU/KVM BlockStorage
After=network.target
Wants=syslog.target
[Service]
EnvironmentFile=-/etc/conf.d/sheepdog.conf
EnvironmentFile=-/etc/sysconfig/sheepdog
EnvironmentFile=-/etc/default/sheepdog
ExecStart=/bin/sh -c '/home/ebsadmin/serNode/sheepdog'
PIDFile=/var/run/sheep.pid
Type=forking
Restart=on-abort
StartLimitInterval=10s
StartLimitBurst=3
[Install]
WantedBy=multi-user.target
驗證sheepdog是否安裝成功
[root@lrr2 /]# type sheep
#service sheepdog start
#systemctl status sheepdog.servic
驗證功能好使
遇到的問題:
一、配置pc_san_conf.ini時填寫的路徑不對,覺得是填寫盤符,按如上填寫便可,注意建立shd目錄。
2.、由於以前安裝過sheepdog,致使sheep和dog的版本不一致,刪除/usr/bin和/usr/sbin/下的dog,而後從新編譯。