nginx + uwsgi + virtualenvを使用したマルチホストdjangoアプリケーション

タスク:異なるバージョンのdjango と異なるバージョンのpythonを使用して、同じサーバーに複数のdjangoプロジェクトをデプロイします。

Ubuntu 12.04の手順が提供されています。

準備する


まず、興味のあるバージョンのpythonを配置します。

コンパイルに必要なパッケージ:
sudo apt-get install zlib1g zlib1g-dev zlibc libssl-dev 

Pythonを入れて、2.7.4と3.3.1を設定しました
 wget http://python.org/ftp/python/2.7.4/Python-2.7.4.tar.bz2 tar -xf Python-2.7.4.tar.bz2 cd Python-2.7.4 ./configure --prefix=/opt/python2.7/ --enable-unicode=ucs4 make && make install 

 wget http://python.org/ftp/python/3.3.1/Python-3.3.1.tar.bz2 tar -xf Python-3.3.1.tar.bz2 cd Python-3.3.1 ./configure --prefix=/opt/python3.3/ make && make install 

プロジェクト設定用のディレクトリを作成しましょう。

Nginxのインストール


 apt-get install nginx-full 

なぜnginxではなくnginx-fullですか? Nginx-fullには、すでにuwsgiを操作するためのモジュールが含まれています。

