ホームページ >バックエンド開発 >Python チュートリアル >Ubuntu14.04の導入事例のご紹介
最初のステップ。
sudo apt-get update
sudo apt-get upgrade
まずアップデートしてください。 。
Django の主流のデプロイ方法: nginx+uwsgi+django
2 番目のステップは nginx をインストールすることです
sudo apt-get install nginx
最新の nginx をインストールする必要がある場合は、nginx をダウンロードする必要があります。公式 Web サイトからソース コード パッケージを入手し、手動でコンパイルします。
nginxのおおよそのファイル構造。
1. 設定ファイル: /etc/nginx
2. プログラム: /usr/sbin/nginx
3. ログ: /var/log/nginx/access.log - error.log
ステップ 3、 install uwsgi
sudo apt-get install python3-dev
sudo apt-get install python3-pip
sudo pip3 install uwsgi (この手順の前に、ダウンロード速度を向上させるために pip ソースを変更できます。~/.pip の下に Create pip.conf を開き、
[global]
trusted-host = pypi.douban.com
index-url = )
uwsgi は、WSGI プロトコル、uwsgi、http およびその他のプロトコルを実装する Web サーバーです。 Nginx の HttpUwsgiModule の機能は、uWSGI サーバーとのやり取りです。
一般的なプロセスは次のとおりです: クライアント<==&ginx<==>uwsgi<==>Django。静的リクエストは Nginx 自体によって処理されます。非静的リクエストは uwsgi を通じて Django に渡され、Django によって処理されて WEB リクエストが完了します。
Django テスト プロジェクト、django-admin startproject mysite、cd mysite、python manage.py startapp Demon1 を作成します。
4 番目のステップ、uwsgi のテスト
mysite ディレクトリに新しいテスト ファイル nano test.py を作成します。
次のように記述します:
def application(env, start_response): start_response('200 OK', [('Content-Type','text/html')])return ["Hello World"]
uwsgi --http :8001 --plugin python --wsgi-file test.py
运行:
python manage.py runserver 0.0.0.0:8002
访问正常。
第五步,测试Django
uwsgi --http:8001 --plugin python --module mysite.wsgi
访问正常。
连接Django和uwsgi。
# mysite_uwsgi.ini file[uwsgi] socket = 127.0.0.1:3400# Django-related settings # the django project directory (full path) chdir = /home/ubuntu/mysite # Django's wsgi filemodule = mysite.wsgi # process-related settings # master master = true# maximum number of worker processes processes = 2threads = 2max-requests = 6000# ... with appropriate permissions - may be neededchmod-socket = 664# clear environment on exit vacuum = true
访问正常。
第六步,配置uwsgi
uwsgi支持通过多种配置文件形式启动,这里采用ini配置文件的方法.
新建uwsgi:nano uwsgi.ini
daemonize = /home/ubuntu/mysite/uwsgi.log
访问时报错,invalid request block <span class="hljs-built_in">size: <span class="hljs-number">21573 (<span class="hljs-built_in">max <span class="hljs-number">4096)...skip</span></span></span></span>
server { # the port your site will be served on listen 80; # the domain name it will serve forserver_name 127.0.0.1; # substitute your machine's IP address or FQDNcharset utf-8; # max upload size client_max_body_size 75M; # adjust to taste # Django media location /media { alias /home/ubuntu/mysite/media; # your Django project's media files - amend as required } location /static { alias /home/ubuntu/mysite/static; # your Django project's static files - amend as required } # Finally, send all non-media requests to the Django server. location / { include uwsgi_params; # the uwsgi_params file you installed uwsgi_pass 127.0.0.1:8001;#此处跟uwsgi配置文件保持一致 } }アクセスは正常です。 5 番目のステップ、Django のテストrrreee アクセスは正常です。 Django と uwsgi を接続します。 rreeeアクセスは正常です。 6 番目のステップは、uwsgi を設定することですuwsgi は、さまざまな設定ファイルによる起動をサポートしています 新しい uwsgi: nano uwsgi.ini rrreee
。
🎜🎜 🎜🎜アクセス時にエラーが発生しました。無効なリクエスト ブロック<span class="hljs-built_in">サイズ: <span class="hljs-number">21573 (<span class="hljs-built_in ">最大 <span class="hljs-number">4096)...スキップ</span></span></span></span>
。 🎜🎜その理由は、URL アドレスが 4096 文字を超えているためです。その理由は、設定ファイルのソケットを http に変更するか、バッファー サイズを変更するだけです。 🎜🎜(何も変更しないことをお勧めします。テスト中に http に変更し、nginx に接続するときにソケットに戻すだけです) 🎜🎜rrreee🎜🎜 正式に実行したら、このコードを uwsgi.ini に追加します。ファイルにアクセス ログがバックグラウンドで出力され、uwsgi.log になります🎜🎜Django がアクセスできるようになりました。 🎜🎜 🎜🎜 🎜🎜ステップ 7、nginx を設定する🎜🎜 nginx のデフォルト設定ファイル /etc/nginx/sites-enabled/default を変更する🎜🎜rrreee🎜🎜 テスト中に忘れずに uwsgi.ini 設定を変更してください。 🎜🎜ステップ 8、実行します🎜🎜 nginx を再起動し、uwsgi を実行します。🎜🎜完了🎜🎜今のところはここまでです。将来的には、nginx、django、および uwsgi に関する知識を追加し続けます。 🎜🎜ほとんどの設定は Baidu 検索から取得したものであるため、各ソースを 1 つずつ投稿することはしません。人生は短すぎる。 🎜🎜🎜以上がUbuntu14.04の導入事例のご紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。