繁体   English   中英

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

[英]rocksdb.errors.RocksIOError: IO error: While lock file: sample.db/LOCK: Resource temporarily unavailable

如何删除rocksDB上的LOCK

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

 * 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

代码:

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)) 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM