Tomcat部署以及优化

1、tomcat

tomcat是用java代码的程序,运行的是java的web服务器

tomcat和php一样都是用来处理动态页面,tomcat也可以做为web应用服务器,开源的

php处理.php为结尾的

tomcat 处理.jsp

nginx 处理 .html

2、tomcat的特点和功能

1、servlet容器:执行java servlet 服务端的java程序,处理客户端的http请求,以及响应。

servlet:是java语言当中用于开发web应用程序的关键组件。处理http请求,生成动态内容,以及响应客户端的请求。处理http请求,生成动态内容,处理java的业务逻辑,会话管理,保持用户的状态信息,购物车同步,用户登录等等。也可以转发nginx的动态请求到数据库。

2、jsp容器 javasever page,这是一种动态页面技术,可以在html页面里面嵌入java代码。

jsp:web应用程序的界面,这个界面的语言是用java来实现的.jsp为结尾的文件,index.jsp3、自身也是一个http的服务器

4、tomcat是一个轻量级的动态页面处理程序,高并发场景不使用。

3、tomcat的组件

tomcat可以有多个service,每个service之间互相独立的。

service:对外提供web服务,包含connector和container。

connector:负责对外接受和响应请求。它是tomcat与客户端沟通的一个枢纽,监听端口接受外界请求。

端口:8080。

接受到了请求之后,要传递给其他组件进行处理,处理完成之后要回到connector,在响应客户端。

container:用来负责处理业务逻辑,engine host context wrapper 四个功能组成。

engine:用来管理多个虚拟主机。一个service只能有一个engine。

host:一个host就是一个主机,也可以叫站点,通过配置host可以添加多个站点。

context:一个context代表代表一个web应用。

wrapper:封装器,负载处理最底层的逻辑。

4、tomcat目录的作用

bin 存放启动和关闭tomcat脚本的文件,starup.sh shutdown.sh。

conf 存放tomcat的主配置文件,server.xml主配置文件。

context.xml:存放host的配置信息。

tomcat-user.xml:登录时认证用户和密码的相关信息,manager文件必须要赋权修改之后才能打开。

lib:tomcat运行时需要jar包,一般不动。

logs:日志文件,catalina.out主日志文件。

temp:存放tomcat运行时产生的文件。

webapps:用来部署web应用的目录,类似于nginx的html。

5、Tomcat服务的部署

拖入两个包

1、搭建环境

关闭防火墙以及安全机制

systemctl stop firewalld
setenforce 0

2、 安装jdk环境

#某rpm包尚未安装,我们可以通过该命令查询其说明信息、安装以后会生成的文件;
rpm -qpl jdk-8u201-linux-x64.rpm #安装并以#显示安装进度以及显示详细过程
rpm -ivh jdk-8u201-linux-x64.rpm #查看jdk环境
java -version

 在/etc/profile.d/  目录下创建相关的 .sh 脚本,profile有默认调用的功能。

vim /etc/profile.d/java.sh
---------------------------------------------
export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
export JRE_HOME=$JAVA_HOME/jre
export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib
export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$PATH
wqsource /etc/profile.d/java.sh #生效环境
java -version

3、安装tomcat

cd /opt
#解压tomcat软件包
tar zxvf apache-tomcat-9.0.16.tar.gz#移动至服务软件包统一管理目录中,并且简易其名称
mv apache-tomcat-9.0.16 /usr/local/tomcat

 测试功能,tomcat目录下的bin目录下控制tomcat的关闭与启动

[root@localhost bin]# ./shutdown.sh #关闭tomcat服务[root@localhost bin]# ./startup.sh #开启tomcat服务

测试页面,默认端口是8080

6、  tomcat优化

tomcat优化:tomcat自身的优化、内核优化、jvm优化(开发优化)

tomcat的并发处理能力不强,大项目一般不使用转发动态的中间件(k8s集群,python,rubby),小项目会使用(内部使用)。

1、优化tomcat的启动速度

vim /usr/java/jdk1.8.0_201-amd64/jre/lib/security/java.security
-------------------------
set nu
117行
file:/dev/urandom #修改结果为异步非阻塞
重启

