ホームページ > バックエンド開発 > PHPチュートリアル > Java クラスターの最適化 - Nginx+tomcat クラスター構成 - 実践

Java クラスターの最適化 - Nginx+tomcat クラスター構成 - 実践

WBOY
リリース: 2016-08-10 08:48:36
オリジナル
974 人が閲覧しました

前回の記事では、クラスターにおける 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 reload
これら 3 つのコマンドを Bat ファイルに作成し、デプロイメント ディレクトリに配置すると、後続の操作が容易になります。
nginx.bat ファイルの内容を開始します: start nginx

nginx.bat ファイルの内容を停止します: nginx -s stop

nginx.bat ファイルの内容をリロードします: nginx -s reload



3. リバースプロキシ設定


デプロイメント ディレクトリの下の conf サブディレクトリにある nginx.conf ファイル (nginx-1.5.13confnginx.conf など) の内容を変更して、関連する構成を調整します。

リバースプロキシ設定例:

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 サービスのリロードに失敗し、対応するサービスがないことを示すメッセージが表示されます。今回はサーバー

優れたツールは優れた機能を実装するだけでなく、より重要なことに、ユーザーがこのツールを使用する場合にのみスムーズな移行を実現できます。Nginx はソフトウェアですこれは、開発者にとってこれら 2 つの要件を正確に満たしています。注意を払わなければ、ユーザーはそれに気づかず、それなしでは生きていけません。これはインターネット製品の考え方ではないでしょうか?

著作権声明: この記事はブロガーによるオリジナルの記事であり、ブロガーの許可なく複製することはできません。

上記は、Java クラスターの最適化 - Nginx+tomcat クラスター構成 - 実践編の内容を含めて紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート