安裝zookeeper時候,可以查看進程啟動,但是狀態顯示報錯:Error contacting service. It is probably not running


安裝zookeeper-3.3.2的時候,啟動正常沒報錯,但zkServer.sh status查看狀態的時候卻出現錯誤,如下:

JMX enabled by default
Using config: /hadoop/zookeeper/bin/../conf/zoo.cfg
Error contacting service. It is probably not running.

jps查看進程,卻發現進程已啟動

7313  QuorumPeerMain

 

在網上查閱資料一共有三種解決方法:

1,打開zkServer.sh 找到status)

STAT=`echo stat | nc localhost $(grep clientPort "$ZOOCFG" | sed -e 's/.*=//') 2> /dev/null| grep Mode`
在nc與localhost之間加上 -q 1 (是數字1而不是字母l)
如果已存在則去掉
注:因為我用的zookeeper是3.4.5版本,所以在我的zkServer.sh腳本文件里根本沒有這一行,所以沒有生效

2,調用sh zkServer.sh status 遇到這個問題。百度,google了后發現有人是修改sh腳本里的一個nc的參數來解決,可在3.4.5的sh文件里並沒有找到nc的調用。配置文檔里指定的log目錄沒有創建導致出錯,手動增加目錄后重啟,問題解決。
注:我想不是日志的問題所以這個方法根本就沒有試

3,創建數據目錄,也就是在你zoo.cfg配置文件里dataDir指定的那個目錄下創建myid文件,並且指定id,改id為你zoo.cfg文件中server.1=localhost:2888:3888中的    1.只要在myid頭部寫入1即可.
注:在我第二次安裝的時候,沒有將myid文件創建在dataDir指定的那個目錄下,也報了該錯誤。之后在dataDir指定的那個目錄下創建myid文件就沒有報錯。

4 因為防火牆沒有關閉。關閉防火牆:

  #查看防火牆狀態

   service iptables status 

  #關閉防火牆
   service iptables stop
  #查看防火牆開機啟動狀態
   chkconfig iptables --list
  #關閉防火牆開機啟動
   chkconfig iptables off

 注意:我的確在開始時候沒有關閉防火牆,但是當我關閉防火牆之后也沒有解決問題。

5 沒有建立主機和ip之間的映射關系。

  建立主機和ip之間映射關系的命令為 vim /etc/hosts   在文件的末端加入各個主機和ip地址之間的映射關系就可以了。

  注意:只有在建立了映射關系之后,才可以將在同一個網段下的機器利用主機名進行文件傳遞。問題解決!

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM