什么情况下要搭建tomcat(你真的知道在生产环境下如何部署tomcat吗)

欢迎关注头条号:老顾聊技术

精品原创技术分享,知识的组装工


目录
  1. 前言
  2. tomcat组件
  3. 部署目录
  4. 目录规划
  5. 目录分离
  6. 启动脚本
  7. 总结
前言

小伙伴们在网上看到的很多文章,都是对tomcat的一些介绍,什么配置啊,怎么启动。其实在生产环境中怎么部署,和网上介绍的有很大区别

这篇文章老顾就带着大家分享一些如何在生产环境下部署。这里不介绍tomcat的一些线程数的配置了,网上一大堆,核心介绍网上没有的。

Tomcat组件

我们先回顾一下tomcat有哪些组件:

什么情况下要搭建tomcat(你真的知道在生产环境下如何部署tomcat吗)(1)

tomcat请求流程:

1、对外接收请求是Connector连接器组件,可以支持不同协议,Connector组件中可设置端口,所以我们请求的时候需要输入端口号。可以把Connector当作接待员

2、Connector组件接收到请求后,转发给处理Engine(catalina引擎)组件去处理。

3、根据请求的域名,分配到对应的Host主机。

4、在根据path分配context组件

区分项目有2个核心组件,一个是host,一个是context。根据域名和path分配不同的项目。其实还少了一个就是启动参数的配置,也就是不同项目的启动参数也可以不一样,如端口号,线程数啊。

部署目录

我们先看一下Tomcat目录结构:

什么情况下要搭建tomcat(你真的知道在生产环境下如何部署tomcat吗)(2)

我们要部署一个web应用,只要把应用的war包放到webapps就可以了。网上一般也是这么讲的。小伙伴们觉得有什么问题吗?

我们看一下,如果我们要部署两个web应用Web-A和Web-B,把他放到webapps中。我们到bin目录下运行startup.sh启动,这样web-A和web-B就可以访问了

如果现在业务上需要把web-B先暂停,那我们改怎么办?还有就是tomcat启动是会有启动参数设置,如最大线程数,最小线程数等配置。那web-A和web-B怎么配置不一样的启动参数呢?

其实还有一个问题,如果我们要把tomcat版本升级怎么办?把tomcat直接覆盖?那些web应用重新部署?

小伙伴们,应该怎么办呢?

目录规划

tomcat软链接

我们先把tomcat应用放到/usr/local目录下

# cd /usr/local # ll drwxr-xr-x. 9 root root 220 5月 8 19:23 apache-tomcat-8.5.40

上面我们是应用了tomcat8.5版本,如果我们需要升级到9.x版本的话,那关于tomcat目录的路径就需要重新修改,这就太不方便了,所以我们可以用软链接的方式解决这个问题

# ln -s apache-tomcat-8.5.40 tomcat # ll drwxr-xr-x. 9 root root 220 5月 8 19:23 apache-tomcat-8.5.40 lrwxrwxrwx. 1 root root 20 5月 8 16:42 tomcat -> apache-tomcat-8.5.40

这样以后用tomcat应用路径,就直接使用tomcat这个软链接,即使将来tomcat升级只要修改一些软链接就行了,其他就不需要改。

目录分离

我们应该要把tomcat和web应用目录分离出来,即使tomcat升级也跟web应用没有关系。那分离出来,怎么启动呢

我们要利用启动参数中的CATALINA_HOME和CATALINA_BASE,来指定tomcat程序应用和web应用;通过CATALINA_BASE就可以实现web应用分离出去,我们来看一些tomcat一共有哪些启动参数

什么情况下要搭建tomcat(你真的知道在生产环境下如何部署tomcat吗)(3)

我们先在/usr/local目录下新建一个web-apps目录,此目录就放web应用

# mkdir web-apps # ll lrwxrwxrwx. 1 root root 20 5月 8 16:42 tomcat -> apache-tomcat-8.5.40 drwxr-xr-x. 2 root root 6 5月 8 20:29 web-apps

在web-apps目录下,新建web-a和web-b目录,这两个目录就是web-A和web-b的web应用目录。

# cd web-apps/ # mkdir web-a # mkdir web-b # ll drwxr-xr-x. 2 root root 6 5月 8 20:33 web-a drwxr-xr-x. 2 root root 6 5月 8 20:33 web-b

