1

如何删除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)
4

1 回答 1

1

我在运行 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))
    
于 2017-11-22T06:48:49.247 回答