如何删除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)时遇到了类似的问题。
我建议你
- 检查RocksDB进程是否有太多打开的文件(看起来不像
从您的应用程序代码来看就是这种情况)。
- 检查您的应用程序的另一个实例是否正在运行。
-
删除 LOCK 文件并运行您的应用程序(sample.db/LOCK)。
os.system('rm sample.db/LOCK')
rdb = rocksdb.DB("sample.db", rocksdb.Options(create_if_missing=True))
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)