把tomcat程序中的conf目录拷贝到web-a和web-b里面,这样各个web应用都有各自的配置文件。

# cp -r /usr/local/tomcat/conf /usr/local/web-apps/web-a/ # cp -r /usr/local/tomcat/conf /usr/local/web-apps/web-b/

再在web-a和web-b目录下,新建webapps和logs目录,webapps存放web应用,logs存放日志文件。

到此目录分离开了,但还缺少一个启动脚本

启动脚本

此启动脚本,老顾引用了网上的一个脚本改造了一下,命名为tomcat.sh

什么情况下要搭建tomcat(你真的知道在生产环境下如何部署tomcat吗)(4)

脚本比较简单,核心就是启动参数,只要注意CATALINA_BASE="`pwd`"的意思是,执行脚本的路径,也就是代表web应用路径是脚本执行的路径;

再把tomcat.sh设置一些启动权限 # chmod x tomcat.sh

修改conf下的server.xml

什么情况下要搭建tomcat(你真的知道在生产环境下如何部署tomcat吗)(5)

修改了红色字体部分,host中的appBase是相对CATALINA_BASE的路径,就是web应用的路径,context中的path是请求url,docBase也是相对路径,相对于appBase的,当然也可以设置绝对路径。在web-a下创建index.html文件

到现在为止的web-a的目录下

# ll drwx------. 3 root root 254 5月 8 22:05 conf drwxr-xr-x. 2 root root 197 5月 8 21:27 logs -rwxr-xr-x. 1 root root 598 5月 8 21:21 tomcat.sh drwxr-xr-x. 2 root root 24 5月 8 21:25 webapps # ll webapps/ -rw-r--r--. 1 root root 12 5月 8 21:25 index.html

启动tomcat.sh

#./tomcat.sh start

访问 http://192.168.31.150:8080/就ok了,直接返回了index.html里面的内容。

需要说明的是,在web-a执行tomcat.sh,里面的启动参数CATALINA_BASE是web应用路径,那tomcat.sh脚本中的$CATALINA_HOME/bin/catalina.sh 这个脚本执行所采用的conf配置文件是web-a目录下的,跟tomcat程序的conf没有任务关系,也跟web-b目录下的conf也没有任何关系,这样就达到了应用之间的配置分离

补充一下,在配置context和host时,很多公司不会在server.xml配置,而是通过conf/Catalina目录下,新建host和context,这个知识点,网上很多,小伙伴们可自行查看,因为我们已经单应用分离出来了,那样的配置好处不大。

总结

上面老顾介绍了tomcat在生产环境的部署要点,其实还缺少一个环节,就是我们war包或jar包是按照什么流程以及方式上传到生产环境的?这个留个悬念,下次老顾会介绍。

我们一般在学习中,一些介绍的资料都是浅层次的,虽然能够运行起来,但在真实使用过程中需要考虑别的因素(维护的方便性,隔离性等),所以在我们学习到的基础上面会有很大的不一样。希望小伙伴通过自己学习的,一定要结合公司或者前辈们分享的生产实战经验,去理解真正的使用。谢谢大家!!!


-End-

如有收获,请帮忙转发,您的鼓励是作者最大的动力,谢谢!

10几年的经验实战分享

相关微服务,分布式,高并发,高可用,企业实战,干货等原创文章正在路上

欢迎关注头条号:老顾聊技术

精品原创技术分享,知识的组装工

推荐阅读

1、分享一线互联网大厂分布式唯一ID设计 之 snowflake方案

2、分享大厂分布式唯一ID设计方案,快来围观

3、你想了解一线大厂的分布式唯一ID生成方案吗?

4、你知道如何处理大数据量吗?(数据拆分篇)

5、如何永不迁移数据和避免热点? 根据服务器指标分配数据量(揭秘篇)

6、你知道怎么分库分表吗?如何做到永不迁移数据和避免热点吗?

7、你了解大型网站的页面静态化吗?

8、你知道如何更新缓存吗?如何保证缓存和数据库双写一致性?

9、你知道怎么解决DB读写分离,导致数据不一致问题吗?

10、DB读写分离情况下,如何解决缓存和数据库不一致性问题?

11、你真的知道怎么使用缓存吗?

12、如何利用锁,防止缓存击穿?重构思想的重要性

13、海量订单产生的业务高峰期,如何避免消息的重复消费?

14、你知道如何保障生产端100%消息投递成功吗?

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页