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

来源:互联网 发布:淘宝直通车类目出价 编辑:程序博客网 时间:2024/05/02 02:40

        上篇文章,我们针对集群中的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服务失败,提示没有对应的服务,这时候可以尝试手动重启服务器

                                                                               

总结:

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

1 0