下載地址:官網或其餘鏡像 git
https://zookeeper.apache.org/ github
http://archive.apache.org/dist/zookeeper/web
命令: wget https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.4.10/zookeeper-3.4.10.tar.gz
解壓到相應路徑apache
tar -xzvf zookeeper-3.4.10.tar.gz -C /home/zookeeper
在主目錄下建立data和logs兩個目錄用於存儲數據和日誌vim
在conf目錄下新建zoo.cfg文件,寫入如下內容保存瀏覽器
mkdir data mkdir logs
cp zoo_sample.cfg zoo.cfg
vim zoo.cfg
tickTime=2000
dataDir=..path../zookeeper/data
dataLogDir=..path../zookeeper/logs
clientPort=2181
進入bin目錄,啓動、中止、重啓分和查看當前節點狀態(包括集羣中是何角色)別執行tomcat
./zkServer.sh start ./zkServer.sh stop ./zkServer.sh restart ./zkServer.sh status
僞集羣模式就是在同一主機啓動多個zookeeper並組成集羣,下邊以在192.168.220.128主機上創3個zookeeper組集羣爲例。bash
將經過第一大點安裝的zookeeper,複製成zookeeper1/zookeeper2/zookeeper3三份app
zookeeper1配置文件conf/zoo.cfg修改以下:webapp
tickTime=2000 dataDir=/usr/myapp/zookeeper1/data dataLogDir=/usr/myapp/zookeeper1/logs clientPort=2181 initLimit=5 syncLimit=2 server.1=192.168.220.128:2888:3888 server.2=192.168.220.128:4888:5888 server.3=192.168.220.128:6888:7888
zookeeper1的data/myid配置以下:
echo '1' > data/myid
zookeeper2配置文件conf/zoo.cfg修改以下:
tickTime=2000 dataDir=/usr/myapp/zookeeper2/data dataLogDir=/usr/myapp/zookeeper2/logs clientPort=3181 initLimit=5 syncLimit=2 server.1=192.168.220.128:2888:3888 server.2=192.168.220.128:4888:5888 server.3=192.168.220.128:6888:7888
zookeeper2的data/myid配置以下:
echo '2' > data/myid
zookeeper3配置文件conf/zoo.cfg修改以下:
tickTime=2000 dataDir=/usr/myapp/zookeeper3/data dataLogDir=/usr/myapp/zookeeper3/logs clientPort=4181 initLimit=5 syncLimit=2 server.1=192.168.220.128:2888:3888 server.2=192.168.220.128:4888:5888 server.3=192.168.220.128:6888:7888
zookeeper3的data/myid配置以下:
echo '3' > data/myid
最後使用1.4的命令把三個zookeeper都啓動便可,啓動順序隨意沒要求。
集羣模式就是在不一樣主機上安裝zookeeper而後組成集羣的模式;下邊以在192.168.220.128/129/130三臺主機爲例。
將第1.1到1.3步中安裝好的zookeeper打包複製到129和130上,並都解壓到一樣的目錄下。
三個zookeeper的conf/zoo.cfg修改以下:
tickTime=2000 dataDir=/usr/myapp/zookeeper-3.4.5/data dataLogDir=/usr/myapp/zookeeper-3.4.5/logs clientPort=2181 initLimit=5 syncLimit=2 server.1=192.168.220.128:2888:3888 server.2=192.168.220.129:2888:3888 server.3=192.168.220.130:2888:3888
對於129和130,因爲安裝目錄都是zookeeper-3.4.5因此dataDir和dataLogDir不須要改變,又因爲在不一樣機器上因此clientPort也不須要改變
因此此時129和130的conf/zoo.cfg的內容與128同樣便可。
128 data/myid修改以下:
echo '1' > data/myid
129 data/myid修改以下:
echo '2' > data/myid
130 data/myid修改以下:
echo '3' > data/myid
最後使用1.4的命令把三個zookeeper都啓動便可,啓動順序隨意沒要求。
應用鏈接zookeepr報錯:Session 0x0 for server 192.168.220.128/192.168.220.128:2181,unexpected error,closing socket connection and attempting reconnect;
先看端口可否telnet通,若是通則使用./zkServer.sh status查看zk是否確實已啓動,沒啓查看bin/zookeeper.out中的報錯。
bin/zookeeper.out中報錯:「zookeeper address already in use」;顯然端口被佔用,要麼是其餘進程佔用了配置的端口,要麼是上邊配置的clientPort和server中的端口有重複。
bin/zookeeper.out中報錯:Cannot open channel to 2 at election address /192.168.220.130:3888;這應該只是組成集羣的130節點未啓動,到130啓動起來zk即會正常。
1.到地址 https://github.com/alibaba/dubbo 下載dubbo源碼
打開命令操做模式 mvn package -Dmaven.skip.test=true
若是編譯時報下面的錯誤,須要修改 D:\技術資料\zookeeper\dubbo-master\dubbo-master\dubbo-admin目錄下的pom.xml文件
[ERROR] Failed to execute goal on project dubbo-admin: Could not resolve dependencies for project com.alibaba:dubbo-admin:war:2.5.4-SNAPSHOT: Could not find artifact com.alibaba:dubbo:jar:2.5.4-SNAPSHOT -> [Help 1]
將 <version>${project.parent.version}</version> 修改成<version>2.5.3</version>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>${project.parent.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.5.3</version>
</dependency>
4.編譯成功
6.把這個dubbo-admin-2.5.4-SNAPSHOT.war拷貝到 tomcat下的webapps目錄下
7 修改tomcat的端口爲8088,修改方法以下,打到conf下的文件 server.xml,由於zookeeper會用到8080的端口,因此爲了避免衝突,把Tomcat的端口改一下。記得必定要改!!!
8 啓動tomcat後,tomcat啓動命令爲 bin下,啓動後,dubbo-admin-2.5.4-SNAPSHOT.war包會自動解壓,在tomcat/webapps目錄下生成一個dubbo-admin-2.5.4-SNAPSHOT文件夾
修改dubbo-admin-2.5.4-SNAPSHOT/WEB-INF/文件夾下的dubbo.properties文件爲以下內容
9 先啓動zookeeper,而後再啓動tomcat,在瀏覽器輸入 http://localhost:8088/dubbo-admin-2.5.4-SNAPSHOT/
https://blog.csdn.net/s296850101/article/details/52638020