ホームページ >バックエンド開発 >PHPチュートリアル >Java クラスターの最適化 - Nginx+tomcat クラスター構成 - 実践
前回の記事では、クラスターにおける Nginx+Tomcat の技術理論を紹介しました
構成手順:
1. インストールします。 最新の Nginx を Nginx 公式 Web サイトのダウンロード ページ (http://nginx.org/en/download.html) バージョン (現在 1.9 .3 バージョン) のインストール パッケージからダウンロードし、解凍して展開ディレクトリにコピーします。
2. Nginx の起動と停止
Nginx は現在、コマンド ライン操作のみをサポートしています。操作する前に、Dos コマンド環境 (cmd コマンド) に入り、Nginx のデプロイメント ディレクトリに入ります。 Nginx の開始: start nginx
Nginx の停止: nginx -s stop 構成を変更した後に再起動: nginx -s reloadnginx.bat ファイルの内容を停止します: nginx -s stop
nginx.bat ファイルの内容をリロードします: nginx -s reloadリバースプロキシ設定例:
location / { #设置主机头和客户端真实地址,以便服务器获取客户端真实IP proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #禁用缓存 proxy_buffering off; #设置反向代理的地址 proxy_pass http://192.168.1.1; }4. 負荷分散設定
デフォルトでは、nginx のアップストリームは、各リクエストを時系列順に 1 つずつ割り当てます。バックエンド サーバーがダウンした場合は、バックエンド サーバーを自動的に削除できます。 もう 1 つの方法は ip_hash です。各リクエストはアクセスされた IP のハッシュ結果に従って割り当てられるため、各訪問者はバックエンド サーバーに固定的にアクセスでき、セッションの問題を解決できます。
負荷分散設定例upstream xvshu.com{ #ip_hash; server 192.168.121.251 1; server 192.168.121.252 1; server 192.168.121.253 1; } server { listen 80 server_name trffweb; location / { #反向代理的地址 proxy_pass http://<span style="font-family: Arial, Helvetica, sans-serif;">xvshu.com</span><span style="font-family: Arial, Helvetica, sans-serif;">; </span> } }
5. 完全な設定例
nginx.conf: #Nginx所用用户和组,window下不指定 #user niumd niumd; #工作的子进程数量(通常等于CPU数量或者2倍于CPU) worker_processes 1; #错误日志存放路径 #error_log logs/error.log; #error_log logs/error.log notice; error_log logs/error.log info; #指定pid存放文件 pid logs/nginx.pid; events { #使用网络IO模型linux建议epoll,FreeBSD建议采用kqueue,window下不指定。 #use epoll; #允许最大连接数 worker_connections 2048; } http { include mime.types; default_type application/octet-stream; #定义日志格式 #log_format main '$remote_addr - $remote_user [$time_local] $request ' # '"$status" $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log off; #access_log logs/access.log; #client_header_timeout 3m; #client_body_timeout 3m; #send_timeout 3m; #client_header_buffer_size 1k; #large_client_header_buffers 4 4k; sendfile on; #tcp_nopush on; #tcp_nodelay on; keepalive_timeout 75; #include gzip.conf; upstream xvshu.cn{ #根据ip计算将请求分配各那个后端tomcat,许多人误认为可以解决session问题,其实并不能。 #同一机器在多网情况下,路由切换,ip可能不同 #ip_hash; server 192.168.112.250:18080 weight=1; server 192.168.112.251:18080 weight=1; } server { listen 80; server_name localhost; #定义server_name localhost中的请求都叫给xvshu.cn处理 location / { #proxy_connect_timeout 3; #proxy_send_timeout 30; #proxy_read_timeout 30; proxy_pass http://xvshu.cn; proxy_redirect default; } } }
優れたツールは優れた機能を実装するだけでなく、より重要なことに、ユーザーがこのツールを使用する場合にのみスムーズな移行を実現できます。Nginx はソフトウェアですこれは、開発者にとってこれら 2 つの要件を正確に満たしています。注意を払わなければ、ユーザーはそれに気づかず、それなしでは生きていけません。これはインターネット製品の考え方ではないでしょうか?
著作権声明: この記事はブロガーによるオリジナルの記事であり、ブロガーの許可なく複製することはできません。
上記は、Java クラスターの最適化 - Nginx+tomcat クラスター構成 - 実践編の内容を含めて紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。