2

我在使用. _ _ 每次我尝试使用数据库例如设置默认值时:mod_wsgi

from flaskext.zodb import zodb, List

db = ZODB(app)
app.config.from_pyfile('settings.py') # here I have defined ZODB_STORAGE = "/home/username/webapps/myapp/htdocs/Data.fs"

@app.before_request
def set_db_defaults():
   if 'entries' not in db:
       db['entries'] = List()

或在这样的视图中:

@app.route('/add', methods=['POST'])
def add_entry():
   db['entries'].append(request.form)
   flash('New entry was successfully posted')
   return redirect(url_for('show_entries'))

我收到以下错误:

[Sat May 19 16:52:30 2012] [error] [client 127.0.0.1]
self._lock_file = LockFile(file_name + '.lock')
[Sat May 19 16:52:30 2012] [error] [client 127.0.0.1]   File
"/home/userame/.virtualenvs/myapp/lib/python2.7/site-packages/zc/lockfile/__init__.py",
line 76, in __init__
[Sat May 19 16:52:30 2012] [error] [client 127.0.0.1]     _lock_file(fp)
[Sat May 19 16:52:30 2012] [error] [client 127.0.0.1]   File
"/home/username/.virtualenvs/myapp/lib/python2.7/site-packages/zc/lockfile/__init__.py",
line 59, in _lock_file
[Sat May 19 16:52:30 2012] [error] [client 127.0.0.1]     raise
LockError("Couldn't lock %r" % file.name)
[Sat May 19 16:52:30 2012] [error] [client 127.0.0.1] LockError:
Couldn't lock '/home/username/webapps/myapp/htdocs/Data.fs.lock'

该应用程序在开发环境中运行良好,我不认为存在权限问题,因为我尝试设置:

ZODB_STORAGE = "/tmp"

并引发了同样的异常。我不明白为什么会发生这种情况以及如何避免这种错误。有任何想法吗?

4

1 回答 1

5

您正在尝试从多个进程打开 ZODB;大概在开发中您只使用一个 WSGI 进程。这基本上是ZODB 中 zc.lockfile.LockError的欺骗。

您的选择是:

  1. 将您的生产环境限制在一个进程中。

  2. 使用 ZEO,见参考问题;zodburi等价物zeo://localhost:9100.

  3. 使用 RelStorage。您可以使用ZConfig URI 方案进行连接,前提是 RelStorage egg 可用。这在旧repoze.zodbconn名称下的 RelStorage 文档中有记录。

于 2012-05-21T09:25:53.110 回答