Nginx反向代理多个服务器的实现方法
nginx反向代理多个服务器,意思是说,当我们发起了不同的请求到nginx,nginx会根据请求的不同,转发到不同的服务器,如下图,当我们通过8000端口访问资源a时,nginx会将请求转发到8080服务器,当访问资源b时,会转发到8081服务器
我们先做下准备工作,首先准备两个tomcat服务器,分别是8080端口和8081端口,8080端口是默认的,这里进行修改8081的端口,首先我们进入tomcat下的conf目录下,进入server.xml文件进行如下两个地方的修改
一、修改shutdown端口号为8015
二、修改start端口号为8081
这样我们就有了两个tomcat了,接下来我们启动一下这两个tomcat,看是否都能访问,如果不能访问,可能就是你防火墙的问题, systemctl stop firewalld ,这个命令可以关闭防火墙,如果还不能访问,可能是阿里云未打开端口
当你的tomcat都可以正常访问后,我们在8080服务器上部署资源a,在8081服务器上部署资源b,具体部署,就是在tomcat下的webapps目录下分别创建a目录和b目录,并创建index.html,里面分别写8080,8081,方便一会测试,这里给出资源a
好了,接下来就是配置nginx了,进入到nginx的conf目录下打开nginx.conf文件,手动配置一个server块
该server的意思是:
- listen 8000:监听8000端口,也就是我们直接访问的nginx端口
- server_name localhost:是域名
- location ~ /a/:是所有访问a资源的请求,会通过下面的代理转发
- http://39.106.231.3:8080;意思是代理转发到ip为39.106.231.3主机下的8080服务器
配置好之后,在sbin目录下执行./nginx -s reload,重新加载配置文件
访问:39.106.231.3:8000/a
访问:39.106.231.3:8000/b
到此这篇关于nginx反向代理多个服务器的实现方法的文章就介绍到这了,更多相关nginx反向代理服务器内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
推荐阅读
-
Nginx服务器作反向代理时的缓存配置要点解析
-
Nginx配置实例-反向代理实现浏览器请求Nginx跳转到服务器某页面
-
Nginx服务器作反向代理实现内部局域网的url转发配置
-
Nginx服务器的SSL证书配置以及对SSL的反向代理配置
-
Nginx服务器的反向代理proxy_pass配置方法讲解
-
nginx 配置虚拟主机,实现在一个服务器可以访问多个网站的方法
-
使用Nginx 反向代理来避免 ajax 跨域请求的方法
-
如何让多个不同类型的后端网站用一个nginx进行反向代理实际场景分析
-
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
-
利用nginx+lua+redis实现反向代理方法教程