nginx反向代理+负载均衡+服务器宕机解决办法

目录

1、反向代理作用

2、反向代理的效果

配置完成。重启nginx,就可以通过bbs.liaoxiang.com访问到我的tomcat页面

3、负载均衡 (就是多台服务器情况下实现均衡访问的问题)

然后就访问nginx地址,如果配置了反向代理,请用反向代理地址也可以访问。访问三次时可以发现150服务器处理了一次,151处理了两次,成功实现了负载均衡

4、应用服务器宕机


1、反向代理作用

        保证系统安全,不暴露服务器IP,利用nginx服务器,利用内网ip进行访问,避免出现攻击服务器的情况 启动本地tomact,127.0.0.1:8080可以访问到tomcat管理页面

2、反向代理的效果

        通过 bbs.liaoxiang.com 可以访问到我的tomcat管理页面(跳转到 http://127.0.0.1:8080/ ),这里需要在本地hosts文件添加链接指向127.0.0.1 

(注意:要通过连接访问本地地址需要修改hosts文件,百度即可)

  • 下载nginx到本地
  • 启动nginx,通过127.0.0.1可以访问到nginx的主页
  • 配置文件nginx.conf
server {
        listen       80;
        server_name  bbs.liaoxiang.com;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        location / {
            proxy_pass   http://127.0.0.1:8080;
            index  index.html index.htm;
        }
       ....

配置完成。重启nginx,就可以通过bbs.liaoxiang.com访问到我的tomcat页面

 


3、负载均衡 (就是多台服务器情况下实现均衡访问的问题)

在nginx.conf中配置upstream,可以实现负载均衡,负载均衡的作用就是利用多台服务器减轻单台服务器的压力

配置4台tomcat服务器,ip:192.168.10.150,192.168.10.151,192.168.10.152,192.168.10.153

都默认8080端口

配置nginx服务器:

server {
        listen       80;
        server_name  bbs.liaoxiang.com;
    
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        upstream myupstream {
             #weight 值越大,负载权重越大,请求次数越多           
             #max_fails 允许请求失败的次数,超过次数后,转发到下一个服务器,当有max_fails个请求失败,就表示后端的服务器不可用,默认为1,将其设置为0可以关闭检查   
             #fail_timeout 指定时间内无响应则失败, 在以后的fail_timeout时间内nginx不会再把请求发往已检查出标记为不可用的服务器
             #down 表示当前server不参与负载
             #backup 其他非backup server都忙的时候,backup server作为备用服务器,将请求转发到backup服务器
             server 192.168.10.150:8080 weight=1 max_fails=2 fail_timeout=30s;
             server 192.168.10.151:8080 weight=2 max_fails=2 fail_timeout=30s;
             server 192.168.10.152:8080 down;
             #server 192.168.10.153:8080 down;
        }
        location / {
            #反向代理
            proxy_pass http://myupstream;
            index  index.html index.htm;
        }
        ....

这里启动nginx会出现错误,需要在http大括号第一行加上:server_names_hash_bucket_size 64;

然后就访问nginx地址,如果配置了反向代理,请用反向代理地址也可以访问。访问三次时可以发现150服务器处理了一次,151处理了两次,成功实现了负载均衡


4、应用服务器宕机

解决办法

配置文件nginx.conf

server {
        listen       80;
        server_name  bbs.liaoxiang.com;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
 
        upstream myupstream {
             #weight 值越大,负载权重越大,请求次数越多             
             #max_fails 允许请求失败的次数,超过失败次数后,转发到下一个服务器,当有max_fails个请求失败,就表示后端的服务器不可用,默认为1,将其设置为0可以关闭检查   
             #fail_timeout 指定时间内无响应则失败, 在以后的fail_timeout时间内nginx不会再把请求发往已检查出标记为不可用的服务器
             #down 表示当前server不参与负载
             #backup 其他非backup server都忙的时候,backup server作为备用服务器,将请求转发到backup服务器
             server 192.168.10.150:8080 weight=1 max_fails=2 fail_timeout=30s;
             server 192.168.10.151:8080 weight=2 max_fails=2 fail_timeout=30s;
             server 192.168.10.152:8080 down;
             #server 192.168.10.153:8080 myupstream;
 
        }
 
        location / {
            proxy_pass  http://myupstream;
            index  index.html index.htm;
            #这里配置宕机检测,都设置为1秒,这是有了负载均衡过后配置的,如果访问时挂了一个服务器,1秒不响应就自动切换到另外应用服务器进行访问
            proxy_connect_timeout 1;
            proxy_send_timeout 1;
            proxy_read_timeout 1;
        }
       ....

重启关闭其中一个服务器做测试,关闭后访问,当访问到已经宕机的服务器时,很明显的发现浏览器会加载一秒钟(设置的一秒监听)过后重新定向到另外一台服务器,避免了宕机出现不能访问的情况。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值