zookeeper啟動錯誤 transaction type: 2 error: KeeperErrorCode = NoNode for /hbase


hbase偽分布式,與zookeeper同一台機器的時候,運行一段時間,啟動zookeeper的時候,日志中有如下錯誤,導致無法啟動zookeeper

java.io.IOException: Failed to process transaction type: 2 error: KeeperErrorCode = NoNode for /hbase/unassigned
    at org.apache.zookeeper.server.persistence.FileTxnSnapLog.restore(FileTxnSnapLog.java:152)
    at org.apache.zookeeper.server.ZKDatabase.loadDataBase(ZKDatabase.java:222)
    at org.apache.zookeeper.server.ZooKeeperServer.loadData(ZooKeeperServer.java:239)
    at org.apache.zookeeper.server.ZooKeeperServer.startdata(ZooKeeperServer.java:366)
    at org.apache.zookeeper.server.NIOServerCnxn$Factory.startup(NIOServerCnxn.java:160)
    at org.apache.zookeeper.server.ZooKeeperServerMain.runFromConfig(ZooKeeperServerMain.java:110)
    at org.apache.hadoop.hbase.zookeeper.HQuorumPeer.runZKServer(HQuorumPeer.java:79)
    at org.apache.hadoop.hbase.zookeeper.HQuorumPeer.main(HQuorumPeer.java:64)

 

由於是偽分布式,zookeeper集成在hbase的機器上,hbase的臨時目錄默認是放在/tmp的,而linux的/tmp目錄是會被定期清理的(參考linux系統的tmpwatch)

所以解決辦法是,修改hbase-site.xml,指定hbase.tmp.dir,這樣hbase的tmp目錄不會被定時清理,over~

<configuration>

....(省略)

<property>
        <name>hbase.tmp.dir</name>
        <value>/hbase/tmp</value>
        <description>Temporary directory on the local filesystem.</description>
</property>

</configuration>

 


免責聲明!

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



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