2016-09-09 10 views
1

私はPythonのコマンドラインを直接使用するとうまく動作するFlask-Web-Appを開発しました。しかし、mod-wsgiでApache2にデプロイすると、内部モジュールをインポートすることができません。私は関連するすべての記事を私のように読みましたが、まだ問題を把握できませんでした。まず、以下を試しました。私のApache WSGI Flask web-appは内部のPythonモジュールをインポートできません

1 - アプリケーションフォルダの下にあるすべてのファイルとサブフォルダがwww-data( "Apache2サービスアカウント")のrwxアクセス権を持っていることを確認しました。

2 - WSGIPythonPath/var/www/FlaskApp/FlaskApp/Base /:/ var/www/FlaskApp/FlaskApp/Base/Form /:/ var/www/FlaskApp/FlaskApp/Base/Model /(以下を参照)

3 - wsgiスクリプトのsys.path変数へのモジュールパスを追加しました。私はちょうど私はおそらく見逃しているかもしれない他に何他のアイデアを持っていない

# internal imports 
import Base.Model as Model 
from Base import Constant as cnst 
from Base.Form import UserRegistrationForm, ProductForm 
. 
. 
. 

if __name__ == "__main__": 
    app.run() 

#!/usr/bin/python 
import sys 
import logging 
logging.basicConfig(stream=sys.stderr) 
sys.path.insert(0,"/var/www/FlaskApp/") 
sys.path.append('/var/www/FlaskApp/FlaskApp/Base/') 
sys.path.append('/var/www/FlaskApp/FlaskApp/Base/Form/') 
sys.path.append('/var/www/FlaskApp/FlaskApp/Base/Model/') 

from FlaskApp import app as application 
application.secret_key = 'as345kj34h5kljj34sy' 

すべての私の内部の輸入は、以下のようなアプリケーションを起動するのinitの.pyです。 Pythonインタプリタをコマンドラインから使用すると、すべてうまく動作します。

あなたは助けてくれてありがとうございます。

よろしく、 メフディ/マイク

Error.logです

[Fri Sep 09 22:59:43.068802 2016] [mpm_event:notice] [pid 10719:tid 139878768617344] AH00489: Apache/2.4.7 (Ubuntu) mod_wsgi/3.4 Python/2.7.6 configured -- resuming normal operations 
[Fri Sep 09 22:59:43.068872 2016] [core:notice] [pid 10719:tid 139878768617344] AH00094: Command line: '/usr/sbin/apache2' 
[Fri Sep 09 22:59:47.926252 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] mod_wsgi (pid=10720): Target WSGI script '/var/www/FlaskApp/flaskapp.wsgi' cannot be loaded as Python module. 
[Fri Sep 09 22:59:47.926300 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] mod_wsgi (pid=10720): Exception occurred processing WSGI script '/var/www/FlaskApp/flaskapp.wsgi'. 
[Fri Sep 09 22:59:47.926325 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] Traceback (most recent call last): 
[Fri Sep 09 22:59:47.926343 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] File "/var/www/FlaskApp/flaskapp.wsgi", line 10, in <module> 
[Fri Sep 09 22:59:47.926403 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866]  from FlaskApp import app as application 
[Fri Sep 09 22:59:47.926414 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] File "/var/www/FlaskApp/FlaskApp/__init__.py", line 22, in <module> 
[Fri Sep 09 22:59:47.926848 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866]  from Base.Form import UserRegistrationForm, ProductForm 
[Fri Sep 09 22:59:47.926889 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] File "/var/www/FlaskApp/FlaskApp/Base/Form/__init__.py", line 1, in <module> 
[Fri Sep 09 22:59:47.926975 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866]  from UserRegistrationForm import UserRegistrationForm 
[Fri Sep 09 22:59:47.927007 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] File "/var/www/FlaskApp/FlaskApp/Base/Form/UserRegistrationForm.py", line 2, in <module> 
[Fri Sep 09 22:59:47.927098 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866]  from Base.Model import db_session, User 
[Fri Sep 09 22:59:47.927156 2016] [:error] [pid 10720:tid 139878671300352] [client ::1:55866] ImportError: No module named Base.Model 

flaskapp.wsgi

#!/usr/bin/python 
import sys 
import logging 
logging.basicConfig(stream=sys.stderr) 
sys.path.insert(0,"/var/www/FlaskApp/") 
sys.path.append('/var/www/FlaskApp/FlaskApp/Base/') 
sys.path.append('/var/www/FlaskApp/FlaskApp/Base/Form/') 
sys.path.append('/var/www/FlaskApp/FlaskApp/Base/Model/') 

from FlaskApp import app as application 
application.secret_key = 'as345kj34h5kljj34sy' 