仮想ホストの設定を読み込む場所をnginxに伝える必要があります。
/etc/nginx/nginx.confを開きます。
include /etc/nginx/sites-enabled/*; include /home/hosting/.nginx/*.conf;という行を追加しinclude /home/hosting/.nginx/*.conf;
ここで、仮想ホストのnginx-configsを作成する必要があります。

設定例:
非表示のテキスト
 server { server_name project1.com; access_log /var/log/project1.access.log; error_log /var/log/project1.error.log; location / { uwsgi_pass unix:/tmp/project1.sock; include /etc/nginx/uwsgi_params; } location /static/ { alias /home/hosting/project1/static/; } location /media/ { alias /home/hosting/project1/media/; } } 

/home/hosting/.nginxディレクトリへの権限をwww-dataユーザー(またはnginxが実行されているユーザー)に付与する必要があります。
 chown -R www-data:www-data /home/hosting/.nginx/ 

nginxを開始します
 service nginx start 

virtualenvwrapperをインストールする


virtualenvwrapper-virtualenvの便利なラッパー。
まだ価値がなければピップを入れます:
 sudo apt-get install python-pip 

virtualenvwrapperを配置します。
 pip install virtualenvwrapper 

〜/ .bashrcに以下を追加します。
 export WORKON_HOME=/home/hosting/.virtualenvs/ source /usr/local/bin/virtualenvwrapper.sh 

.bashrcが起動するように、コンソールに再配置します。 コンソールでmkvirtualenvコマンドを使用できるようになりました。

プロジェクトファイルをディレクトリに配置します。

プロジェクトごとに、仮想環境を作成します。 project1がPython 2.7で実行され、project2が3.3で実行されるとします。
 mkvirtualenv project1 -p /opt/python2.7/bin/python deactivate mkvirtualenv project2 -p /opt/python3.3/bin/python3 deactivate 

プロジェクトごとに、依存関係を仮想環境に配置します。 (私の場合、依存関係は各プロジェクトのルートにあるrequirements.txtファイルに記述されています)
 workon project1 cd /home/hosting/project1 pip install -r requirements.txt workon project2 cd /home/hosting/project2 pip install -r requirements.txt 

uwsgiの構成。


次のように、皇帝モード(--emperor)で構成します。 このモードは、特にマルチホスティング用に設計されています。

皇帝モードでは、uwsgiは指定されたディレクトリから構成を自動的にロードします。これは便利です。つまり、一度uwsgiを実行し、構成内のすべてのアプリケーションのプロセスを作成します。

デフォルトでは、uwsgiは現在の環境にあるpythonを使用してプロジェクトコードを実行するため、virtualenvからuwsgiを実行する必要があります。
pythonにはいくつかの異なるバージョンがあるため、たとえばpython 2.7から起動したuwsgiは、python 3.3の環境でdjangoアプリケーションを提供できません。
したがって、Pythonの各バージョンに対して皇帝を作成し、インタープリターのバージョンに従ってアプリケーション構成をグループ化します。

皇帝のための仮想環境を作成します。
 mkvirtualenv python27 -p /opt/python2.7/bin/python deactivate mkvirtualenv python33 -p /opt/python3.3/bin/python3 deactivate 

ここで、すべてのvirtualenvにuwsgiを配置して構成する必要があります。
 workon python27 pip install uwsgi workon python33 pip install uwsgi 

各uwsgi皇帝の設定ディレクトリを作成します。
 mkdir /home/hosting/.uwsgi/python27 mkdir /home/hosting/.uwsgi/python33 

プロジェクトごとにuwsgi-configsを作成します。
/home/hosting/.uwsgi/python27/project1.ini
非表示のテキスト
 [uwsgi] protocol = wsgi master = true processes = 1 #    socket = /tmp/project1.sock #   pythonpath   , . uwsgi         virtualenv pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7/site-packages/setuptools-0.6c11-py2.7.egg pythonpath = /home/hosting/.virtualenvs/project1/lib/python27.zip pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7 pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7/plat-linux2 pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7/lib-tk pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7/lib-old pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7/lib-dynload pythonpath = /home/hosting/.virtualenvs/project1/lib/python2.7/site-packages # -  virtualenv     ,      pythonpath = /opt/python2.7/lib/python2.7 chdir = /home/hosting/project1 virtualenv = /home/hosting/.virtualenvs/project1 env = DJANGO_SETTINGS_MODULE=settings module = django.core.handlers.wsgi:WSGIHandler() no-site = true vhost = true chmod-socket = 666 

2番目のプロジェクト構成も同様です。 ファイル名は.iniで終わる必要があります。そうしないと、uwsgiはこの構成を取得しません。

次に、システムでuwsgiをサービスとして登録する必要があります。 私はupstartを使用しました。それは箱から出てきたものです。
2つの設定ファイルを作成しましょう。
/etc/init/uwsgi27.conf
 description "uWSGI Emperor (python 2.7)" start on runlevel [2345] stop on runlevel [06] exec /home/hosting/.virtualenvs/python27/bin/uwsgi --master --emperor /home/hosting/.uwsgi/python27 --logto /var/log/uwsgi27.emperor.log 

/etc/init/uwsgi33.conf
 description "uWSGI Emperor (python 3.3)" start on runlevel [2345] stop on runlevel [06] exec /home/hosting/.virtualenvs/python33/bin/uwsgi --master --emperor /home/hosting/.uwsgi/python33/ --logto /var/log/uwsgi33.emperor.log 

ユーザーとセキュリティ


ルートから、「インペリアル」プロセスのみを実行し、プロジェクト自体は自分のユーザーの下になります。

各プロジェクトのユーザーを作成します。
 adduser --no-create-home --disabled-login --disabled-password www-project1 adduser --no-create-home --disabled-login --disabled-password www-project2 

uid gidパラメーターを各uwsgi ini-configsに追加します
 uid = www-project1 #  gid = www-project1 #  

正しい許可を設定する
非表示のテキスト
 chown -R www-data:www-data /home/hosting/.nginx chmod -R 770 /home/hosting/.nginx chown -R root:root /home/hosting/.uwsgi chmod -R 770 /home/hosting/.uwsgi chown -R root:root /home/hosting/.virtualenvs/python27 /home/hosting/.virtualenvs/python33 chmod -R 775 /home/hosting/.virtualenvs chown -R www-project1:www-project1 /home/hosting/project1 /home/hosting/.virtualenvs/project1 chown -R www-project2:www-project2 /home/hosting/project2 /home/hosting/.virtualenvs/project2 

uwsgiを起動する
 service uwsgi27 start service uwsgi33 start 

チェック-すべてが機能するはずです。
何かが機能しない場合は、プロジェクト設定で指定されたnginxログとuwsgi皇帝のログを見てください。
uwsgiがアプリケーションを正常にデプロイしたことを示す兆候は、uwsgiログのWSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x135e280 pid: 21737 (default app)WSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x135e280 pid: 21737 (default app)WSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x135e280 pid: 21737 (default app)ラインWSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x135e280 pid: 21737 (default app)の存在WSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x135e280 pid: 21737 (default app)
新しいアプリケーションを追加するには、.nginxおよび.uwsgiで構成を作成し、nginxを再起動する必要があります。 uwsgi自体が新しい構成を取得します。

参照資料


projects.unbit.it/uwsgi/wiki/MultiPython
projects.unbit.it/uwsgi/wiki/DynamicVirtualenv
auphonic.com/blog/2011/06/18/django-deployment-nginx-uwsgi-virtualenv-and-fabric
eshlox.net/en/2012/09/11/nginx-uwsgi-virtualenv-and-django-ubuntu-1204
uwsgi-docs.readthedocs.org/en/latest/Emperor.html

PS


この記事で説明されている方法は、アーキテクチャの点ではあまり美しくありません。 最初は、1人のuwsgi皇帝に近づき、アプリケーション構成のプラグインパラメーターでインタープリターのバージョンを解決したいと考えていました。 しかし、Python用のuwsgi-pluginを作成することができなかったため、別の方法で作成する必要がありました。

Source: https://habr.com/ru/post/J179831/


All Articles