nginx + tomcat クラスターで負荷分散を実現
2012-09-21 14:15 1338 人が読んだ コメント (1) 収集レポート
nginx tomcat クラスターサーバー負荷分散ファイル
nginx をインストールします
1.ライブラリ e ウェット ftp://ftp.csx.cam.ac.uk/pub/software/prography/pcre/pcre-8.10.tar.gz
Tar ZXVF PCRE-8.10.gz 8 CD PCRE-8.10 /
./configure
Make && MAKE Install
CD ../
nginx をインストール
wettp: //nginx.org/download/nginx- cd nginx -1.0.2/
./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
make && make install cd ../
Nginx ログディレクトリを作成する
mkdir -p /home/nginx/logs
chmod +w /home/nginx/logs
chown -R www:www /home/nginx/ logs
Nginx 設定を作成するファイル
①、/usr/local/nginx/conf/ ディレクトリに nginx.conf ファイルを作成します:
rm -f /usr/local/nginx/conf/nginx.conf
vi /usr/local/ nginx/conf/nginx.conf
次のように入力します:
user www www;
worker_processes 8;
error_log /home/nginx/logs/nginx_error.log crit ;
pid /usr/ local/nginx/nginx.pid;
worker_rlimit_nofile 65535;
events
{
use worker_connections 65535;
}
http
{
include mime.types;
default_type application/octet-stream;
#charset gb2312;
server_names_hash_bucket_size 128;
client_header_buffer_size 32k;
large_client_header_buffers 4 32k;
client_max_body_size 8m;
sendfile on;
tcp_nopush on;
keepalive_timeout 60;
tcp_nolay on;
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 12 8k;
gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.0;
gzip_comp_level 2;
gzip_types text/plain application/x-javascript text/css application/xml;
gzip_vary on;
#limit_zone craw ler$binary_remote_addr10m;
#测试
サーバー
{
listen 80;
server_name www.test.com;
index index.htm index.html index.jsp;
root /home/htdocs /web/ROOT/;
location ~ .*$
{
index index.jsp;
proxy_pass http://www.test.com:8080;
}
アクセス_log ログ/sp.imichat.com.log結合;
error_page 404 = /404.html;
}
}
②、在/usr/local/nginx/conf/目录中创建fcgi.conf文件:
vi /usr/local/nginx/conf/fcgi.conf
输入以下内容:
fastcgi_param GATEWAY_INTERFACE CGI/1.1;
fastcgi_param SERVER_SOFTWARE nginx;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param CONTENT_TYPE $content_type;
fastcgi_param CONTENT_LENGTH $content_length;
fastcgi_param SCRIPT_FILENAME $ document_root $ fastcgi_script_name; cgi_param remote_addr $ Remote_addr;
fastcgi_param REMOTE_PORT $remote_port;
fastcgi_param SERVER_ADDR $server_addr;
fastcgi_param SERVER_PORT $server_port;
fastcgi_param SERVER_NAME $server_name;
# PHP のみ、PHP が --enable で構築された場合には必須-force-cgi-redirect
fastcgi_param REDIRECT_STATUS 200;
启アニメーションNginx
ulimit -SHn 65535
/usr/local/nginx/sbin/nginx
構成开机自動启动Nginx
vi /etc/rc.local
在末尾增加以下の内容:
ulimit -SHn 65535
/usr/local/nginx/sbin/nginx
优化Linux内核パラメータ
vi /etc /sysctl .conf
末尾增追加以下の内容:
# Add
net.ipv4.tcp_max_syn_backlog = 65536
net.core.netdev_max_backlog = 32768
net.core.somaxconn = 32768
ネット.core.wmem_default = 8388608
net.core.rmem_default = 8388608
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
net.ipv4.tcp_timestamps = 0
ネット.ipv4.tcp_synack_retries = 2
net.ipv4.tcp_syn_retries = 2
net.ipv4.tcp_tw_recycle = 1
#net.ipv4.tcp_tw_len = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_mem = 94500000 915000000 927000000
net.ipv4.tcp_max_orphans = 3276800
#net.ipv4.tcp_fin_timeout = 30
#net.ipv4.tcp_keepalive_time = 120
net.ipv4.ip_local_port_range = 1024 65535
使用構成立即生效:
/sbin/sysctl -p
在不停止Nginxサービス务的情况下变更Nginx構成
修正/usr/local/nginx/conf /nginx.conf構成文件後、请実行以下のコマンド检查構成文件が正确:
/usr/local/nginx/sbin/nginx -t
如果画面表示以下の行情報、说明構成文件正确:
設定ファイル/usr/local/nginx/conf/nginx.conf 構文は問題ありません
設定ファイル/usr/local/nginx/conf/nginx.conf は正常にテストされました
重启nginx:
/usr/local/ nginx/sbin/nginx -s reload
编写每天定時切割Nginx日志の脚本
U スクリプトを作成します /usr/local/nginx/sbin/cut_nginx_log.sh
vi /usr/ntinx/sbin/cut_nginx_log.sh
::
#!/Bin/bash
# このスクリプトは 00:00 に実行されます
# Nginx ログのパス
logs_root_path="/home/nginx/logs/"
logs_path=${logs_root_path}$(date -d "yesterday" +"% Y")/$(date -d "昨日" +"%m")/
mkdir -p ${logs_path}
#ログファイル名 ============== ======================================
logs_name="weblogs"
logs_file =${logs_root_path}${logs_name}.log
cut_logs_file=${logs_path}${logs_name}_$(date -d "昨日" +"%Y%m%d").log
mv $ {logs_file} ${cut_logs_file}
tar czf ${cut_logs_file}.tar.gz ${cut_logs_file}
rm -f ${cut_logs_file}
#nginxを再起動
/usr/local/nginx/ sbin/nginx -s reload
このスクリプトに実行権限を与えます
# chmod +x /usr/local/nginx/sbin/cut_nginx_log.sh
毎朝00:00にnginxのアクセスログをカットするようにcrontabを設定します
crontab -e
次の内容を入力します:
00 00 * * * /bin/bash /usr/local/nginx/sbin/cut_nginx_log.sh
2. nginx 負荷分散を設定します。 nginx .conf を編集
vim /usr/local/nginx/conf/nginx.conf
サーバー www.test.com: 8080; : IP_hash が追加された場合、これはユーザーがサーバーに接続した後に行ったすべての操作と、着陸後に着陸後に行ったすべての操作にのみ適用されます。そのサーバー上にのみ適用され、別のサーバーにジャンプすることはありません。そのサーバーが終了すると、自動的に終了して別のサーバーに接続します
www.test.com は独自のサーバーです。上流の後の名前を使用するのが最善です。 proxy_pass という名前と同じにすることをお勧めします。 例:
upstream www.test .com{
# test
server
{
listen80;
server_name ROOT/;
location ~ .*$
{E Index Index.jsp;
proxy_pass Http://www.test.com 注: 負荷分散のために、後でポートを追加することはできません。
Access_log ログ/SP .imichat.com.log 結合;
error_page 404 = /404.html;
}
注: ロードバランシングが失敗した場合は、ポート 80 が nginx を経由せずに Tomcat サービスポートに直接転送されているかどうかを確認してください
3. Tomcat クラスターを構成します
Tomcat の最大同時実行数を最適化し、サーバーを編集します。 xml
関係ありません
enableLookups="false" redirectPort="8443" acceptCount=" 500"
className="org.apache.catalina.ha.tcp .SimpleTcpCluster" tcpListenAddress="12 7.0.0.1インチ / >
web.xml を変更します
タグを追加します:
直前に、これは tomcat に追加されたセッションからコピーされます。 Tomcat クラスターを構築するために必要です。そうしないと、ユーザーのセッションが正常に使用できなくなります。
以上、ロードバランシングを実現するためのnginx + tomcatクラスタについて、その内容も含めて紹介しましたが、PHPチュートリアルに興味のある友人の参考になれば幸いです。