FlaskApp.conf

WSGIPythonPath /var/www/FlaskApp/FlaskApp/Base/:/var/www/FlaskApp/FlaskApp/Base/Form/:/var/www/FlaskApp/FlaskApp/Base/Model/ 

<VirtualHost *:80> 
    ServerName localhost 
    ServerAdmin [email protected] 
    WSGIScriptAlias//var/www/FlaskApp/flaskapp.wsgi 
    <Directory /var/www/FlaskApp/FlaskApp/> 
     Order allow,deny 
     Allow from all 
    </Directory> 
    Alias /static /var/www/FlaskApp/FlaskApp/static 
    <Directory /var/www/FlaskApp/FlaskApp/static/> 
     Order allow,deny 
     Allow from all 
    </Directory> 
    ErrorLog ${APACHE_LOG_DIR}/error.log 
    LogLevel warn 
    CustomLog ${APACHE_LOG_DIR}/access.log combined 

</VirtualHost> 

答えて

1

の代わりに:

WSGIPythonPath /var/www/FlaskApp/FlaskApp/Base/:/var/www/FlaskApp/FlaskApp/Base/Form/:/var/www/FlaskApp/FlaskApp/Base/Model/ 

<VirtualHost *:80> 
    ServerName localhost 
    ServerAdmin [email protected] 
    WSGIScriptAlias//var/www/FlaskApp/flaskapp.wsgi 
    <Directory /var/www/FlaskApp/FlaskApp/> 
     Order allow,deny 
     Allow from all 
    </Directory> 
    Alias /static /var/www/FlaskApp/FlaskApp/static 
    <Directory /var/www/FlaskApp/FlaskApp/static/> 
     Order allow,deny 
     Allow from all 
    </Directory> 
    ErrorLog ${APACHE_LOG_DIR}/error.log 
    LogLevel warn 
    CustomLog ${APACHE_LOG_DIR}/access.log combined 

</VirtualHost> 

使用してみてください:作ら

<VirtualHost *:80> 
    ServerName localhost 
    ServerAdmin [email protected] 
    WSGIDaemonProcess myapp python-path=/var/www/FlaskApp/FlaskApp 
    WSGIScriptAlias//var/www/FlaskApp/flaskapp.wsgi process-group=myapp application-group=%{GLOBAL} 
    <Directory /var/www/FlaskApp> 
    <Files flaskapp.wsgi> 
     Order allow,deny 
     Allow from all 
    </Files> 
    </Directory> 
    Alias /static /var/www/FlaskApp/FlaskApp/static 
    <Directory /var/www/FlaskApp/FlaskApp/static/> 
     Order allow,deny 
     Allow from all 
    </Directory> 
    ErrorLog ${APACHE_LOG_DIR}/error.log 
    LogLevel warn 
    CustomLog ${APACHE_LOG_DIR}/access.log combined 

</VirtualHost> 

変更点は以下のとおりです。モードを埋め込まれていない

  1. 使用のmod_wsgiデーモンモード。 http://blog.dscpl.com.au/2012/10/why-are-you-using-embedded-mode-of.html
  2. Apacheディレクトリアクセス許可を修正してください。それがうまくいっていれば、Apache設定のどこか他の場所でセキュリティ設定が緩慢になっていることが示唆されているように、うまく動作していないはずだったことを示唆しています。これを優先するメカニズムに変更しましたが、Apacheの設定でApacheがファイルシステム内のすべてのファイルを処理できるようにする理由を考えてください。
  3. 正しいPythonモジュール検索パスを設定します。デーモンプロセスグループに切り替えた後、デーモンプロセスグループを終了しました。
  4. サブインタープリタで動作しないPythonのサードパーティ拡張モジュールの問題を回避するために、デーモンプロセスグループのPythonメイン(アプリケーション)インタープリタコンテキストを使用する場合。
+0

ハイレベルのコメント:)私は多くの場合、それのすべての詳細を理解するためにいつかかかります。しかし、今のところ私はDBアクセスのスレッド問題が発生しているようです。明らかに、sqlite3はマルチスレッドと互換性がありません。ここにエラーログがあります。 [:Sep 10 02:09:17.767883 2016] [:エラー] [pid 11618:tid 140582090196736] ProgrammingError:(sqlite3.ProgrammingError)スレッドで作成されたSQLiteオブジェクトは、同じスレッドでのみ使用できます。オブジェクトはスレッドid 140582190909184これはスレッドIDです。140582090196736 – user1941390

+0

修正いただきありがとうございます。そして私は私の答え[ここ](http://stackoverflow.com/questions/34009296/using-sqlalchemy-session-from-flask-raises-sqlite-objects-created-in-a-thread-c)を見つけました。 – user1941390

関連する問題