百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Nginx 反向代理学习及实例笔记_nginx反向代理的主要作用

off999 2025-02-18 12:49 31 浏览 0 评论

背景

前几天在学习负载均衡的知识,遇到了 Nginx 反向代理 的概念,其实在年初就写过一次 Nginx 反向实例的笔记,今天翻看发现很是潦草,而且当时的编辑器也不满足Markdown,作为尴尬症晚期的我,索性删掉重新整理一篇 ...

【一】概念解释

  • 代理

代理其实就是一个中介,A 和 B 本来可以直连,中间插入一个 C,C 就是中介。

  • 正向代理

刚开始的时候,代理多数是帮助内网 client 访问外网 server 用的(比如HTTP代理),从内到外。

  • 反向代理(Reverse Proxy)

"反向"这个词在这儿的意思其实是指方向相反 以代理服务器来接受Internet上的连接请求,然后将请求转发给内部网络上的服务器;并将从服务器上得到的结果返回给Internet上请求连接的客户端 此时代理服务器对外就表现为一个服务器 当一个代理服务器能够代理外部网络上的主机,访问内部网络时,这种代理服务的方式称为反向代理服务。

  • 图像解释 【ps : 来源 知乎】


知乎用户解释图

  1. 正向代理中,Proxy 和 Client 同属一个 LAN,对 Server 透明;
  2. 反向代理中,Proxy 和 Server 同属一个 LAN,对 Client 透明。
  3. 实际上 Proxy 在两种代理中做的事都是代为收发请求和响应,不过从结构上来看正好左右互换了下,所以把后出现的那种代理方式叫成了反向代理。
  • 形象图【ps : 来源 知乎】

形象图示


  • 总结

正向代理隐藏真实客户端,反向代理隐藏真实服务端 正向代理,代理的对象是客户端;反向代理,代理的对象是服务端

【二】反向代理的应用/好处

  • 反向代理的应用:

现在许多大型 web 网站都用到反向代理。 除了可以防止外网对内网服务器的恶性攻击、缓存以减少服务器的压力和访问安全控制之外,还可以进行负载均衡,将用户请求分配给多个服务器

  • 反向代理的好处:

(1). 解决了网站服务器对外可见的问题; (2). 节约了有限的 IP 地址资源,企业内所有的网站共享一个在 internet 中注册的 IP 地址,这些服务器分配私有地址,采用虚拟主机的方式对外提供服务; (3). 保护了真实的 web 服务器,web 服务器对外不可见,外网只能看到反向代理服务器,而反向代理服务器上并没有真实数据,因此,保证了 web 服务器的资源安全; (4). 加速了对网站访问速度,减轻 web 服务器的负担,反向代理具有缓存网页的功能,如果用户需要的内容在缓存中,则可以直接从代理服务其中获取,减轻了 web 服务器的负荷,同时也加快了用户的访问速度。 (5).可以实现安全过滤,流控,防 DDOS 等一系列策略

【三】反向代理的实现

  • 1)需要有一个负载均衡设备来分发用户请求,将用户请求分发到空闲的服务器上
  • 2)服务器返回自己的服务到负载均衡设备
  • 3)负载均衡将服务器的服务返回用户

以上的潜台词是:用户和负载均衡设备直接通信,也意味着用户做服务器域名解析时,解析得到的 IP 其实是负载均衡的 IP,而不是服务器的 IP,这样有一个好处是,当新加入/移走服务器时,仅仅需要修改负载均衡的服务器列表,而不会影响现有的服务。(来自:知乎)

【四】Nginx 反向代理 操作

1). nginx 反向代理 参考配置代码
        #设定负载均衡的服务器列表
        #weigth参数表示权值,权值越高被分配到的几率越大
        upstream Mos{
            server 192.168.1.106:80 weight=3;  
            server 192.168.1.143:80 weight=1;  
            #server localhost:80 weight=1; #本机
        }

        server {
            listen       80;
            server_name  localhost;
            index index.html index.htm index.php;
            root /mnt/web/hyicnoa;

            location / {
                if (!-e $request_filename){
                    rewrite ^/(.*)$ /index.php?s=/$1 last;
                    }
                proxy_pass http://Mos ;  #在这里设置一个代理,和upstream的名字一样
                }
            location ~ .*\.(php|php5)?$
            {
                #fastcgi_pass  unix:/tmp/php-cgi.sock;
                fastcgi_pass  127.0.0.1:9000;
                fastcgi_index index.php;
                include fastcgi.conf;
            }
            location ~ \.php$ 
            {
                proxy_pass  http://192.168.1.106; #此处限制访问 php 文件时,跳转到192.168.1.106 服务器解析
            }
            location ~ .*\.(js|css)?$
            {
            expires 1h;
            }
        }
