지난 글에서 클러스터 내 Nginx+tomcat의 기술 이론을 소개했는데, 오늘은 간단한 클러스터 구성을 완성해보겠습니다.
결과 미리보기
구성 후 결과를 살펴보겠습니다.
구성 단계:
1. 설치
Nginx 공식 홈페이지 다운로드 페이지(http://nginx.org/en/download)에서 Nginx 최신 버전(현재)을 다운로드합니다. .html) 버전 1.9.3) 설치 패키지이므로 압축을 풀고 배포 디렉터리에 복사합니다.2. Nginx 시작 및 중지
Nginx는 현재 명령줄 작업만 지원하므로 실행 전 Dos 명령 환경(cmd 명령)에 들어가서 Nginx를 입력하세요. 배포 디렉터리.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 이 방법에서는 각 요청이 시간순으로 다른 백엔드 서버에 하나씩 할당되며, 백엔드 서버가 다운되면 자동으로 제거될 수 있습니다.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 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.