>백엔드 개발 >PHP 튜토리얼 >Java 클러스터 최적화 - Nginx+tomcat 클러스터 구성 - 실습

Java 클러스터 최적화 - Nginx+tomcat 클러스터 구성 - 실습

WBOY
WBOY원래의
2016-08-10 08:48:36969검색

지난 글에서 클러스터 내 Nginx+tomcat의 기술 이론을 소개했는데, 오늘은 간단한 클러스터 구성을 완성해보겠습니다.

결과 미리보기

구성 후 결과를 살펴보겠습니다.

구성 단계:

1. 설치

Nginx 공식 홈페이지 다운로드 페이지(http://nginx.org/en/download)에서 Nginx 최신 버전(현재)을 다운로드합니다. .html) 버전 1.9.3) 설치 패키지이므로 압축을 풀고 배포 디렉터리에 복사합니다.

2. Nginx 시작 및 중지

Nginx는 현재 명령줄 작업만 지원하므로 실행 전 Dos 명령 환경(cmd 명령)에 들어가서 Nginx를 입력하세요. 배포 디렉터리.
Nginx 시작: start nginx
Nginx 중지: nginx -s stop
구성 수정 후 다시 시작: nginx -s reload
이 세 가지 명령을 bat 파일로 만들어 배포 디렉터리에 배치할 수 있습니다. 후속 작업에 편리합니다.
nginx.bat 파일 콘텐츠 시작: nginx 시작
nginx.bat 파일 콘텐츠 중지: nginx -s 중지

nginx.bat 파일 콘텐츠 다시 로드: nginx -s reload

3. 역방향 프록시 구성

배포 디렉터리(예: nginx-1.5.13confnginx) 아래의 conf 하위 디렉터리에서 nginx.conf 파일을 수정합니다. .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의 기본 업스트림은 다음을 기반으로 합니다. on 이 방법에서는 각 요청이 시간순으로 다른 백엔드 서버에 하나씩 할당되며, 백엔드 서버가 다운되면 자동으로 제거될 수 있습니다.
또 다른 방법은 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는 사용자가 주의를 기울이지 않으면 다음과 같은 사실을 깨닫게 될 것입니다. 사용자가 그것을 경험할 수 없고, 그것 없이는 살 수 없도록 최선을 다합니다! 이것이 인터넷 상품의 생각이 아닐까요?

저작권 안내: 이 글은 해당 블로거의 원본 글이므로 블로거의 허락 없이 복제할 수 없습니다.

위 내용을 포함하여 Java 클러스터 최적화 - Nginx+tomcat 클러스터 구성 - 실습을 소개하고 있으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.