参考连接html
Nginx负载均衡配置nginx
#使用如下命令 sudo yum install -y nginx #sudo表示使用管理员权限运行命令 #yum是centos系统中下载安装程序的命令 #若是提示中发现yum资源库中没用Nginx的话,则使用如下命令进行添加 sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
#启动Nginx,使用默认配置文件启动,若是Nginx没有关闭,使用此种方式启动会出现端口被占用的状况 nginx #中止nginx nginx -s stop #若是上面中止nginx的方式无效 能够强制中止 pkill -9 nginx #重启nginx nginx -s reload #因为在Linux下写配置文件,容易丢个符号,致使启动失败,因此启动以前能够检查一下配置文件的正确性 nginx -t #检查指定配置文件 nginx -t -c /etc/nginx/nginx.conf
安装成功以后,想要使用Nginx必须配置配置文件,默认配置文件的地址(/etc/nginx/nginx.conf)centos
user nginx; worker_processes auto; error_log /var/log/nginx/error.log; pid /run/nginx.pid; include /usr/share/nginx/modules/*.conf; events { worker_connections 1024; } http { 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 /var/log/nginx/access.log main; sendfile on; tcp_nopush on; tcp_nodelay on; keepalive_timeout 65; types_hash_max_size 2048; include /etc/nginx/mime.types; default_type application/octet-stream; include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*; #以上配置均是默认值不曾修改,若是想搞懂上面的是什么意思,本身去慢慢学习吧 #这个配置是负载均衡使用的 #此处的app_nodejs是负载均衡的名字 upstream app_nodejs { #访问的实际地址是下面的,能够有多个,多个时就达到了负载均衡的做用,后面其实还有一个参数,可是此处写不写无区别。 server 127.0.0.1:8082; keepalive 64; } server { #监听的是80端口,不建议换成其余端口,由于换成其余端口后,你访问时,域名也得加上加上端口,好比端口号改为8080,访问时则是:onloading.cn:8080 listen 80 default; #访问的域名 server_name onloading.cn; #若是访问的是ip,则直接返回404,此处只容许经过域名访问 if ($host ~ "\d+\.\d+\.\d+\.\d") { return 404; } location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-Nginx-Proxy true; proxy_set_header Connection ""; #指定使用哪一个负载均衡,其余location的值均属于默认值 proxy_pass http://app_nodejs; proxy_redirect off; } } }
若是想要进行反向代理设置,须要对http中的server节点进行设置,实现反向代理有两种方式,均是把下面的节点替换掉上面的默认文件的相关节点便可tomcat
第一种、使用负载均衡的方式进行反向代理服务器
#app_nodejs名称是为了下面server找到对应的负载均衡 upstream app_nodejs { #访问的实际地址 server 127.0.0.1:8082; } server { #监听的是80端口,不建议换成其余端口,由于换成其余端口后,你访问时,域名也得加上加上端口,好比端口号改为8080,访问时则是:onloading.cn:8080 listen 80 default; #访问的域名 server_name onloading.cn; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-Nginx-Proxy true; proxy_set_header Connection ""; #指定使用哪一个负载均衡,其余location的值均属于默认值,便是上面的upstream的名称 proxy_pass http://app_nodejs; proxy_redirect off; } }
第二种、不使用负载均衡,直接定义反向代理的地址app
#该种方式不须要使用upstream节点 server { #监听的是80端口,不建议换成其余端口,由于换成其余端口后,你访问时,域名也得加上加上端口,好比端口号改为8080,访问时则是:onloading.cn:8080 listen 80 default; #访问的域名 server_name onloading.cn; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-Nginx-Proxy true; proxy_set_header Connection ""; #与上面不一样的就是,此处指定的是实际访问的地址 proxy_pass 127.0.0.1:8082; proxy_redirect off; } }
此处参考连接负载均衡
#此处的upstream表示平均分配给三台机器 upstream app_nodejs { server 192.168.0.100:8080; server 192.168.0.101:8080; server 192.168.0.101:8080; } server { listen 80 default; #访问的域名 server_name onloading.cn; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-Nginx-Proxy true; proxy_set_header Connection ""; proxy_pass http://app_nodejs; proxy_redirect off; } }
upstream tomcats { server 192.168.0.100:8080 weight=2; # 2/6次 server 192.168.0.101:8080 weight=3; # 3/6次 server 192.168.0.102:8080 weight=1; # 1/6次 }
upstream tomcats { #表示100服务器的分配比例是2,失败最大次数为3,失败后从新失效时长为15秒 server 192.168.0.100:8080 weight=2 max_fails=3 fail_timeout=15; #表示101服务器无效 server 192.168.0.101:8080 down; #表示102服务器为备份服务器 server 192.168.0.102:8080 backup; }
upstream tomcats { server 192.168.0.100:8080 max_conns=1000; }
目前我只用过以上属性,固然Nginx还有不少其余的属性,有兴趣的能够从网上多找找。tcp