当前位置: 首页 > news >正文

05 部署Nginx反向代理

01 服务器基本信息

名称IP地址
真实Web服务器172.2.25.10
Proxy服务器172.2.25.11

02 Proxy基本设置

[root@likexy-nginx-01 conf.d]# pwd
/etc/nginx/conf.d
[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;}
}
# 在Windoes的hosts文件添加# 172.2.25.11	www.wp.proxy.com
image-20241125121945054
图1 使用Proxy服务器访问网页
image-20241125122546464
图2 抓取到的报文
# 通过域名访问的
image-20241125122843285

图3 可以看到hosts文件

# 代理服务器向真实服务器访问时丢掉了头部
image-20241125122928042
图4 丢失掉了头部

03 Proxy添加头部访问Web服务器

# 我们需要代理服务器向后端请求带着域名
[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;proxy_set_header Host $http_host;	# 携带头部信息}
}
# 头部信息携带了,但是版本由1.1变成了1.0
image-20241125123355807
图5 可以看到添加的头部信息

04 Proxy携带版本信息

[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;proxy_set_header Host $http_host;	# 携带头部信息proxy_http_version 1.1;				# 设置HTTP版本}
}
image-20241125123629371
图6 添加HTTP版本信息

05 在Nginx日志添加客户端IP地址

# 但是在日志上面看不到客户端的IP地址,看到的是代理服务器的IP地址
# 最后一个是"-",在nginx配置文件里面写的是"$http_x_forwarded_for",通过代理服务器连接到Web服务器的客户端的原始IP地址# 但是代理服务器没有获取到客户端的IP
image-20241125123827314
图7 访问的Nginx日志,可以看到没有客户端IP地址
[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;proxy_set_header Host $http_host;	# 携带头部信息proxy_http_version 1.1;				# 设置HTTP版本proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;	# 代理服务器获取客户端IP地址}
}
# 配置完访问就有客户端IP地址了
image-20241125125453179
图8 可以看到客户端IP地址

06 代理到Web的TCP连接,响应,返回时间

[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;proxy_set_header Host $http_host;proxy_http_version 1.1;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_connect_timeout 60s;		# 连接时间proxy_read_timeout 60s;			# 响应时间proxy_send_timeout 60s;			# 返回时间}
}

07 代理缓冲区

# 头部信息:就是语言,浏览器信息等
image-20241125130900015
图9 查看头部信息
# 主题信息就是访问的网页资源,图片等
[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;proxy_set_header Host $http_host;proxy_http_version 1.1;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_connect_timeout 60s;proxy_read_timeout 60s;proxy_send_timeout 60s;proxy_buffering on;		# 开启缓冲区proxy_buffer_size 32k;	# 头部信息缓冲区大小proxy_buffers 4 128k;	# 主体信息缓冲区大小
}

08 设置代理文件

[root@likexy-nginx-01 conf.d]# pwd
/etc/nginx/conf.d
# 把代理需要设置的全部放到一个文件
[root@likexy-nginx-01 conf.d]# cat proxy-data 
proxy_set_header Host $http_host;
proxy_http_version 1.1;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout 60s;
proxy_read_timeout 60s;
proxy_send_timeout 60s;
proxy_buffering on;
proxy_buffer_size 32k;
proxy_buffers 4 128k;[root@likexy-nginx-01 conf.d]# cat proxy.conf 
server {listen 80;server_name www.wp.proxy.com;location / {proxy_pass http://172.2.25.10;include /etc/nginx/conf.d/proxy-data;}
}

相关文章:

  • 【Linux高级全栈开发】2.1.2 事件驱动reactor的原理与实现
  • 【运营商查询】批量手机号码归属地和手机运营商高速查询分类,按省份城市,按运营商移动联通电信快速分类导出Excel表格,基于WPF的实现方案
  • ChatGPT:OpenAI Codex—一款基于云的软件工程 AI 代理,赋能 ChatGPT,革新软件开发模式
  • RISC-V 开发板 MUSE Pi Pro V2D图像加速器测试,踩坑介绍
  • 抖音视频怎么去掉抖音号水印
  • uni-app学习笔记七-vue3事件处理
  • esp32课设记录(一)按键的短按、长按与双击
  • 区间带边权并查集,XY4060泄露的测试点
  • pycharm连接github(详细步骤)
  • 如何利用 Java 爬虫获得某书笔记详情:实战指南
  • 面向GIS的Android studio移动开发(二)--在地图上绘制电子围栏
  • Spring AI Alibaba集成阿里云百炼大模型
  • 【已经解决诸多问题】Mamba安装
  • 延时双删-争议与我的思路-001
  • Neo4j数据库
  • 有哪些GIF图片转换的开源工具
  • 07 负载均衡
  • Linux的MySQL头文件和找不到头文件问题解决
  • windows多版本Python共存(大合集)
  • 方案精读:104页DeepSeek金融银行核算流程场景部署建设方案【附全文阅读】
  • 上海这场有温度的“人才集市”,为更多人才搭建“暖心桥”
  • 蒲慕明院士:未来数十年不是AI取代人,而是会用AI的人取代不会用的
  • 法律顾问被控配合他人诈骗酒店资产一审判8年,二审辩称无罪
  • 高新波任西安电子科技大学校长
  • 《求是》杂志发表习近平总书记重要文章《锲而不舍落实中央八项规定精神,以优良党风引领社风民风》
  • 免签国+1,中乌(兹别克斯坦)互免签证协定6月生效