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

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

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

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

uWSGI

uWSGIは、PythonでWebサービスを動かすアプリケーションサーバの一つです。WSGI(Web Server Gateway Interface)アプリケーションコンテナの一種で、WSGIに則ったDjangoやFlaskなどで動かすことができます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1892閲覧

uwsgiサーバーが立ち上がらない

cunwe

総合スコア65

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

uWSGI

uWSGIは、PythonでWebサービスを動かすアプリケーションサーバの一つです。WSGI(Web Server Gateway Interface)アプリケーションコンテナの一種で、WSGIに則ったDjangoやFlaskなどで動かすことができます。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/09/22 16:53

編集2021/09/22 17:59

現状

自分はflaskではなくDjangoでプロジェクトを作りましたがこちらの記事を参考に本番環境構築を試みてるところでして、その途中でuwsgiが立ち上げらないという問題が発生しました。また、仮想環境構築にはvenvを使用し、当方はMacユーザーです。

具体的な問題点

(myvenv)m.t.の状態で、pip3 install uwsgiをし、uwsgi -http :8000 --wsgi-file test.pyを実行すると

dyld: Library not loaded: @rpath/Python3.framework/Versions/3.8/Python3 Referenced from: /Users/m.t./blog_django/myvenv/bin/uwsgi Reason: image not found zsh: abort uwsgi

というエラーが出てしまいました。ちなみにtest.pyはblog_djangoの直下にあります。

試したこと

uwsgiコマンドが使えないのかなと思い、which uwsgiを実行すると/Users/m.t./blog_django/myvenv/bin/uwsgiと表示されたのでそこは問題なさそうです。

また、エラー文でggってこちらの記事を見つけたのですが、今回のケースで必要なライブラリがわかりませんでした。知見をお持ちの方よろしくお願いいたします。

追記

続けて調べてましたらこちらのqiita記事が見つかったのですが、ここでのindex.pyが僕で言うtest.pyかと思うのですが/var/www/uwsgi配下にないのではと思いました。一番最初に添付させていただいた記事ではプロジェクト直下にあるようですがどちらが正しいでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

基本的な問題と解決方法はこれと同じかと思います。
dyld: Library not loaded ... Reason: Image not found - stackoverflow


これを今回の問題に読み替えて手順を書きますと、

仮想環境に切替:

sh

1cd /Users/m.t./blog_django 2source myvenv/bin/activate

uwsgi の場所を確認:

sh

1which uwsgi 2# /Users/m.t./blog_django/myvenv/bin/uwsgi

uwsgi が使うライブラリを確認:

sh

1otool -L /Users/m.t./blog_django/myvenv/bin/uwsgi

出力例:

sh

1/Users/m.t./blog_django/myvenv/bin/uwsgi: 2 /usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1281.100.1) 3 /opt/local/lib/libz.1.dylib (compatibility version 1.0.0, current version 1.2.11) 4 /opt/local/lib/libpcre.1.dylib (compatibility version 4.0.0, current version 4.13.0) 5 /opt/local/lib/libexpat.1.dylib (compatibility version 10.0.0, current version 10.1.0) 6 /System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation (compatibility version 150.0.0, current version 1677.104.0) 7 @rpath/Python3.framework/Versions/3.8/Python3 (compatibility version 3.8.0, current version 3.8.0)

エラーメッセージにもありますが、@rpath/Python3.framework/Versions/3.8/Python3 が見つからないと言われているため、この @rpath という動的に解決されるパスの部分を絶対パスに変更させます。

@rpath/Python3.framework/Versions/3.8/Python3/Applications/Xcode.app/.../3.8/Python3 に変更:

sh

1install_name_tool -change @rpath/Python3.framework/Versions/3.8/Python3 /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.8/Python3 /Users/m.t./blog_django/myvenv/bin/uwsgi

(元に戻したいときはパスを反対にして実行するか、pip uninstall uwsgi して pip install uwsgi のように再インストールすればいいです)


uwsgi のバージョンを出せればとりあえず成功です。

sh

1uwsgi --version 2# 2.0.19.1

ここでのindex.pyが僕で言うtest.pyかと思うのですが/var/www/uwsgi配下にないのではと思いました。一番最初に添付させていただいた記事ではプロジェクト直下にあるようですがどちらが正しいでしょうか?

プロジェクト直下でも、uwsgi --http :9090 --wsgi-file test.py のようにファイルを指定して起動するので、今回の問題には直接関係はないですよ。

なお、上記の手順がよくわからず不安という場合は gunicorn などは何もせずとも普通に動作したので、そちらをおすすめします。

投稿2021/09/22 21:49

編集2021/09/23 00:20
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

cunwe

2021/09/23 01:02

ご提示いただいた方法で無事にバージョンが表示されるようになりました、ありがとうございます! >プロジェクト直下でも、uwsgi --http :9090 --wsgi-file test.py のようにファイルを指定して起動するので、今回の問題には直接関係はないですよ。 これはtest.pyがプロジェクト内のアプリケーション内にあってもuwsgi --http :9090 --wsgi-file test.pyをuwsgi --http :9090 --wsgi-file application/test.py とパスを変えればいいということでしょうか? また、uwsgiをインストールした時点で/var/www/uwsgiは作成されているのでしょうか?見つけられなくて。。
退会済みユーザー

退会済みユーザー

2021/09/23 07:33

私にはその `test.py` が何か分かりませんが、uWGSI で動かせる `def application()...` 関数があるものとして、`blog_django/application/test.py` があって `blog_django` にいるとしたら `uwsgi --http :9090 --wsgi-file application/test.py` ですね。 本番環境でしっかり Django と uWSGI を使うマニュアルは本家にありますのでよく読んでください。 https://docs.djangoproject.com/en/3.2/howto/deployment/wsgi/uwsgi/ `/var/www/uwsgi` というのは Qiita の記事の人が決めた適当な置き場所だと思います。この質問でいえば `/.../blog_django/application` ディレクトリにあたるものをそこに置きましたと。 最終的にどう本番運用したいのかによるのでこれ以上は何とも言えません。uWSGI の基本的な使い方が分からないとか、作業過程で疑問が出るのであれば新しく質問するのをお勧めします。
cunwe

2021/09/23 09:14

ご回答いただきありがとうございます。また疑問が出てたら質問しようと思います!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問