0

webfaction に webapp を正常にアップロードしましたが、peewee を使用して webfaction アカウントの MySQL データベースに接続すると、次のエラーが発生することに気付きました。

ProgrammingError: (1146, "Table 'TABLEGOESHERE' doesn't exist")

正確なエラーは、以下のエラー ログ ファイルにあります。

背景情報:

  • webfaction で MySQL データベースを作成しました

  • サービスが提供するコントロール パネル内にテーブルを作成しませんでした。完全に空です。

  • ターミナルを介してフラスコアプリを正常に実行できますが、Webサーバーでライブにしようとしているため、このプロセスは初めてです。

peewee を使用している場合、次のようにプログラム内からテーブルを作成できると想定しました。

models.py

# -- Peewe Modules
from peewee import *

DATABASE = MySQLDatabase("DBNAMEGOESHERE", host="HOSTGOESHERE", port=PORTGOESHERE, user="USERGOESHERE", passwd="PASSGOESHERE")

# -- DATABASE OBJECTS GO HERE:

#-- INIT
def initialize():
    DATABASE.connect()
    DATABASE.create_tables([Post, etc...],safe=True)
    DATABASE.close()

初期化関数は、ファイルの下部にある__init__.pyファイルで次のように呼び出されます。

if __name__ == "__main__":
    models.initialize()
    try:
        models.User.create_user(
            username = 'user',
            email = 'email',
            password = 'pass',
            is_admin = True,
            confirmed = True,
            confirmed_on = datetime.datetime.now(),
        )
    except ValueError:
        pass
    app.run()

('/') にルーティングされるインデックス ビューは、__init__.pyファイルで次のように count メソッドを呼び出します。

count = models.Post.select().count()

そして、この行が原因で私のサイトに 500 内部サーバー エラーが表示され、このエラー ログが生成されたと思います (わかりやすくするために、タイムスタンプは削除されています)。

return self.wsgi_app(environ, start_response)

File "/home/username/webapps/myapp/myapp/__init__.py", line 49, in __call__
return self.app(environ, start_response)

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1820, in wsgi_app
response = self.make_response(self.handle_exception(e))

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1403, in handle_exception
reraise(exc_type, exc_value, tb)

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1817, in wsgi_app
response = self.full_dispatch_request()

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1477, in full_dispatch_request
rv = self.handle_user_exception(e)

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1381, in handle_user_exception
reraise(exc_type, exc_value, tb)

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1475, in full_dispatch_request
rv = self.dispatch_request()

File "/home/username/lib/python2.7/Flask-0.10.1-py2.7.egg/flask/app.py", line 1461, in dispatch_request
return self.view_functions[rule.endpoint](**req.view_args)

File "/home/username/webapps/myapp/myapp/__init__.py", line 587, in index
count = models.Post.select().count()

File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 2792, in count
return self.aggregate(convert=False) or 0

 File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 2785, in aggregate
return self._aggregate(aggregation).scalar(convert=convert)

File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 2564, in scalar
row = self._execute().fetchone()

File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 2555, in _execute
return self.database.execute_sql(sql, params, self.require_commit)

File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 3366, in execute_sql
self.commit()

File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 3212, in __exit__
reraise(new_type, new_type(*exc_args), traceback)

File "/home/username/lib/python2.7/peewee-2.7.3-py2.7.egg/peewee.py", line 3359, in execute_sql
cursor.execute(sql, params or ())

 File "/usr/lib64/python2.7/site-packages/MySQLdb/cursors.py", line 174, in execute
self.errorhandler(self, exc, value)

File "/usr/lib64/python2.7/site-packages/MySQLdb/connections.py", line 36, in defaulterrorhandler
   raise errorclass, errorvalue
ProgrammingError: (1146, "Table 'DATABASENAMEHERE.post' doesn't exist")

この問題の特定と修正を手伝ってくれる人はいますか? フラスコアプリを webfaction 上の MySQL データベースと連携させる方法がわかりません。

4

2 に答える 2

2

コマンドラインから直接アプリケーションを実行して、アプリケーションが実行されていることを確認してください。つまり、__name__ == '__main__'ブロックは実際に実行されていますか? 代わりに専用の WSGI サーバーを使用している可能性はありますか?

于 2015-12-02T04:58:25.727 に答える
1

サーバーの初期化コードを、Webfaction で Flask アプリを実行するファイルに移動しました。コマンドライン用であるため、条件の下に追加のコードを配置することはお勧めしません。

于 2015-12-02T19:01:02.443 に答える