Nginx + UWSGIの使い方
(disqus.com と getsentry.com で) 多くの実験を行った結果、私は間違いなく言えます: uwsgi は Python の世界の標準になるはずです。 nginx と組み合わせると、Python ベースの Web アプリケーションのスレッド (または非スレッド) でのパフォーマンス エクスペリエンスが向上します。
更新: 「与えられたメトリックはどれも遅い」という古くからの言い伝えを無視してください。ここでのリクエストとはバックエンド ノードを指します。バックエンド ノードは受信イベント (サイズが 20 KB から 1 MB の範囲のリクエスト) を処理し、ネットワーク内のさまざまなホップを飛び越えます。ポリシーであり、ほとんどは何らかのキュー操作を形成します。可能な限り多くのワークロードをオフロードします。 (この段落の翻訳に問題があります。原文と訳者注を参照してください)
サービス戦略
Python アプリケーションを実行する方法はすでに多数あります。 mod_wsgi を使用するつもりはありません。そして最も重要なのは、イベント モデルがどのように機能するかを説明しようとしているわけではありません。これらが Python の世界ではまだ使用されているとは思えないため、この記事のトピックは従来のスレッド (またはマルチプロセス) Python アプリケーションに関するものではありません。
代わりに、私が最もよく知っている 2 つの最も人気のあるソリューション、gunicorn と uwsgi に焦点を当てます。
Gunicorn (Python UNIX プラットフォーム用の wsgi サーバー)
過去を振り返ると、Python の Web サーバーのソリューションは基本的に mod_wsgi でした。最近最も人気のある (または流行していると考えられている) 方法の 1 つは Gunicorn です。
実際、私は今でも gunicorn を使用することをお勧めします。これにより、不便さが大幅に軽減されます。Gunicorn は Django を美しく埋め込み、セットアップが簡単です。
また、uwsgi と同じ構成オプションが 10% ありますが (これは一部の人にとっては良いことです)、それ以外は、比較すると、uwsgi (または他の Python Web サーバー) とほぼ同じ基本機能を提供します。
うすぎ
私の意見では、Gunicorn から uwsgi まで、これが唯一の選択肢です。パフォーマンスが向上し、理解しやすい構成オプションが増え、プロトコルを通じて nginx と対話できる機能も利点を追加します。
その構成も非常にシンプルです。関連する記事を見つけるだけです。詳細については後ほど説明します。
私はいくつかのアプリケーションを実行するために uwsgi を使い始め、次の 2 つの目的で –processes=10 と –threads=10 を使用してサーバーのマルチ CPU をテストしました:
サポート状況
メモリ使用量を削減できる可能性をテストしています
スレッドの安全性サポートをテストします
(これらのテストに価値があるかどうかについては、DISQUS はシングルスレッドで実行されます。できるだけ合理化して各ノードの機能を最大化したいと考えています)
成功に向けて継続的に反復します
API の平均応答時間を 40 ミリ秒未満に短縮できたことを非常に誇りに思っています。ここで話している API 応答時間とは、リクエストが Python サーバーに到達してから、サーバーがプロキシに応答を返すまでにかかる時間を指します。
残念ながら、サービス ノードにはまだ約 30% のメモリがあり、アクセスのスパイクが発生し始めると、応答時間の変動が当初の予想と一致しなくなり始めました。 % のリソースが利用可能です。
多くの調整を行った後、多数の uwsgi プロセスを非アクティブ化し、nginx に負荷分散を行わせました (以前は uwsgi 自体に負荷分散を行わせていました)。
これは、uwsgiprocesses=10 を実行する代わりに、--processes=10 の代わりに 10 個の個別の uwsgi インスタンスを実行することを意味します。
その結果、美しく安定した 20 ミリ秒の平均応答時間が得られます。
API 応答時間
一緒に並べてください
私は何かについて話すよりも、実際に何かをするのが好きなので、ここではオンライン サーバーの実際のセットアップをいくつか紹介します。
nginx
構成の最初の部分は Nginx であり、実際に uwsgi プロセス バックエンドの数を計算して追加する必要があるため、少し複雑になります。
まず、Web ページで構成リストを作成します:
# recipes/web.rb hosts = (0..(node[:getsentry][:web][:processes] - 1)).to_a.map do |x| port = 9000 + x "127.0.0.1:#{port}" end template "#{node['nginx']['dir']}/sites-available/getsentry.com" do source "nginx/getsentry.erb" owner "root" group "root" variables( :hosts => hosts ) mode 0644 notifies :reload, "service[nginx]" end
Nginx の設定は非常に簡単です:
# templates/getsentry.erb upstream internal { <% @hosts.each do |host| %> server <%= host %>; <% end %> } server { location / { uwsgi_pass internal; uwsgi_param Host $host; uwsgi_param X-Real-IP $remote_addr; uwsgi_param X-Forwarded-For $proxy_add_x_forwarded_for; uwsgi_param X-Forwarded-Proto $http_x_forwarded_proto; include uwsgi_params; } }
これで、uwsgi ホストの数を設定し、ポート 9000 から始まる重み値を割り当てました。これは、uwsgi 構成で使用されるソケット アドレスです。
うすぎ
一方、スーパーバイザーを使用して uwsg プロセスを制御します。これも非常に簡単です:
# recipes/web.rb command = "/srv/www/getsentry.com/env/bin/uwsgi -s 127.0.0.1:90%(process_num)02d --need-app --disable-logging --wsgi-file getsentry/wsgi.py --processes 1 --threads #{node['getsentry']['web']['threads']}" supervisor_service "web" do directory "/srv/www/getsentry.com/current/" command command user "dcramer" stdout_logfile "syslog" stderr_logfile "syslog" startsecs 10 stopsignal "QUIT" stopasgroup true killasgroup true process_name '%(program_name)s %(process_num)02d' numprocs node['getsentry']['web']['processes'] end
場所の選択
なぜ別の方法があるのか (またはこの場合は機能しないのか) 誰かが非常に説得力のある議論を思いつかない限り、Python の世界がより標準になるにつれて、私はこのパターンについて聞きたいと思っています。少なくとも、uwsgi 内でプロセス管理を改善する方法についての議論が火花を散らすことを期待します。
以上がNginx + UWSGIの使い方の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Linuxでnginxを開始する手順:nginxがインストールされているかどうかを確認します。 systemctlを使用して、nginxを開始してnginxサービスを開始します。 SystemCTLを使用して、NGINXがシステムスタートアップでNGINXの自動起動を有効にすることができます。 SystemCTLステータスNGINXを使用して、スタートアップが成功していることを確認します。 Webブラウザのhttp:// localhostにアクセスして、デフォルトのウェルカムページを表示します。

