tomcat多实例优化及zabbix监控群集(一)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
日志服务 SLS,月写入数据量 50GB 1个月
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: tomcat多实例优化及zabbix监控群集

tomcat简介

Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache,Sun和其他一些公司及个人共同开发而成。

Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。

Tomcat和Nginx,Apache(httpd),lighttpd等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Server和JSP容器,独立的Server容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Nginx/Apache服务器。其他JAVA容器还有resin、weblogic、websphere等。

tomcat安装

  1. 部署java环境
1. [root@tomcat ~]# yum -y install java-1.8.0
2. [root@tomcat ~]# java -version
3. ^Hopenjdk version "1.8.0_352"
4. OpenJDK Runtime Environment (build 1.8.0_352-b08)
5. OpenJDK 64-Bit Server VM (build 25.352-b08, mixed mode)
  1. 部署tomcat
1. [root@tomcat ~]# tar zxf /media/apache-tomcat-8.5.64.tar.gz -C /opt
2. [root@tomcat ~]# cd /opt
3. [root@tomcat opt]# ln -s apache-tomcat-8.5.64 tomcat
4. [root@tomcat opt]# /opt/tomcat/bin/startup.sh         //启动tomcat
5. [root@tomcat opt]# netstat -lntup|grep 8080
6. tcp6       0      0 :::8080                 :::*                    LISTEN      10634/java
  1. tomcat目录介绍

(1)总目录

1. [root@tomcat opt]# cd /opt/tomcat/
2. [root@tomcat tomcat]# tree -L 1
3. ├── bin  startup.sh shutdown.sh          //用以启动,关闭Tomcat或其他脚本功能的脚本(.bat和.sh)
4. ├── conf server.xml                     //用以配置Tomcat的XML及DTD文件
5. ├── lib                                   //存放web应用能访问的JAR包
6. ├── logs                                 //Catalina和其他web应用程序的日志文件
7. ├── temp                             //临时文件
8. ├── webapps 网页根目录               //Web应用程序根目录
9. └── work                             //用以产生有JSP编译出的Servlet的.java和.class文件

(2)webapps目录

1. [root@tomcat tomcat]# cd webapps/
2. [root@tomcat webapps]# ll
3. 总用量8
4. drwxr-x--- 14 root root 4096 8月  10 16:37 docs          #tomcat帮助文档
5. drwxr-x---  6 root root   78 8月  10 16:37 examples      #web应用
6. drwxr-x---  5 root root   82 8月  10 16:37 host-manager  #管理
7. drwxr-x---  5 root root   97 8月  10 16:37 manager       #管理
8. drwxr-x---  3 root root 4096 8月  10 16:37 ROOT          #默认网站根目录

(3)bin目

脚本

作用

startup.sh

开启tomcat脚本

shutdown.sh

关闭tomcat脚本

catalina.sh

核心管理脚本,以后jvm优化参数及相关配置,修改tomcat启动参数

  1. 启动和关闭tomcat
1. 脚本方式:
2.     /opt/tomcat/bin/startup.sh 
3.     /opt/tomcat/bin/shutdown.sh
4. 或者
5.     /opt/tomcat/bin/catalina.sh start
6.     /opt/tomcat/bin/catalina.sh stop
  1. 添加tomcat系统服务
1. cat >> /opt/tomcat/bin/setenv.sh << "END"
2. # 设置tomcat pid
3. CATALINA_PID="$CATALINA_BASE/tomcat.pid"
4. # 设置java参数,提高性能
5. JAVA_OPTS="-server -XX:MetaspaceSize=256M -XX:MaxMetaspaceSize=1024m -Xms512M -Xmx1024M -XX:MaxNewSize=256m"
6. END
  1. 用户、组、权限
1. [root@tomcat ~]# chmod +x /opt/tomcat/bin/setenv.sh    //设置权限
2. [root@tomcat ~]# groupadd -r tomcat
3. [root@tomcat ~]# useradd -r -d /opt/tomcat -s /sbin/nologin -g tomcat tomcat
4. [root@tomcat ~]# chown -R tomcat.tomcat /opt
  1. systemctl启动tomcat脚本
1. cat >> /usr/lib/systemd/system/tomcat.service << "END"
2. [Unit]
3. Description=Apache Tomcat 8
4. After=syslog.target network.target
5. 
6. [Service]
7. Type=forking
8. PIDFile=/opt/tomcat/tomcat.pid
9. ExecStart=/opt/tomcat/bin/startup.sh 
10. ExecReload=/bin/kill -s HUP $MAINPID
11. ExecStop=/bin/kill -s QUIT $MAINPID
12. PrivateTmp=true
13. User=tomcat
14. Group=tomcat 
15. 
16. [Install]
17. WantedBy=multi-user.target
18. END
19. 
20. 启动tomcat:
21. [root@tomcat ~]# systemctl restart tomcat

tomcat配置文件

1.tomcat配置文件介绍

1. [root@tomcat ~]# tree /opt/tomcat/conf/
2. /opt/tomcat/conf/
3. ├── Catalina
4. │   └── localhost
5. ├── catalina.policy
6. ├── catalina.properties
7. ├── context.xml
8. ├── jaspic-providers.xml
9. ├── jaspic-providers.xsd
10. ├── logging.properties
11. ├── server.xml              #主配置文件
12. ├── tomcat-users.xml        #管理用户配置文件
13. ├── tomcat-users.xsd
14. └── web.xml

3.访问网页测试

