我们服务器内用leveldb存一些不是很重要的, 但是又需要(半)持久化的东西. 可是自从2016到现在, 碰见好几次不同类型的死锁. 直到今天, 才发现真正的原因, 那就是leveldb不支持fork.

所以在你使用leveldb的时候, 一定需要注意初始化顺序:

  • fork
  • init leveldb

或者:

  • init leveldb
  • close leveldb
  • fork
  • init leveldb

总之, 不能init leveldb然后再fork, 一旦这样做, 最后就会无限卡在leveldb::port::CondVar::Wait.

切记切记….

05-11 13:15