博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Nginx+Tomcat实现反向代理及动静分离
阅读量:6075 次
发布时间:2019-06-20

本文共 2846 字,大约阅读时间需要 9 分钟。

通常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 &quot;%r&quot; %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后返回如下页面

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

 

配置Nginx

[root@node2nginx]# pwd
/etc/nginx

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

[root@node2nginx]# vim nginx.conf

       location / {


            proxy_pass ;

       }

保存退出,并检查语法

[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

访问测试

确保代理无误

将动态内容重定向至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;

        }

访问测试,结果如下:

因为只将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;
     }

}

访问测试,一切正常,如下所示

 

END,谢谢各位

 

 

本文转自zuzhou 51CTO博客,原文链接:http://blog.51cto.com/yijiu/1435305

转载地址:http://hhigx.baihongyu.com/

你可能感兴趣的文章
Redis--初接触
查看>>
ethereum/EIPs-158 State clearing 被EIP-161取代
查看>>
np.mgrid的用法
查看>>
html 富文本编辑器相关--中文状态下输入@的问题
查看>>
在这里给大家安利一个好的免费的虚拟主机云服务器使用地址
查看>>
Linux下使用wc统计文件行数
查看>>
java.lang.UnsupportedClassVersionError: com/T : Unsupported major.minor version问题解决
查看>>
【GO】golang 方法的值调用和指针调用
查看>>
Devexpress ChartControl 柱状图简单例子
查看>>
n元线性方程非负整数解的个数问题
查看>>
技术题目收集整理
查看>>
想象力比知识更重要么?提出问题比解决问题更重要?
查看>>
iOS边练边学--父子控制器之自定义控制器的切换
查看>>
八个防止浪费时间的小窍门
查看>>
^ 转义字符
查看>>
java面向对象入门之带参方法创建
查看>>
Eclipse反编译插件jad的安装
查看>>
动态加载swiper,默认显示最后一个swiper-slide
查看>>
css 让一张彩色的图片变成一张黑白图
查看>>
Git介绍和基本原理
查看>>