当前位置: 代码网 > 服务器>服务器>Nginx > Nginx中反向代理+负载均衡+服务器宕机解决办法详解

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

2024年05月19日 Nginx 我要评论
1、反向代理作用保证系统安全,不暴露服务器ip,利用nginx服务器,利用内网ip进行访问,避免出现攻击服务器的情况启动本地tomact,127.0.0.1:8080可以访问到tomcat管理页面2、

1、反向代理作用

保证系统安全,不暴露服务器ip,利用nginx服务器,利用内网ip进行访问,避免出现攻击服务器的情况

启动本地tomact,127.0.0.1:8080可以访问到tomcat管理页面

2、反向代理的效果

通过 bbs.liaoxiang.com 可以访问到我的tomcat管理页面(跳转到//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;
        }
       ....

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

到此这篇关于nginx中反向代理+负载均衡+服务器宕机解决办法详解的文章就介绍到这了,更多相关nginx反向代理+负载均衡+服务器宕机内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com