非阻塞的版本,不依赖系统的终端,进程忙也不会进入等待状态,所以处理速度相对较快,如果对应用的安全性要求比较高

2、默认配置不适合成产环境,可能频繁出现假死,需要不停的重启。 根据生产环境的实际 情况,自行测试。

vim server.xml
71行
#port 8080是http的端口 80
#8443 是https的端口 443
#接收客户端https的请求优化线程
maxThreads="500" :tomcat使用线程来处理接收请求的个数,tomcat最多可以创建多少个线程。默认是200个500 1000
minSpareThreads="20":最小空闲数线程,tomcat开启之后,没人使用也会有进程待命,默认值是10
maxSparThrads:最大空闲数进程,一旦线程总数超过了这个值,tomcat就会关闭不再需要的线程。默认是-1,不限制,一般不设置
connectionTimeout="20000" 网络连接超时时间,单位的毫秒,设置成0,永不超时,默认即可。
enableLookups:是否支持反向解析,取值范围:true/false 一般都是关闭false,可以提高处理速度
disableUplaodTimeout=false:上传时是否使用超时机制,默认10秒。true是禁用/false是开启
connectionUploadtimeout="20":上传的超时时间,自定义
acceptCount:当所有可以使用的处理请求的线程数都被使用时,可以接入请求的最大队列长度,超过了这个数字的请求被不予处理(直接丢弃)默认100个。
compression:是否对请响应数据进行压缩,on就是开启,off就是关闭
开启压缩之后,可以有效的减少页面的大小(文本无效,图片,音频,视频)一般可以减少三分之一,节省带宽,默认off。
compression="on"
compressionMinSize:表示响应压缩的最小值,只有响应报文大于这个值才会进行压缩,如果开启了压缩,默认值2048。
noCompressionUserAgents="浏览器名称" 对于这些浏览器,不启用压缩。
compressableMimeType="text/plain,image/jpg"压缩类型,指定对那些类型的文件进行压缩。

常用的页面类型:

文本类型:text/plain,text/html,tetx/css,text/javascript

图片类型:image/jpg,image/jpeg,image/gif

音频:audio/ogg,wav,mpeg

视频:video/mp4,webm,rmvb,quicktime

应用程序:application/pdf,application/json,application/xml

多个之间使用逗号隔开

3、内核优化:系统安全的优化补齐

内核优化的配置文件:

1、打开文件数的限制,系统初始化第一步要做的事情 

vim /etc/security/limits.conf

2、内核参数文件:

vim /etc/sysctl.conf---------------------------
sysctl -a 查看系统默认参数
常见的
net.ipv4.ip_forward=0/1 禁用或者开启数据包的转发功能。要做路由器必须打开,0是关,1是开
net.ipv4.tcp_max_tw_buckets=2000允许timewait的最大数量。
net.ipv4.tcp_sack=1 启用有选择的应答,提高tcp的处理性能。
net.core.netdev_max_backlog=262144 (字节)网络接口接收数据包队列的最大的大小
vm.swappiness=0 关闭内存的交换行为,不使用交换分区,k8s默认就不能使用交换分区,否则会保存。
net.ipv4.tcp_max_orphans:系统允许的最大的tcp连接数量
net.ipv4.ip_local_port_range=1024 65000 设定系统的端口范围1024-65000
net.ipv4.tcp_fin_timeout=10 tcp关闭连接超时时间
net.ipv4.tcp_keepalive_time:设置tcp的keepalive包的探测包的发送频率,用于检查连接状态

其他的

