Nginx+Tomcat实现反向代理及动静分离

通常tomcat部署结构

通常tomcat前端是nginx或apache,后端都为tomcat,也就意味着无论前端是什么角色都是以代理的方式进行工作的

但是要注意的是如果基于nginx做反向代理,转发请求到tomcat的时候是基于http协议进行转发的

但注意的是tomcat的连接器有httpajp jk2 jserv

而如果基于nginx做转发的话只支持http做转发

而如果apache做代理转发的话,几乎常用协议都支持

但常用的连接类型都是ajp协议,因为ajp协议可以工作在二进制模式下,而http协议都是工作在文本模式下,所以ajp的效率要比http要高效

因此要部署一个tomcat前端web服务器很多时候可以使用apache

使用nginx反向代理用户请求至tomcat

规划如下:

服务器角色 服务器IP
Nginx 10.0.10.62
Tomcat 10.0.10.61

 

配置Tomcat

还原配置文件并修改配置文件

[root@node1 conf]#catalina.sh stop
[root@node1 conf]#mv server.xml server.xml.bak2
[root@node1 conf]# cp server.xml.bak server.xml

加入用户

[root@node1 conf]#vim tomcat-users.xml
<rolerolename="manager-gui"/>                                                     #定义管理组,分别是信息页面以及管理页面
<role rolename="admin-gui"/>
<userusername="tomcat" password="tomcat"roles="manager-gui,admin-gui"/>           #将用户tomcat加入至这两个组内

创建网站目录

[root@node1 conf]#mkdir /tomcat/app1

创建host主机

[root@node1 conf]#vim server.xml

加入参数

     <Host name="www.test.com"  appBase="/tomcat/app1"
           unpackWARs="true"autoDeploy="true">       
              <ValveclassName="org.apache.catalina.valves.AccessLogValve"directory="logs"       
              <ValveclassName="org.apache.catalina.valves.AccessLogValve"directory="logs"
     <Context path="/"docBase="/tomcat/app1" />
         <ValveclassName="org.apache.catalina.valves.AccessLogValve"directory="logs"
          prefix="www_access_log." suffix=".txt"
            pattern="%h %l %u %t "%r" %s %b"/>
     </Host>

#path相当于uri的路径
更改默认主机

 <Engine name="Catalina" defaultHost="www.test.com">

更改端口

   <Connector port="80" protocol="HTTP/1.1"

启动服务

[root@node1 conf]#catalina.sh start

部署网站程序,步骤略,访问ip后返回如下页面
wKioL1O6SmnT-9blAASiu6_pSzE799

访问测试无误,继续之后的配置

配置Nginx

[root@node2nginx]# pwd
/etc/nginx

编辑配置文件,将所有的请求都代理至后端tomcat

[root@node2nginx]# vim nginx.conf
       location / {
            proxy_pass http://10.0.10.61:80;
       }

保存退出,并检查语法

[root@node2nginx]# /usr/local/nginx/sbin/nginx -t
nginx: theconfiguration file /etc/nginx/nginx.conf syntax is ok
nginx:configuration file /etc/nginx/nginx.conf test is successful

访问测试
wKioL1O6SoDjQJ_gAAOCzXFIzr4122

确保代理无误
将动态内容重定向至tomcat
再次编辑配置文件

[root@node2nginx]# vim nginx.conf

改为以下参数,凡是以jsp等动态页面的请求统统转发至10.0.10.61的80端口上

        location / {
            root /usr/shar/nginx/html;
            index index.html;
        }
 
        location ~ \.(jsp|do)$ {
            proxy_pass http://10.0.10.61:80;
        }

访问测试,结果如下:
wKiom1O6SsKBneL8AAEldm1MpCQ989

因为只将jsp跳转过来但是图片找不到,这时我们需要使用nginx来响应用户的静态请求
实现动静分离
将图片复制到nginx本地目录,这里我们为了方便并且为了目录的一致性,将其源码全部拷贝至nginx节点

[root@node2nginx]# mkdir -p /web/html
[root@node1tomcat]# scp -r app1 root@node2:/web/html

编辑nginx配置文件,修改如下:

server {
       listen       8080;
        server_name  localhost;
           index index.jsp;
        #charset koi8-r;
        #access_log logs/host.access.log  main;
        location / {
        root /web/html;
           index index.html;
        }
}
    server {
       listen       80;
        server_name  localhost;
           index index.jsp;
        #charset koi8-r;
        #access_log logs/host.access.log  main;
 
   location/ {
         proxy_pass http://10.0.10.61:80;
        }
 
     location ~*\.(html|gif|jpg|jpeg|ico|swf|htm|xml)$ {
         proxy_pass http://10.0.10.62:80;
     }
 
     location ~* \.(jsp|do)$ {
         proxy_pass http://10.0.10.61:80;
     }
}

访问测试,一切正常,如下所示
wKiom1O6StXx3ZPqAAOCzXFIzr4120
END,谢谢各位

还没有评论,快来抢沙发!

发表评论

  • 😉
  • 😐
  • 😡
  • 😈
  • 🙂
  • 😯
  • 🙁
  • 🙄
  • 😛
  • 😳
  • 😮
  • emoji-mrgree
  • 😆
  • 💡
  • 😀
  • 👿
  • 😥
  • 😎
  • ➡
  • 😕
  • ❓
  • ❗
  • 68 queries in 0.408 seconds