nginx反向代理踩坑(容器方式)

简介: nginx反向代理踩坑(容器方式)

一、简述



1.1 什么是反向代理?

这很重要,反向代理就是代理服务器代理真实服务器。客户端以为代理服务器就是真实服务器,所以就会把要请求的==资源(URL)==发给代理服务器。


代理服务器一般是由nginx来充当,代理功能由配置文件来完成。


4a8753492b4547d3e24b011d68e69b1f_bac9c8409edd1bf5dab33ce8de191b80.png


1.2 看图理解

画的仓促,大概有这个意思


e4de4b9c326ff017114e16b36f159a4e_8ba5904039e07bd6b5042ed4ab9e9145.png


1.3 错误总结

错误记录:


nginx和tomcat全容器化


用nginx代理两台tomcat服务器,


当访问资源带edu的时候交给tomcat1


当访问资源带vod的时候交给tomcat2


做反向代理测试的时候,写的是完整的URL,不是部分路径。因为代理服务器在客户端看来就是真实服务器!!!


这次对反向代理的理解更深刻了,坚持下来没有错。


同时,请教别人也是必须的,多交流多思考才能更好的解决问题~


以下是错误演示


70b9f899404bf3619b9b2e300158c673_394c0de8378a79a6af7f9953f81fda48.png


二、正确案例


2.1 启动nginx

docker run --name nginx -p 80:80 --link=tomcat:tomcat1 --link=tomcat02:tomca -v /opt/docker-nginx/nginx.conf:/etc/nginx/nginx.conf -v /opt/docker-nginx/log:/var/log/nginx -v /opt/docker-nginx/conf.d/default.conf:/etc/nginx/conf.d/default.conf -d 313ec0a602bc


2.2 启动tomcat

先启动一个


docker run -it -p 8080:8080 tomcat


docker cp复制文件


docker cp 容器id:/usr/local/tomcat/webapps.dist/* /opt/webapps


再启动挂载卷


docker run -it -p 8081:8080 --name tomcat01 -v /opt/webapps:/usr/local/tomcat/webapps tomcat


docker run -it -p 8082:8080 --name tomcat02 -v /opt/webapps:/usr/local/tomcat/webapps tomcat


建文件,建资源


[root@VM-16-8-centos vod]# ll

total 4

-rw-r–r-- 1 root root 11 Apr 14 21:42 a.html

[root@VM-16-8-centos vod]# pwd

/opt/tomcat/webapps/vod


[root@VM-16-8-centos edu]# ll

total 4

-rw-r–r-- 1 root root 8 Apr 14 21:26 a.html

[root@VM-16-8-centos edu]# pwd

/opt/tomcat/webapps/edu


1769a315086c9082ac1a78d4fcc9cab4_3587e60a77049d3f5e5959ca6ee077fa.png


2.3 配置nginx

[root@VM-16-8-centos docker-nginx]# vim nginx.conf 
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
      listen 80;
      server_name xxx.xxx.xxx.xxx;
      location ~ /edu/ {
         proxy_pass http://xxx.xxx.xxx.xxx:8081;
      }
      location ~ /vod/ {
         proxy_pass http://xxx.xxx.xxx.xxx:8082;
      }
    }
}

2.4 重启所有服务

docker restart …


2.5 测试


3080f2338965c30308ad6638873e0e68_6a13be98a00a50e8835c8e2c24c0a21f.png

e7e35ccea8d9d42369f483be659f2aa6_4b01279a69e77432e3795f72f102bc7c.png


三、云服务器上跑的nginx怎么代理本地项目


不可以!

要么都在云端,只有代理服务器IP和真实服务器IP能互通的情况下才能代理!!!

相关文章
|
3天前
|
缓存 负载均衡 应用服务中间件
Nginx七层(应用层)反向代理:HTTP反向代理proxy_pass篇
通过使用Nginx的反向代理功能,可以有效地提高Web应用的性能、安全性和可扩展性。配置过程中需要注意不同场景下的具体需求,如负载均衡、SSL终止和缓存策略等。正确配置和优化Nginx反向代理可以显著提升系统的整体表现。
33 18
|
2月前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
173 61
|
2月前
|
缓存 负载均衡 安全
Nginx的反向代理具体是如何实现的?
Nginx的反向代理具体是如何实现的?
|
24天前
|
缓存 Java 应用服务中间件
nginx的正向代理和反向代理以及tomcat
Nginx的正向代理和反向代理功能在不同的场景中具有重要作用,正向代理主要用于客户端访问控制和匿名浏览,而反向代理则用于负载均衡和高可用性服务。Tomcat作为Java Web应用服务器,与Nginx结合使用,可以显著提升Web应用的性能和稳定性。通过合理配置Nginx和Tomcat,可以构建高效、稳定和可扩展的Web服务架构。
124 11
|
1月前
|
存储 应用服务中间件 nginx
nginx反向代理bucket目录配置
该配置实现通过Nginx代理访问阿里云OSS存储桶中的图片资源。当用户访问代理域名下的图片URL(如 `http://代理域名/123.png`)时,Nginx会将请求转发到指定的OSS存储桶地址,并重写路径为 `/prod/files/2024/12/12/123.png`。
77 5
|
2月前
|
缓存 负载均衡 算法
如何配置Nginx反向代理以实现负载均衡?
如何配置Nginx反向代理以实现负载均衡?
|
2月前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
2月前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
529 1
nginx配置反向代理404问题
|
2月前
|
安全 应用服务中间件 网络安全
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
如何测试Nginx反向代理实现SSL加密访问的配置是否正确?
126 3
|
2月前
|
安全 应用服务中间件 网络安全
配置Nginx反向代理实现SSL加密访问的步骤是什么?
我们可以成功地配置 Nginx 反向代理实现 SSL 加密访问,为用户提供更安全、可靠的网络服务。同时,在实际应用中,还需要根据具体情况进行进一步的优化和调整,以满足不同的需求。SSL 加密是网络安全的重要保障,合理配置和维护是确保系统安全稳定运行的关键。
189 3