java集群优化——Nginx+tomcat集群配置-实践篇

时间:2022-10-12 19:14:44

        上篇文章,我们针对集群中的Nginx+tomcat技术理论进行了介绍,今天,咱们一起来完成一个简单的集群搭建

结果预览

大家先看看配置之后的结果:


       java集群优化——Nginx+tomcat集群配置-实践篇


配置步骤:

 1.        安装

        从Nginx官网下载页面(http://nginx.org/en/download.html)下载Nginx最新版本(目前是1.9.3版本)安装包,解压后复制到部署目录。

2.        启动和停止Nginx

        Nginx目前只支持命令行操作,操作前先进入Dos命令环境(cmd命令),并进入Nginx部署目录。
       启动Nginx:start nginx
        停止Nginx:nginx -s stop
        修改配置后重启:nginx -s reload
        这三个命令可分别做成bat文件,放在部署目录下,方便后续操作。
        start nginx.bat文件内容:start nginx
        stop nginx.bat文件内容:nginx -s stop

        reload nginx.bat文件内容:nginx -s reload


3.        反向代理配置

        修改部署目录下conf子目录的nginx.conf文件(如nginx-1.5.13\conf\nginx.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 的 upstream默认是以轮询的方式实现负载均衡,这种方式中,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
        另外一种方式是ip_hash:每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。 

负载均衡配置示例
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服务失败,提示没有对应的服务,这时候可以尝试手动重启服务器

                                                                               java集群优化——Nginx+tomcat集群配置-实践篇

总结:

        一个好的工具,不仅仅是实现了好的功能,还有更重要的一点就是,一定要有更简单的业务逻辑,这样用户在使用这款工具的时候才能顺利过渡,而Nginx这款软件,对于广大开发者恰恰符合这两个要求,不用心,用户就会体会到,用心了,就是让用户体会不到,离不开!这不就是互联网产品的思维吗?