Omnicore启动失败处理办法,错误提示:Failed to load freeze state from leveldb
如果你最近重新启动了omnicored节点软件的话,可能会看到这个提示信息:
1 |
Failed to load freeze state from levelDB. It is unsafe to continue. |
然后启动失败而退出。本文给出上述问题的官方解决方案及故障原因分析。
同样,如果你使用图形版的omnicore-qt的话,可能会看到这个画面:
点击[OK]按钮后,omnicore-qt也就退出了。
无论你使用0.3.1版本还是最新的0.4.0版本的omnicored或omnicore-qt,上述错误都无法避免, 这导致你无法使用omni节点。
解决方案
正式解决方案:Omni官方承认这是一个软件bug,正式的解决方案是等待新的版本,但是目前新版本的发布日期还未确定。 你可以跟踪官方github的这个992# issue,来及时 获得omni节点软件新版本的动态。
临时解决方案:官方在twitter同时给出了在新版本发布之前的临时性解决方案:
简单地说,就是在启动omnicored时使用-startclean
选项。例如:
1 |
~$ omnicored -startclean |
这是一个费时的操作,依赖于你的机器配置与网络情况,可能需要几个小时甚至几天的时间。
避免重新启动:需要指出的是,这个Bug仅仅影响启动过程,如果你的omni节点还在正常运行就不用担心。 因此官方同时建议,在新的版本发布之前,最好不要重新启动omnicored或omnicore-qt。
原因分析
查看omnicore.log,你会发现omnicore在启动过程中解析omni协议的阶段,一条错误的USDT(资产类型:31) 冻结交易造成了软件失败。
问题是,这个错误的交易是怎么产生的?
一种可能的原因是,这是一个针对性伪造的攻击性交易,通过P2P连接传入omni节点软件,从而造成了omni节点软件 的启动故障。