您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 11348|回复: 0
打印 上一主题 下一主题

[centos] Nginx正向反向代理区别及原理解析

[复制链接]
跳转到指定楼层
楼主
发表于 2020-7-30 12:17:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

一、正向代理和反向代理的区别8 s4 _* V- p. f; }4 o

正向代理代理客户端,反向代理代理服务器。

1.1正向代理
. |/ X/ K; \- |) y" B2 C1 S$ r# j+ X

正向代理服务器位于客户端和服务器之间,为了从服务器获取数据,客户端要向代理服务器发送一个请求,并指定目标服务器,代理服务器将目标服务器返回的数据转交给客户端。这里客户端需要要进行一些正向代理的设置的。

举例:翻墙

正向代理中被代理的是客户端的请求

1.2 反向代理
7 K+ D8 m) o5 r: U" r0 V/ G0 l% Q) K; O

  1. server {4 Q7 _" T* y6 M) d) L: A
  2.     listen    8080;7 ?. `; G% G! i; |: P1 a) \0 |0 @
  3.     server_name localhost;
    / A1 l. B1 w" t4 k% M0 F/ l9 d. o
  4.      ! E, L' P$ g! n7 I9 d$ B/ q! h
  5.     location /category/ {* h) s% e) m3 K1 h; E( d
  6.       proxy_pass http://localhost;& ?# F/ S7 n/ @# ]
  7.     }9 H9 h5 `, x8 r0 @
  8.   }
复制代码
9 d' o! N$ g+ ^0 B- z2 o

反向代理,客户端对代理是无感知的,客户端不需要任何配置就可以访问,客户端将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。

二、nginx反向代理的使用
$ U" B5 p, g+ K) K# u: t& ~3 i

在nginx的配置文件nginx.conf中新建一个虚拟主机的配置,

3 o5 X+ U) }3 p% V

7 T- I& L! W6 w7 F5 N

以上的配置中,

listen 表示nginx要监听的端口;

server_name 就是访问nginx时在浏览器中输入的域名,可以直接填ip地址,要绑定多个可以用空格隔开;

location 表示nginx监听该端口时要匹配的url,如果访问nginx的url中包含有/category/就执行代理

proxy_pass 表示nginx要把客户端的请求代理到的目标。

注意这里proxy_pass的路径写法,如果像上边这样,路径的结尾不带/,表示的是相对路径,那么nginx在转发请求时不会截取掉原始url中的/category/ ,如浏览器访问http://localhost:8080/category/findAll,那么nginx实际发出的请求地址是http://localhost/category/findAll。

如果proxy_pass的目标路径配置时 末尾带上了/ ,表示的是绝对路径,那么nginx在转发请求时就会截取掉原始url中的/category/ ,如浏览器访问http://localhost:8080/category/findAll,那么nginx实际发出的请求地址是http://localhost/findAll。

在配置时要根据自己的需要决定是否需要带 /,不然实际使用时nginx会一直报404的错误。

我这里的配置因为我的后端接口路径中包含了/category,所以我使用了相对路径,保留了这个。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。


; t5 h2 t3 p, z. `
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 09:44 , Processed in 0.156146 second(s), 20 queries .

Copyright © 2001-2024 Powered by cncml! X3.2. Theme By cncml!