zookeeper启动错误 transaction type: 2 error: KeeperErrorCode = NoNode for /hbase

本文解决HBase伪分布式环境下,Zookeeper启动时报错Failed to process transaction type: 2 error的问题。通过修改hbase-site.xml配置文件,指定hbase.tmp.dir路径,避免了Linux系统定时清理导致的问题。此解决方案适用于Hadoop环境下的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>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值