通常的代理服务器,只用于代理内部网络对Internet的连接请求,客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中由代理服务器向Internet上的web服务器发起请求,最终达到客户机上网的目的。
而反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
如下图:
nginx+Tomcat实现反向代理
安装Tomcat
端口号分别改为9001,9002
修改nginx.conf配置
#配置一个代理即tomcat9001服务器
upstream tomcat_server_9001 {
server 192.168.150.128:9001;
}
#配置一个代理即tomcat2服务器
upstream tomcat_server_9002 {
server 192.168.150.128:9002;
}
#配置一个虚拟主机
server {
listen 80;
server_name www.yoess.com;
location / {
#域名www.yoess.com的请求全部转发到tomcat_server_9001即tomcat9001服务上
proxy_set_header Host "www.yoess.com";
proxy_pass http://tomcat_server_9001;
#欢迎页面,按照从左到右的顺序查找页面
index index.jsp index.html index.htm;
}
}
server {
listen 80;
server_name www.yoess.cn;
location / {
#域名www.yoess.cn的请求全部转发到tomcat_server_9002即tomcat9002服务上
proxy_set_header Host "www.yoess.cn";
proxy_pass http://tomcat_server_9002;
index index.jsp index.html index.htm;
}
}
proxy_set_header问题,如果不设置跳转不了 !!待研究。不知原因出在哪里。
启动测试
www.yoess.cn 的请求全到了9002服务器
www.yoess.com的请求全到了9001服务器