nginx常用配置系列-反向代理

接上篇,反向代理的原理与用途很多地方有讲,用文字说再多可能也表达不清楚,下面贴一张拓扑图,介绍下什么叫反向代理

以上图有两种情景

1. 访问者的客户端是 local ,要访问baidu的服务器,baidu的前台服务器本身不处理具体的业务,只是根据访问的数据类型,或者业务类型等(就是一些特定的规则,比如URL正则),将不同类的请求转发到不同的后端服务器,例如server1是静态资源的,server2是处理账户系统的等

2. 后端的每个server提供的服务完全相同,baidu的前台服务器根据后端每个服务器的负载量来均衡转发客户端来的请求,这种叫负载均衡(server1,server2, server3完全相同)

如何配置nginx的反向代理,我举例常用的nginx+tomcat这种结构的服务器,tomcat默认跑在8080端口,我想将前台的请求都通过80(HTTP)走,下面直接看配置文件:

复制代码
# 定义后端的tomcat服务器组
upstream tomcatserver {
    # server 后端服务器的IP地址:端口 weight权重
    server 127.0.0.1:8080 weight=5;
    server 127.0.0.1:8080 weight=10;
}

server {
    listen       80;
    server_name  example.com;
    
    # 将所有请求转发到tomcat
    location / {
        # 负载均衡转发到后端的服务器组
        proxy_pass   http://tomcatserver;
        # 如果不需要负载均衡,只是将所有的请求转发到某个具体的机器上
        # proxy_pass   http://127.0.0.1:8080;
    }
    
    # 静态资源单独处理,根据location的规则,静态资源会优先处理,不会转发到tomcat
    location ~* .*\.(js|css|ico|png|jpg|eot|svg|ttf|woff|mp3|gif|json|html|swf)$ {
        # 静态资源
        root /home/www;
        # 缓存30天
        expires 30d; 
        # add_header Cache-Control 'no-store';
    }
}
复制代码

上面最核心的是upstream定义段,upstream是用来配置后端服务器均衡的(可以参考http://www.cnblogs.com/jacktang/p/3669115.html)

 至此,一个简单的反向代理代理就配置好了,当然nginx支持很多配置方式,多级负载均衡等,原理都与此相同

 ========= nginx反向代理配置 =========

 

文中有不足指出,请直接指出,QQ:1485619676,欢迎一起交流学习

 

posted @   依天照海  阅读(2718)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示