サーバーには、要求されたリソースにアクセスする許可がなく、NGINX 403エラーが発生します。ソリューションには以下が含まれます。ファイル許可を確認します。 .htaccess構成を確認してください。 nginx構成を確認してください。 SELINUXアクセス許可を構成します。ファイアウォールルールを確認してください。ブラウザの問題、サーバーの障害、その他の可能なエラーなど、他の原因をトラブルシューティングします。

Windowsでnginxを構成する方法は? nginxをインストールし、仮想ホスト構成を作成します。メイン構成ファイルを変更し、仮想ホスト構成を含めます。 nginxを起動またはリロードします。構成をテストし、Webサイトを表示します。 SSLを選択的に有効にし、SSL証明書を構成します。ファイアウォールを選択的に設定して、ポート80および443のトラフィックを許可します。

nginxが開始されるかどうかを確認する方法:1。コマンドラインを使用します:SystemCTLステータスnginx(Linux/unix)、netstat -ano | FindStr 80(Windows); 2。ポート80が開いているかどうかを確認します。 3.システムログのnginx起動メッセージを確認します。 4. Nagios、Zabbix、Icingaなどのサードパーティツールを使用します。

NGINXサーバーを起動するには、異なるオペレーティングシステムに従って異なる手順が必要です。Linux/UNIXシステム:NGINXパッケージをインストールします(たとえば、APT-GetまたはYumを使用)。 SystemCtlを使用して、NGINXサービスを開始します(たとえば、Sudo SystemCtl Start NGinx)。 Windowsシステム:Windowsバイナリファイルをダウンロードしてインストールします。 nginx.exe実行可能ファイルを使用してnginxを開始します(たとえば、nginx.exe -c conf \ nginx.conf)。どのオペレーティングシステムを使用しても、サーバーIPにアクセスできます

Linuxでは、次のコマンドを使用して、nginxが起動されるかどうかを確認します。SystemCTLステータスNGINXコマンド出力に基づいて、「アクティブ:アクティブ(実行)」が表示された場合、NGINXが開始されます。 「アクティブ:非アクティブ(dead)」が表示されると、nginxが停止します。

Nginxクロスドメインの問題を解決するには2つの方法があります。クロスドメイン応答ヘッダーの変更:ディレクティブを追加して、クロスドメイン要求を許可し、許可されたメソッドとヘッダーを指定し、キャッシュ時間を設定します。 CORSモジュールを使用します。モジュールを有効にし、CORSルールを構成して、ドメインクロスリクエスト、メソッド、ヘッダー、キャッシュ時間を許可します。

Nginx 403禁止エラーを修正する方法は?ファイルまたはディレクトリの許可を確認します。 2。HTACCESSファイルを確認します。 3. nginx構成ファイルを確認します。 4。nginxを再起動します。他の考えられる原因には、ファイアウォールルール、Selinux設定、またはアプリケーションの問題が含まれます。
