>백엔드 개발 >PHP 튜토리얼 >nginx tomcat 클러스터는 로드 밸런싱을 구현합니다.

nginx tomcat 클러스터는 로드 밸런싱을 구현합니다.

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-07-29 09:00:34900검색
nginx + tomcat 클러스터로 로드 밸런싱 달성
2012-09-21 14:15 1338명 읽기 댓글(1) 수집 보고서
nginxtomcat 클러스터 서버 로드 밸런싱 파일
1. nginx 설치
필수 prce 라이브러리
wget ftp://ftp.csx.cam.ac. pub/software/programming/pcre/pcre-8.10.tar.gz

tar zxvf pcre-8.10.tar.gz
cd pcre-8.10/
./configure
make && make install
cd ../
nginx 설치
wget http://nginx.org/download/nginx-0.8.54.tar.gz
wget http://nginx.org/download/nginx-1.0.2.tar.gz
tar zxvf nginx-1.0.2.tar.gz
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
다음을 입력하세요:
사용자 www www;
worker_processes 8;
error_log /home/nginx/logs/nginx_error.log crit;
pid /usr/local/nginx/nginx.pid;
worker_rlimit_nofile 65535;
이벤트
{
epoll 사용;
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;
    파일 보내기 on;
    tcp_nopush on;
    keepalive_timeout 60;
    tcp_nodelay 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 128k;
    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 crawler$binary_remote_addr10m;
  #测试
 서버
  {
   목록 ko      80 ;
    server_name www.test.com;
    index index.htm index.html index.jsp;
   루트  /home/ htdocs/web/ROOT/;
    위치 ~ .*$
    {
      index index.jsp;
      proxy_pass http://www.test.com:8080;
    }
    access_log logs/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;
fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  요청 ST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $document_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_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 
현재 末尾增加以下内容: 
    # 추가
net.ipv4.tcp_max_syn_backlog = 65536
net.core.netdev _max_backlog =  32768
net.core.somaxconn = 32768
net.core.wmem_default = 8388608
net.core.rmem_default = 8388608
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
net.ipv4.tcp_timestamps = 0
net.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 9270000 00
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 
如果屏幕显示以下两行信息,说ming配置文件正确:
  구성 파일 /usr/local/nginx/conf/nginx.conf 구문은 정상입니다
  구성 파일 /usr/local/nginx/conf/nginx.conf는 성공적으로 테스트되었습니다
중첩nginx: 
      /usr/local/nginx/sbin/nginx -s reload
编写每🎜>        创建脚本/usr/local/nginx/sbin/cut_nginx_log.sh
            vi /usr/local/nginx/sbin/cut_nginx_log.sh
输안녕하세용内容: 
#!/bin/bash
# 이 스크립트는 00:00에 실행됩니다.
# Nginx 로그 경로
logs_root_path="/home/nginx/logs/"
logs_path=${logs_root_path}$(date -d "어제" +"%Y")/$( 날짜 -d "어제" +"%m")/
mkdir -p ${logs_path}
#日志文件name ======== ===========================================
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 다시 로드
对这个脚本赋执行权限
# chmod +x /usr/local/nginx/sbin/cut_nginx_log.sh
设置crontab,每天凌晨00:00切割nginx访问日志 
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 {
             서버  www.test.com:8888;
            서버  www.test.com:8080;
        #ip_hash;   注:如果加入了ip_hash, 这种只能适用于当某个用户连接上了一台服务器后,他登陆の后所做的一切操twitter那一台服务器不会跳转到另extreative服务器,如果那台服务器over掉了,则会自动退出,连接到另一服务器
    }
www.test.com 是自己的服务器,最好是용도
upstream 인터페이스 이름 要与proxy_pass 这字个name字 一样,建议upstream后面적 이름 ,proxy_pass 后면적 이름,server_name 后면적 이름 一致
示예:
  업스트림  www.test.com {
              서버  www.test.com:8888;
             서버  www.test.com:8080;
    }
  #测试
 서버
  {
   듣기      80;
    server_name www.test.com;
    index index.htm index.html index.jsp;
   루트  /home/htdocs/web/ROOT/;
    위치 ~ .*$
    {
      색인 index.jsp;
      proxy_pass http://www.test.com; 注:做了负载均衡,这个后면就不能再加端口
    }
    access_log logs/sp.imichat.com.log 결합;
    error_page  404 = /404.html;
  }
참고: 로드 밸런싱이 실패할 경우 nginx를 거치지 않고 tomcat 서비스 포트로 80번 포트가 바로 전달되는지 확인해주세요
3. tomcat 클러스터 구성
Tomcat의 최대 동시성 최적화, server.xml 편집
maxThreads ="2048" minSpareThreads="100" maxSpareThreads="200"
> ~  < .ha.tcp.SimpleTcpCluster" tcpListenAddress="127.0.0.1" />
web.xml 수정
태그 추가: <배포 가능/>
                                                                                                                                      '/web-app' 바로 앞에 추가할 수 있습니다. 이 단계는 다음을 위해 필요합니다. Tomcat 클러스터를 구축하지 않으면 사용자 세션을 정상적으로 사용할 수 없습니다. > 위 내용은 내용의 측면을 포함하여 로드 밸런싱을 달성하기 위한 nginx tomcat 클러스터를 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.