kernel.sysrq = 0: 禁用了内核的SysRq功能,SysRq允许在系统崩溃或出现问题时执行一些调试操作。kernel.core_uses_pid = 1: 设置核心转储文件名中包含进程ID,有助于标识是哪个进程导致了核心转储。kernel.msgmnb 和 kernel.msgmax: 增加IPC消息队列的默认和最大大小,用于进程间通信。kernel.shmmax 和 kernel.shmall: 调整共享内存的最大大小和分配页面数。net.ipv4.ip_forward = 0: 禁用IP数据包的转发功能,通常用于不充当路由器的系统。net.ipv4.conf.default.rp_filter 和 net.ipv4.conf.all.rp_filter: 控制反向路径过滤,提高网络安全性。net.ipv4.icmp_echo_ignore_all: 允许或禁止系统响应ping请求。net.ipv4.icmp_echo_ignore_broadcasts: 禁止系统对广播和多播地址的ICMP回显和时间戳请求作出响应。net.ipv4.conf.default.accept_source_route: 不接受源路由,增加网络安全性。net.ipv4.tcp_syncookies = 1: 启用SYN Cookies,保护系统免受TCP SYN 攻击。net.ipv4.tcp_max_tw_buckets = 6000: 设置允许的TIME_WAIT套接字最大数量,避免服务器性能下降。net.ipv4.tcp_sack = 1: 启用有选择的应答(SACK)来提高TCP性能。net.ipv4.tcp_window_scaling = 1: 启用TCP窗口缩放功能,允许大窗口的TCP传输。net.ipv4.tcp_rmem, net.ipv4.tcp_wmem: 调整TCP套接字读取和写入缓冲区大小。net.ipv4.tcp_mem: 设置TCP缓冲区的最小、默认和最大值。net.core.wmem_default, net.core.rmem_default, net.core.rmem_max, net.core.wmem_max: 调整网络核心
缓冲区的大小。net.core.netdev_max_backlog: 控制网络接口接收数据包的排队队列大小。net.ipv4.tcp_max_orphans: 设置系统允许的孤立TCP连接最大数量。net.ipv4.tcp_max_syn_backlog: 控制系统允许的三次握手队列长度。net.ipv4.tcp_synack_retries 和 net.ipv4.tcp_syn_retries: 设置SYN-ACK和SYN请求的重试次数。net.ipv4.tcp_tw_recycle 和 net.ipv4.tcp_tw_reuse: 启用TIME_WAIT套接字快速回收和重用。net.ipv4.tcp_fin_timeout: 设置TCP连接FIN(关闭连接)的超时时间。net.ipv4.tcp_keepalive_time: 设置TCP keepalive探测包发送频率,以检测连接状态。net.ipv4.ip_local_port_range: 设置本地端口范围,用于分配本地应用程序端口。net.ipv6.conf.all.disable_ipv6 和 net.ipv6.conf.default.disable_ipv6: 禁用IPv6。net.netfilter.nf_conntrack_max 和其他 net.netfilter.nf_conntrack_*: 控制连接跟踪和防火墙相关设置。net.nf_conntrack_max: 设置最大连接跟踪项数。vm.overcommit_memory = 0: 控制内存超额分配策略,避免OOM killer杀掉进程。vm.swappiness = 0: 设置内存交换行为,降低内存交换。fs.file-max = 999999: 设置进程可以同时打开的最大文件句柄数。net.ipv4.tcp_max_tw_buckets = 6000: 设置操作系统允许的TIME_WAIT套接字最大数量。net.ipv4.ip_local_port_range = 1024 65000: 设置系统允许的本地端口范围。net.ipv4.tcp_tw_recycle = 1: 启用TIME_WAIT套接字快速回收。

4、 jvm的优化

起jar包的命令

java -jar 包名 &

 在bin下的catalina.sh

对以下命令行进行解释

-Xms2048m -Xmx2048m -Xmn768m -XX:ParallelGCThreads=2 -XX:PermSize=1024m -XX:MaxPermSize=1024m -Djava.awt.headless=true -XX:+DisableExplicitGC" 
cygwin=false

-Xms:java初始化堆的大小,分配jvm的最小内存,cpu的性能比较高,可以分配的高一点

-Xmx:java堆的最大值,也就是jvm的最大内存,主要取决于物理内存的大小,官方建议设置成与xms一样的值。

设置成物理内存的一半。

-Xmn:新生代内存的大小,官方推荐,设置成jvm内存最大值的3/8

java自带垃圾回收机制,java进行垃圾回收之后不需要重新计算堆区的大小。

堆区:新生代 中生代 老年代

每生成一个新的对象,对象占用的内存空间就是新生代空间。

垃圾回收对堆区当中的资源进行回收之后,新生代没有被回收的资源就转移到中生代,中生代的就会转移到老年代。

整个jvm堆的大小:新生代+老生代+永久代(系统自带的)

-XX:ParallelGCThreads=2:配置并行收集器的线程数,同时有多少个线程一起进行垃圾回收,一般配置成cpu的一半。

-XX:PermSize=1024m:设置非堆内存的初始值,持久带内存的大小,默认是物理内存的1/4,建议设置成整个jvm内存的一半,在非堆内存是不会被java的垃圾回收机制处理的

-XX:MaxPermSize=1024m:非堆内存的最大值,和初始值一致即可。

-Djava.awt.headless=true:防止在linux访问的情况下,web页面的图片不能打开。

+DisableExplicitGC":老年代的收集算法,缩短垃圾回收机制的时间

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/372983.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

超详细!Jmeter 压测-设计5W并发量场景

需求:设计一个5W并发量的性能场景? 1、确定性能测试工具,性能测试思路 测试工具:Jmeter 并发设计思路:如果被测服务足够快,比如10ms的响应时间,1个线程/秒就是100tps,5万的TPS&…

MySQL之基本查询(上)-表的增删查改

目录 Create(创建) 案例建表 插入 单行数据 指定列插入 单行数据 全列插入 多行数据 全列插入 插入是否更新 插入时更新 替换 Retrieve(读取) 建表插入 select列 全列查询 指定列查询 查询字段为表达式 为查询结果指定别名 结果去重 where条件 比较运算符 逻辑运…

嵌入式代码升级——IAP

目录 IAP的特点 实现 IAP 功能 STM32 正常的程序运行流程 STM32 加入IAP后的运行流程 程序执行流程 BootLoader程序 APP1程序 APP2程序 验证操作步骤 IAP(In-Application Programming)指的是在应用程序运行时对其自身的Flash存储器进行编程的操作…

招投标信息采集系统:让您的企业始终站在行业前沿

一、为何招投标信息如此关键? 在经济全球化的大背景下,招投标活动日益频繁,成为企业获取项目、拓展市场的主流方式之一。招投标信息采集,作为企业战略决策的前置环节,其重要性不言而喻。它不仅关乎企业能否第一时间发…

如何网页在线编辑微软Office Word,并导出为PDF格式。

随着互联网技术的不断发展,越来越多的企业开始采用在线办公模式,微软Office Word 是最好用的文档编辑工具,然而doc、docx、xls、xlsx、ppt、pptx等格式的Office文档是无法直接在浏览器中直接打开的,如果可以实现Web在线预览编辑Of…

git只列出本地分支

git只列出本地分支 git branch --list git强制删除本地分支 git branch -D_error: the branch dlx-test is not fully merged. -CSDN博客文章浏览阅读648次。git branch -d 可以通过: git branch 查看所有本地分支及其名字,然后删除特定分支。git删除远程remote分支…

互联网医院系统,开发互联网医院设计哪些功能?

随着科技的进步和数字化转型的推动,互联网医院系统已成为现代医疗服务的重要组成部分。这一系统通过整合信息技术与医疗资源,为用户提供便捷、高效的医疗服务。以下是互联网医院系统的主要功能介绍。 1、在线咨询与诊断 互联网医院系统允许患者通过网络平…

IEC62056标准体系简介-2.IEC62056标准体系及对象标识系统(OBIS)

1. IEC 62056标准体系 IEC 62056标准体系目前共包括六部分,见图1: 第61部分:对象标识系统第62部分:接口类第53部分:COSEM应用层第46部分:使用HDLC(High Level Data Link Control)协…

54、一维和二维自组织映射(matlab)

1、一维和二维自组织映射原理 一维和二维自组织映射(Self-Organizing Maps, SOM)是一种无监督的机器学习算法,通过学习输入数据的拓扑结构,将高维输入数据映射到低维的网格结构中,使得相似的输入数据点在映射空间中也…

阿尔泰科技与西安交通大学陕西省某技术重点实验室共谋未来!

