Rocksdb.errors.RocksIOError:IO错误:锁定文件时:sample.db/LOCK:资源暂时不可用

2024-01-02

如何删除rocksDB上的锁

我尝试运行以下代码但出现以下错误

 * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
 * Restarting with stat
Traceback (most recent call last):
File "hello flask.py", line 18, in <module>
rdb = rocksdb.DB("sample.db", rocksdb.Options(create_if_missing=True))
File "rocksdb/_rocksdb.pyx", line 1437, in 
rocksdb._rocksdb.DB.__cinit__ (rocksdb/_rocksdb.cpp:23176)
File "rocksdb/_rocksdb.pyx", line 84, in rocksdb._rocksdb.check_status 
(rocksdb/_rocksdb.cpp:3453)
rocksdb.errors.RocksIOError: IO error: While lock file: sample.db/LOCK: 
Resource temporarily unavailable

Code :

from flask import Flask
import rocksdb

app = Flask(__name__)

@app.route('/hello/<name>')
def hello_name(name):
    value = name.encode(encoding='UTF-8',errors='strict')
    rdb.put(b'name', value)
    return 'Hello %s!' % rdb.get(b'name')

@app.route('/')
def hello():
    return 'Welcome'

if __name__ == '__main__':
    rdb = rocksdb.DB("sample.db", rocksdb.Options(create_if_missing=True))
    app.run(debug = True)

我在运行 write_stress 测试(tools/write_stress_runner.py)时遇到了类似的问题。 我建议你

  1. 检查RocksDB进程是否有太多打开的文件(看起来不像 从您的应用程序代码来看就是这种情况)。
  2. 检查您的应用程序的另一个实例是否正在运行。
  3. 删除 LOCK 文件并运行您的应用程序(sample.db/LOCK)。

    os.system('rm sample.db/LOCK')
    
    rdb = rocksdb.DB("sample.db", rocksdb.Options(create_if_missing=True))
    
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Rocksdb.errors.RocksIOError:IO错误:锁定文件时:sample.db/LOCK:资源暂时不可用 的相关文章

随机推荐