2).提示

上述配置文件内容仅供参考,信息并未显示完全 强烈建议不要直接修改 nginx.conf 文件,一般是根据类似如下的代码 include /etc/nginx/conf.d/*.conf;进行对应目录下新建文件的配置,以避免较大的配置影响. "proxy_pass http://xxxxxx" 作为代理的位置,需要明确自己在哪种条件下进行代理的使用,具体实践需要参考 nginx 配置语法,着重在于正则表达的限制条件

3). 注意信息
  • (1). 服务器列表仅做参考,以本次操作为例,代理机为 192.168.1.87:80,则访问静态文件时会按 weight 比重分配到 192.168.1.106:80和 192.168.1.143:80服务器器,进行负载分配
  • (2).根据配置信息
location ~ \.php$ 
            {
                proxy_pass  http://192.168.1.106; #此处限制访问php文件时,跳转到192.168.1.106服务器解析
            }

当访问 php 文件时,会由 192.168.1.106 服务器解析内容,完成后再交由192.168.1.87:80显示给用户.

  • (3).针对不同的目录进行代理把下面的配置放到根目录代理的上面
 location /zmPro/ {
        proxy_pass http://192.168.1.143; #当访问zmPro目录时,由该IP服务器进行解析
        }
  • (4). 反向代理进行的负载均衡需要注意 session 的使用限制, 参考文章介绍
  • (5). 个人理解,负载均衡的配置只需更改一处 nginx 配置文件即可,要求服务器列表中的相应目录是尽量可以成功访问的。
  • (6).开启服务,允许访问,本人测试时只是关闭了防火墙,根据定义的均衡服务器,避免访问文件的存在性.
4). 截图
  • default.conf 配置截图,仅供参考
  • 笔记截图
5).结果描述
  • 访问 html 文件时,会根据权重由 192.168.1.106 和 192.168.1.143 进行解析
  • 访问 php 文件时,只会由 192.168.1.106 解析
  • 访问 zmPro 目录下的文件时,会由 192.168.1.143 解析,此时如果是 html 文件,如果 192.168.1.106 对应位置没有相关文件,会根据前面的权重出现不同的访问状况,一种情况是由 192.168.1.143 正常解析,另一种情况是 192.168.1.106 无对应文件而 404 解析失败,如图:


  • 所以,强烈建议匹配不同内容时,注意访问的可行性,以及文件的同步性,建议可参考文章 nginx 反向代理配置及优化
  • 另外还有一些关于c++ Linux后台服务器开发的一些知识点分享:Linux,Nginx,MySQL,Redis,P2P,K8S,Docker,TCP/IP,协程,DPDK,webrtc,音视频等等视频。
  • 需要的朋友可以后台私信【1】获取学习视频

    相关推荐

    qq恢复删除好友官网(qq恢复已删好友)
    qq恢复删除好友官网(qq恢复已删好友)

    qq恢复官方网站,http://huifu.qq.com/1、什么是QQ恢复系统?QQ恢复系统是腾讯公司提供的一项找回QQ联系人、QQ群的服务,向所有QQ用户免费开放。2、QQ恢复系统能恢复多长时间内删除的好友?普通用户可以申请恢复3个月内...

    2025-12-28 16:03 off999

    优启通u盘重装win7系统教程(优启通u盘装win7系统教程图解)

    系统显示未找到万能驱动的解决方法是:1、重插下usb口1、造成“找不到驱动器设备驱动程序”的原因,可能是usb口出现问题。2、换个usb口可能是单独这个usb口出现问题,可以选择另外的usb口重试wi...

    笔记本mac地址在哪看(笔记本电脑mac地址怎么查询)
    • 笔记本mac地址在哪看(笔记本电脑mac地址怎么查询)
    • 笔记本mac地址在哪看(笔记本电脑mac地址怎么查询)
    • 笔记本mac地址在哪看(笔记本电脑mac地址怎么查询)
    • 笔记本mac地址在哪看(笔记本电脑mac地址怎么查询)
    wifi加密方式怎么设置(wifi网络加密怎么设置)

    若你想将自己的无线网改成加密的,可以按照以下步骤操作:1.打开你的路由器管理界面。一般来说,在浏览器地址栏输入“192.168.1.1”或“192.168.0.1”,然后输入用户名和密码登录就可以打...

    sql数据库自学(数据库入门必看——《sql基础教程》)

    SQLServer数据库基础知识:1.数据库是由数据组成的,这些数据可以被组织成有序的数据结构,以支持特定的应用程序。2.数据库管理系统(DBMS)是一种软件工具,用于创建、管理和操作数据库。...

    无线网连接不可上网怎么回事

    可能有几下几方面原因:1、无线路由器网络参数设置错误,无法拨通ISP运营商的局端设备,无法接入互联网;2、宽带线路出现故障,路由器无法拨通ISP运营商的局端设备,无法连通;3、宽带DNS服务器由于某种...

    电脑蓝屏重新启动(电脑蓝屏重新启动快捷键)
    • 电脑蓝屏重新启动(电脑蓝屏重新启动快捷键)
    • 电脑蓝屏重新启动(电脑蓝屏重新启动快捷键)
    • 电脑蓝屏重新启动(电脑蓝屏重新启动快捷键)
    • 电脑蓝屏重新启动(电脑蓝屏重新启动快捷键)
    恢复大师app下载(恢复大师app下载软件)

    是真的。开心手机恢复大师是一款苹果手机数据恢复软件,可以恢复删除的微信聊天记录、短信、通讯录、备忘录、qq聊天记录等17种数据。我测试了一下,确实是可以恢复的。而且开心手机恢复大师是可以免费试用的,是...

    windowsxp下载网站(windows xp download)

    目前无法下载因为红色警戒XP电脑版是一款已经停止开发的游戏,官方已经停止了对其的支持和更新。虽然网上有一些模拟器可以运行该游戏,但是安装和使用相对困难,而且可能存在版权问题。建议玩家选择其他同类型的游...

    没人用过的激活码没过期(没人用过的激活码没过期可以用吗)

    迷你世界并不存在什么激活码的。《迷你世界》是一款高度自由的休闲类3D沙盒游戏,有着非常方便快捷的多人联机模式,只要有网络就能和各个地方的小伙伴们一起玩。这里没有等级和规则限制,没有规定的玩法,只有随心...

    2017年联想笔记本电脑有几款

    17年的笔记本电脑可以勉强安装一下win10系统试试。关键看你的内存有多少,内存大于4个G的话可以安装win10速度不会太慢。最好是安装win7系统,这样能发挥你这台电脑的所有的性能,你用起来也会感觉...

    当前显卡排名(当下显卡排行)

    101、Irispro5802、Iris62002、Iris52004、UHD630/6205、HD6306、HD5307、HD46008、HD44009、HD420010、HD40...

    win10专业版激活变成企业版(win10专业版激活变成企业版怎么办)

    win10永久激活密钥很少,一旦网上有分享,等你拿到时就超过期限了,一般是要购买。激活win10系统可以使用激活工具:win10激活工具下载一、win10专业版产品密钥NXRQM-CXV6P-PBGV...

    ghostwinxp下载纯净版(ghost win7纯净版下载)

    可以下载的,现在官网和其他网站上都可以下载xp原版的。可以通过以下步骤下载我的世界游戏到xp系统中:1.首先打开你的浏览器软件,搜索关键字“我的世界xp版下载”,找到可靠下载地址;2.从下载页面下...

    惠普完整版驱动(惠普最新驱动)

    惠普官方的标准操作:HP1050安装驱动步骤:一:准备:拿出驱动光盘放入光驱或到HP官网下载完整版驱动。二:不要插USB数据线或插上线打印机电源不要开,安装完整版驱动,当程序提示插入USB数据线时,插...

    取消回复欢迎 发表评论: