質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Q&A

解決済

2回答

2591閲覧

apacheとWSGIの連携ができない

Tomo0225

総合スコア67

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

0グッド

1クリップ

投稿2021/12/26 11:44

CentoOS7上でApacheとWSGIを使用してWebサーバーを作る環境構築をしているのですが、ApacheにWSGIを連携ができません。
//etc/httpd/conf.dにwsgi.confを作成し以下の内容を書き込みました。
また//var/www/app下にtest_app.pyを作成し以下の内容としました。
その上で
service httpd restartを実行するとJob for httpd.service failed because the control process exited with error code.というエラーが出てしまいます。
service httpd configtest
を実行してみるとSyntax OKとでます。
色々調べてみたのですが原因が分かりません。何が原因でしょうか。

wsgi.conf

LoadModule wsgi_module /root/.pyenv/versions/3.6.2/lib/python3.6/site-packages/mod_wsgi/server/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so WSGIDaemonProcess myapp user=username group=username WSGIProcessGroup myapp WSGISocketPrefix /var/run/wsgi WSGIScriptAlias /app /var/www/app/test_app.py <Directory /var/www/app/> Options ExecCGI MultiViews Indexes MultiViewsMatch Handlers AddHandler wsgi-script .py AddHandler wsgi-script .wsgi DirectoryIndex index.html index.py test_app.py Order allow,deny Allow from all </Directory>

test_app.py

def aplication(environ, start_response): status = '200 OK' html = '<html>\n' \ '<body>\n' \ '<div style="width: 100%; font-size: 40px; font-weight: bold; text-align: center;">\n' \ 'WSGI テストページ(/var/www/app/test_app.py)\n' \ '</div>\n' \ '</body>\n' \ '</html>\n'.encode("utf-8") response_header = [('Content-type','text/html')] start_response(status,response_header) return [html]

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

angel_p_57

2021/12/26 14:07

> エラーが出てしまいます。 それだと「サービスの起動に失敗した」以上の情報がないので、失敗時のログを提示してください。 エラーログ ( 設定ファイルにある ErrorLog ディレクティブでファイル名を確認してください ) や、journalctl -u httpd の出力が候補となります。( 後者は journalctl -u httpd -S 12:00 のように、時刻指定で範囲を絞った方が良いかも知れません ) > wsgi.confを作成し 作成したという情報は良いと思いますが、そこに含まれる =username なんかは実設定値なのかフェイクに置き換えてるのか、見てはっきりしません。 また、「他の設定ファイルに手を入れたかどうか」が判断つかないので、デフォルトなら「OSのパッケージでインストールしたまま」とか、明記してください。
Tomo0225

2021/12/26 14:43

エラーログを確認したところめぼしいのはこのくらいしかありませんでした。 このような記述が見当たりました。 httpd: Syntax error on line 353 of /etc/httpd/conf/httpd.conf: Syntax error on line 1 of /etc/httpd/conf.d/wsgi.conf:Cannot load /root/.pyenv/versions/3.6.2/lib/python3.6/site-packages/mod_wsgi/server/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so into server: /root/.pyenv/versions/3.6.2/site-packages/mod_wsgi/server/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so: cannot open shared object file: Permission denied またマシンはVMWareWorkStationの仮想マシンを使用しておりCentoOS7をセットアップしてから pyenvとPython3.6.2とhttpdとhttpd httpd-develとpython-develとwsgi_moduleをインストールしました。 wsgi.confの中身はusernameのところのみ実際のフォルダ名を置きかあえて書いてあります。
guest

回答2

0

自己解決

SELinuxをOFFしたら解決しました。

投稿2021/12/30 04:56

Tomo0225

総合スコア67

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

Cannot load /root/.pyenv/…/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so into server: …: Permission denied
というメッセージが直接の原因を表しているものでしょう。
Apacheは起動こそrootで行いますが、動作自体は apache 等の非rootユーザで行います。
ここで一般に /root ディレクトリは root のみアクセス可のため、指定されたモジュールファイルを読み込みできなくなっています。
※configtestで問題が出ないのは、rootでチェックしていて、パーミッションで引っかからないからでしょう。

/root のパーミッションを緩くするという手もありますが、流石にそれはどうかと思いますので、pyenv する時のディレクトリを変えて mod-wsgi をインストールし直す ( それに合わせて LoadModuleのファイル名も変える ) のが良いと思います。

投稿2021/12/26 22:28

angel_p_57

総合スコア1681

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tomo0225

2021/12/30 04:56

pyenvとmod_wsgiをインストールする場所を変えて find / -name mod_wsgi*soで指定された以下ディレクトリをLoadModuleで指定したのですが、それでも上手くいきませんでした。 /home/yasue/.pyenv/versions/3.6.2/lib/python3.6/site-packages/mod_wsgi/server/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so journalctl -u httpdでログチェックではやはり /home/yasue/.pyenv/versions/3.6.2/lib/python3.6/site-packages/mod_wsgi/server/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so: cannot open shared object file: Permission denied となっています。 さらにmod_wsgi-py36.cpython-36m-x86_64-linux-gnu.soまでのディレクトリを全てchmod 777 で権限変更しても結果が変わりませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問