近日,阿尔泰科技的电子工程师(熊工)应邀前往西安交通大学陕西省某技术重点实验室,参与课题组项目的测试与调试工作。此次合作不仅成功推动了项目的进展,还为未来的深入合作奠定了坚实基础。 阿尔泰科技作为领先的测控技…

刷题之删除有序数组中的重复项(leetcode)

删除有序数组中的重复项 这题简单题&#xff0c;双指针&#xff0c;一个指针记录未重复的数的个数&#xff0c;另一个记录遍历的位置。 以下是简单模拟&#xff0c;可以优化&#xff1a; class Solution { public:int removeDuplicates(vector<int>& nums) {int l0…

Debezium报错处理系列之第114篇:No TableMapEventData has been found for table id:256.

Debezium报错处理系列之第114篇:Caused by: com.github.shyiko.mysql.binlog.event.deserialization.MissingTableMapEventException: No TableMapEventData has been found for table id:256. Usually that means that you have started reading binary log within the logic…

博美犬插画:成都亚恒丰创教育科技有限公司

​博美犬插画&#xff1a;萌动心灵的细腻笔触 在浩瀚的艺术海洋中&#xff0c;有一种艺术形式总能以它独有的温柔与细腻&#xff0c;触动人心最柔软的部分——那便是插画。而当插画遇上博美犬这一萌宠界的明星&#xff0c;便诞生了一幅幅令人爱不释手的作品&#xff0c;成都亚…

代码随想录打卡第十八天

代码随想录–二叉树部分 day 17 休息日 day 18 二叉树第五天 文章目录 代码随想录--二叉树部分一、力扣654--最大二叉树二、力扣617--合并二叉树三、力扣700--二乘树中的搜素四、力扣98--验证二叉搜索树 一、力扣654–最大二叉树 代码随想录题目链接&#xff1a;代码随想录 给…

美容师有什么话术技巧?美业人如何提升自己的销售技巧?博弈美业门店管理系统分享经验

作为一名美容师&#xff0c;有一些话术和销售技巧可以帮助你提升服务质量和销售业绩。以下是博弈美业收银系统分享的一些建议&#xff1a; 1.建立信任&#xff1a; 在与客户交流时&#xff0c;表现出真诚、友好和专业的态度。倾听客户的需求&#xff0c;并给予针对性的建议&a…

随笔(一)

1.即时通信软件原理&#xff08;发展&#xff09; 即时通信软件实现原理_即时通讯原理-CSDN博客 笔记&#xff1a; 2.泛洪算法&#xff1a; 算法介绍 | 泛洪算法&#xff08;Flood fill Algorithm&#xff09;-CSDN博客 漫水填充算法实现最常见有四邻域像素填充法&#xf…

Redis代替Session实现共享

集群的session共享问题 session共享问题&#xff1a;多台tomcat并不共享session存储空间&#xff0c;当请求切换到不同的tomcat服务时导致数据丢失的问题。 session的替代方案&#xff1a; 数据共享内存存储key、value结构 将redis替换session可以解决session共享问题

Day65 代码随想录打卡|回溯算法篇---组合总和II

题目&#xff08;leecode T40&#xff09;&#xff1a; 给定一个候选人编号的集合 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字在每个组合中只能使用 一次 。 注意&#xff1a;解集不能包含…

第十八节 LLaVA如何按需构建LORA训练(视觉、语言、映射多个组合训练)

文章目录 前言一、基于llava源码构建新的参数1、添加lora_vit参数2、训练命令脚本设置二、修改源码,构建lora训练1、修改源码-lora训练2、LLM模型lora加载3、VIT模型加载4、权重冻结操作5、结果显示三、实验结果前言 如果看了我前面文章,想必你基本对整个代码有了更深认识。…

DevOps实战:使用GitLab+Jenkins+Kubernetes(k8s)建立CI_CD解决方案

一.系统环境 本文主要基于Kubernetes1.21.9和Linux操作系统CentOS7.4。 服务器版本docker软件版本Kubernetes(k8s)集群版本CPU架构CentOS Linux release 7.4.1708 (Core)Docker version 20.10.12v1.21.9x86_64CI/CD解决方案架构图:CI/CD解决方案架构图描述:程序员写好代码之…