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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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,可以查看页面即可。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
3月前
|
Arthas 监控 Java
Arthas 可以用于监控和诊断在 Windows 系统下部署的 Tomcat 服务
Arthas 可以用于监控和诊断在 Windows 系统下部署的 Tomcat 服务
181 2
|
4月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
77 4
|
4月前
|
监控 关系型数据库 机器人
小白带你学习linux的监控平台zabbix
小白带你学习linux的监控平台zabbix
137 0
|
6月前
|
监控 关系型数据库 MySQL
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
|
1月前
|
数据采集 监控 数据库
请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
【2月更文挑战第25天】请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
25 2
|
6月前
|
监控
zabbix如何添加自定义监控项
zabbix如何添加自定义监控项
263 0
|
2月前
|
Java 应用服务中间件
优化tomcat的性能
优化tomcat的性能
|
2月前
|
监控 Cloud Native 关系型数据库
使用 Grafana 统一监控展示 - 对接 Zabbix
使用 Grafana 统一监控展示 - 对接 Zabbix
|
4月前
|
监控 Docker 容器
Zabbix【部署 03】zabbix-agent2安装配置使用(zabbix-agent2监控docker实例分享)
Zabbix【部署 03】zabbix-agent2安装配置使用(zabbix-agent2监控docker实例分享)
242 0

推荐镜像

更多