浏览器访问 http://192.168.8.1:8080

Server.xml详解

  • server.xml组件类别
l 顶级组件:位于整个配置的顶层,如server。l 容器类组件:可以包含其它组件的组件,如server服务器,engine引擎,host主机,context上下文。连接器组件:连接用户请求至tomcat,如connector。被嵌套类组件:位于一个容器内,不能包含其它组件,如Valve,logger。 -->listen 8082
  • 组件详情
server:表示一个运行于JVM中的tomcat实例。
service(服务):将connector关联至engine,因此一个service内部可以有多个connector,但只能有一个引擎engine。service内部有两个connector,一个engine。因此一个service内部可以有多个connector。connector:接收用户请求,类似于httpd的listen配置监听端口。engine:核心容器组件,catalina引擎,负责通过connector接受用户请求,并处理请求,将请求转至对应的虚拟主机host。host:类似于httpd中的虚拟主机,一般而言支持基于FQDN的虚拟主机。context:定义一个应用程序,是一个最内层的容器类组件(不能再嵌套)。篇日志context的主要目的指定对应的webapp的根目录,类似于httpd的alias,其还能为webapp指定额外的属性,如部署方式等。Valve:阀门,拦截请求并在将其转至对应的webapp前进行某种处理操作,可以用于任何容器中,比如记录日志(access log valve),基于IP做访问控制(remote address filter valve)。logger: 日志记录器,用于记录组件内部的状态信息,可以用于除context外的任何容器中。realm:可以用于任意容器类的组件中,关联一个用户认证库,实现认证和授权。可以关联的认证库有两种:UserDatabaseRealm,MemoryRealm和JDBCRealm。UserDatabaseRealm:使用JNDI自定义的用户认证库。MemoryRealm:认证信息定义在tomcat-users.xml中。JDBCRealm:认证信息定义在数据库中,并通过JDBC连接至数据库查找认证用户。
  • 配置文件注释
tomcat配置文件注释

Tomcat端口

tomcat启动之后默认会启动2个端口,分别是8080、8005。

8080端口和8443端口

connectionTimeout="20000"

redirectPort="8443" />

这个端口用于监听浏览器发送的请求,设置为80后可以直接使用域名访问,但是如果使用普通账户启动的tomcat,则不能使用小于1024的端口。

8443端口是用于https连接的,除了打开注释之外还需要有域名证书才可以。

8009端口

Nginx反向代理tomcat的时候可以使用ajp协议反向代理到该端口

不过我们常用的还是反向代理到8080。

8005端口

tomcat监听的关闭端口,就是说这个端口负责关闭tomcat的请求,当执行shutdown.sh关闭tomcat就是链接8085端口执行shutdown命令。

实验步骤

搭建jpress

  1. 安装配置mysql数据库
1. [root@tomcat ~]# rpm -ivh /media/mysql5.6-rpm/* --nodeps --force
2. [root@tomcat ~]# systemctl start mysqld
3. [root@tomcat ~]# systemctl enable mysqld
4. [root@tomcat ~]# mysqladmin -uroot password
5. New password: 
6. Confirm new password: 
7. [root@tomcat ~]# mysql -uroot -p123
8. mysql> create database jpress DEFAULT CHARACTER SET utf8;
9. Query OK, 1 row affected (0.00 sec)
10. 
11. mysql> flush privileges;
12. Query OK, 0 rows affected (0.00 sec)
13. 
14. mysql> exit
15. Bye
  1. 上传jpress代码
[root@tomcat ~]# cp -rp /media/jpress.war /opt/tomcat/webapps/

复制到webapps目录后war包自动解压

  1. web页面配置jpress

浏览器访问http://192.168.8.1:8080/jpress/

安装过程,数据库用户使用root

完成后不用登录,登陆页面访问:http://192.168.8.1:8080/jpress,可以查看页面即可。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
1月前
|
监控 应用服务中间件 nginx
基于Zabbix的SLA监控体系构建与实践
本文由Zabbix社区专家褚凤彬分享,详解SLA在Zabbix中的应用。通过Trigger与Service联动,构建Web应用的多层级监控体系,并介绍SLA计算规则、维护期处理及升级注意事项,助力企业精准掌控服务可用性。
323 36
|
7月前
|
运维 监控 安全
【案例分享】中国通号卡斯柯公司:ZABBIX如何破解轨道交通监控难题
本文根据2023上海峰会上朱林贤的演讲整理,聚焦中国通号卡斯柯公司如何借助Zabbix实现轨道交通信号系统的智能化管理。作为中外合资企业,卡斯柯通过统一平台整合设备监控,大幅降低成本并提升灵活性,成功应用于国内外项目。文章探讨了传统监控系统的痛点、研发维护经验及国产化与开源技术挑战,为行业转型提供了宝贵启示。未来,开放协作将是推动轨道交通智能化发展的关键。
355 8
|
9月前
|
存储 缓存 监控
|
10月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
160 23
|
10月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
243 25
|
10月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
278 22
|
监控 Java 应用服务中间件
【SpringBoot技术专题】「Tomcat技术专区」用正确的姿势如何用外置tomcat配置及运行(Tomcat优化分析)
【SpringBoot技术专题】「Tomcat技术专区」用正确的姿势如何用外置tomcat配置及运行(Tomcat优化分析)
475 0
|
Java 应用服务中间件 Apache
|
Java 应用服务中间件 Linux
|
Web App开发 网络协议 Java

推荐镜像

更多