Tomcat调优和JVM参数优化的

关于Tomcat调优和JVM优化,我听完这个的时候,当时就想说,问这个不是应该的么?那么下面阿粉就给大家好好的掰扯掰扯这个Tomcat优化和 JVM 参数优化的事情

Tomcat

这年头还有问Tomcat调优和JVM参数优化的,你还不知道怎么回答么?那么你一定需要看看这篇文章

关于Tomcat是什么东西,相信大家做开发的,肯定是一点也不陌生,服务器,Web应用服务器,一种轻量级的应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。

而我们在日常的开发中,可能很大一部分我们只是知道怎么使用Tomcat服务器,但是却不知道怎么去调整Tomcat里面的各种配置参数,让Tomcat能够更好的运行,那么就听阿粉来给大家介绍把。

配置文件修改优化

Tomcat在Windows下一般的目录都是我们下载解压出来的目录也就是${TOMCAT_HOME},就像这个样子 D:developtomcatapache-tomcat-7.0.88,而他的配置文件就是conf下的server.xml文件,而我们需要调优的肯定也是这个文件里面的内容。

我们就先从 Connector 来进行分析:

Connector :连接器,负责接收客户的请求,以及向客户端回送响应的消息

而我们对 Connector 优化,其实优化的就是我们在访问请求时候的并发能力,而往往并发也是我们在工作中很多时候需要去考虑的问题,而我们在这个连接器里面可以配置什么内容呢?

    <Connector executor="tomcatThreadPool"
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

我们最常用的就是在里面配置一个URL的统一编码格式比如说我们在里面配置一个 UTF-8 的编码格式。

URIEncoding :URIEncoding = UTF-8

executor : 指定这个连接器所使用的执行器(线程池)

connectionTimeout :连接超时时间

maxThreads :客户请求最大线程数

minSpareThreads :Tomcat初始化时创建的线程数,一直会运行的线程

maxSpareThreads :Tomcat连接器的最大空闲线程数

minProcessors :服务器创建时的最小处理线程数

maxProcessors :服务器同时最大处理线程数

enableLookups :若设为true, 则支持域名解析,可把 ip 地址解析为主机名,而为了减少性能的消耗的话,我们就有时候会关闭它

redirectPort :在需要基于安全通道的场合,把客户请求转发到基于SSL 的 redirectPort 端口

acceptAccount :监听端口队列最大数,满了之后客户请求会被拒绝(不能小于maxSpareThreads )

而我们一般最常搭配的,却是 URIEncoding 而很少的去改其他的配置,但是在面试中,肯定不会说让你去优化编码格式把,而我们修改的一定是其他的关于最大处理线程数,域名解析啦,

而我们在最终的配置就不再是上面的代码了,而变成了优化之后的:

    <Connector port="8080"
        protocol="HTTP/1.1" 
        connectionTimeout="20000" 超时时间,毫秒
        redirectPort="443" 
        maxThreads="3000" 最大线程数
        minSpareThreads="20" 最小空闲线程数,这里是一直会运行的线程
        acceptCount="1000" 监听端口队列数
        enableLookups="false" 关闭dns解析,减少性能损耗
        server="None"               
        URIEncoding="UTF-8"   
      />

NIO和BIO还有 NIO2

其实关于 NIO 和 BIO 和 AIO 阿粉在之前已经完全都说过了,同步阻塞 IO 就是 BIO ,而同步非阻塞IO和异步阻塞IO 就是 NIO ,而异步非阻塞IO就是 AIO 啦,

BIO :同步阻塞IO

这年头还有问Tomcat调优和JVM参数优化的,你还不知道怎么回答么?那么你一定需要看看这篇文章

NIO :同步非阻塞IO和异步阻塞IO

AIO :这种异步非阻塞 IO 是我们最需要注意的,是从 JDK7 及其以上才会支持的。

话不多说,直接上如何修改,

<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>

<Connector connectionTimeout="20000" port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" redirectPort="8443"/>
            

网上有人说,从 Tomcat8 以上就是 NIO 模式了,但是实际情况好像是没有,还是需要自己手动去换成 NIO 模式。

关于 Tomcat的优化,阿粉就不再给大家叙述了,给大家再来说说这个关于 JVM 的优化。

JVM

阿粉最开始写文章的时候,就是首先从 JVM 写起来的,大家可以搜索一下曾经阿粉写的关于 JVM 的内容,里面有对 JVM 的完整的介绍,对 FullGC ,YGC 等垃圾收集方式,都做过介绍,这里阿粉只给大家介绍怎么去通过修改 Tomcat 的配置,来达到,我们对 JVM 的优化。

大家都知道,正确的选择不同的 GC 策略,调整 JVM、GC 的参数,可以极大的减少由于 GC 工作,而却这样会大大的提高我们程序的运行效率。

目录还是那个目录,Tomcat 的根目录下的 bin 目录,catalina.bat ,Linux的话,去修改.sh 的文件即可。

找到 JAVA_OPTS 而他就是用来设置 JVM 相关运行参数的变量的,在这里阿粉也给大家说一下关于 JVM 的参数属性,不然不能直接瞎改吧,容易出事。

-Xms :初始堆大小 物理内存的1/64(<1GB)

-Xmx :最大堆大小 物理内存的1/4(<1GB)

-Xmn :年轻代大小(1.4or lator)  注意的是这个 ,整个堆大小=年轻代大小 + 年老代大小 + 持久代大小.

-XX:NewSize :设置年轻代大小(for 1.3/1.4)

-XX:MaxNewSize :年轻代最大值(for 1.3/1.4)

-XX:PermSize :设置持久代(perm gen)初始值 物理内存的1/64

-XX:MaxPermSize :设置持久代最大值 物理内存的1/4

-Xss :每个线程的堆栈大小

-XX:NewRatio :年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)

-XX:+AggressiveOpts :加快编译

-XX:+UseBiasedLocking :锁机制的性能改善

-XX:+DisableExplicitGC :关闭System.gc()

-XX:+UseParNewGC :设置年轻代为并行收集

-XX:+UseConcMarkSweepGC :使用CMS内存收集

-XX:MaxTenuringThreshold :垃圾最大年龄

-XX+UseCMSCompactAtFullCollection :在FULL GC的时候, 对年老代的压缩

-XX:LargePageSizeInBytes :内存页的大小不可设置过大, 会影响Perm的大小

-XX:+UseFastAccessorMethods :原始类型的快速优化

-XX:+UseCMSInitiatingOccupancyOnly :使用手动定义初始化定义开始CMS收集

而这些内容就是需要你去自己手动去挑选一些合适的自己去配置上去,而不是一股脑的复制上去,不然适得其反就不好了。

给阿粉点个在看吧?

< END >

转自:https://mp.weixin.qq.com/s/lwL3KXuj96Tl5QRr-1GsjA

一套完整的 后台管理系统

作者:huanzi-qch

链接:https://www.cnblogs.com/huanzi-qch/p/11534203.html

前言

这套Base Admin是一套简单通用的后台管理系统,主要功能有:权限管理、菜单管理、用户管理,系统设置、实时日志,实时监控,API加密,以及登录用户修改密码、配置个性菜单等

技术栈

前端:layui

java后端:SpringBoot + Thymeleaf + WebSocket + Spring Security + SpringData-Jpa + MySql

工程结构说明

java部分、html、js、css部分都是大目录下面按单表一个子目录存放

一套完整的 后台管理系统,赚钱就靠它了!

一套完整的 后台管理系统,赚钱就靠它了!

运行预览

效果先睹为快,具体介绍在下方,按功能点进行详情介绍

一套完整的 后台管理系统,赚钱就靠它了!

功能演示

登录

(为了方便演示,密码输入框的类型改成text)

配置文件分支选择,dev环境无需输入验证码

一套完整的 后台管理系统,赚钱就靠它了!

一套完整的 后台管理系统,赚钱就靠它了!

同时支持多种登录限制

允许/禁止账号多人在线

一套完整的 后台管理系统,赚钱就靠它了!

软删除

一套完整的 后台管理系统,赚钱就靠它了!

限制登录IP地址

一套完整的 后台管理系统,赚钱就靠它了!

账号过期

一套完整的 后台管理系统,赚钱就靠它了!

更多登录限制,还可以继续扩展

系统设置

一下简单的系统属性设置,想支持更多的配置可自行扩展(比如这里的:用户管理初始、重置密码)

一套完整的 后台管理系统,赚钱就靠它了!

系统设置新增部分功能,详见文末“补充更新”。

推荐阅读:设计模式入门

菜单管理

菜单管理是一棵layui的Tree

增删改

一套完整的 后台管理系统,赚钱就靠它了!

权限管理

增删改查

一套完整的 后台管理系统,赚钱就靠它了!

动态权限加载

权限的加载并不是写死在代码,而是动态从数据库读取,每次调用save方法时更新权限集合

1、妲己是ROLE_USER权限,权限内容为空,无权访问/sys/下面的路径(http://localhost:8888/sys/sysUser/get/1)

2、使用sa超级管理员进行权限管理编辑,给ROLE_USER的权限内容添加 /sys/**,妲己立即有权限访问(http://localhost:8888/sys/sysUser/get/1)

一套完整的 后台管理系统,赚钱就靠它了!

用户管理

主要包括用户信息、登录限制的维护,菜单、权限的分配等

一套完整的 后台管理系统,赚钱就靠它了!

修改用户权限是下一次登录生效

一套完整的 后台管理系统,赚钱就靠它了!

修改用户菜单是刷新系统即可生效

一套完整的 后台管理系统,赚钱就靠它了!

用户管理新增“当前在线用户”管理,详见文末“补充更新”。

推荐阅读:设计模式入门

登录用户信息

基本信息

登录用户只能修改部分信息,例如名称、修改密码

一套完整的 后台管理系统,赚钱就靠它了!

修改密码

密码使用的是MD5加密并转换为16进制字符串存储,用户除了能主动修改密码外,还能叫管理员重置密码

一套完整的 后台管理系统,赚钱就靠它了!

一套完整的 后台管理系统,赚钱就靠它了!

个性菜单

用户可以自行配置自己的个性化快捷菜单

一套完整的 后台管理系统,赚钱就靠它了!

实时日志

使用websocket,实时将日志输出到web页面,1秒刷新一次

注意:这里的日志配置只配置了dev环境,prod环境尚未为空,发布生产环境前记得先配置,否则生成的日志文件将不会输入日志内容!

一套完整的 后台管理系统,赚钱就靠它了!

一套完整的 后台管理系统,赚钱就靠它了!

实时监控

实时监控的是系统硬件环境、以及jvm运行时内存,注:因本人暂无Linux环境,所以只测试了windows环境,有问题请及时反馈,谢谢!

使用websocket,实时将数据输出到web页面,1秒刷新一次

一套完整的 后台管理系统,赚钱就靠它了!

API加密

请求参数加密

一套完整的 后台管理系统,赚钱就靠它了!

响应数据加密

一套完整的 后台管理系统,赚钱就靠它了!

1、系统设置新增API加密开关,可一键关闭、开启API加密;

开启API加密

一套完整的 后台管理系统,赚钱就靠它了!

关闭API加密

一套完整的 后台管理系统,赚钱就靠它了!

关键点讲解

1、定制url访问权限,动态权限读取,需要自定义配置认证数据源、认证管理器、拦截器,详情步骤请参考:

https://www.jianshu.com/p/0a06496e75ea;

2、API加密中,由于登录校验是Spring Security做的,因此我们要在UsernamePasswordAuthenticationFilter获取账号、密码之前完成解密操作,正好我们的校验验证码操作就是在它之前,同时要做响应数据的加密操作,所以登录部分的API加密光按照我们之前的博客来还是不够的,需要在CaptchaFilterConfig进行解密操作,解密后new一个自定义RequestWrapper设置Parameter,并将这个新对象传到doFilter交由下一步处理

3、还是API加密问题,我们是在程序启动的时候生成后端RSA秘钥对,正常来说我们在访问登录页面进行登录的时候前端获取一下就可以了,但在开发环境中,我们通常开启热部署功能,改完代码程序可能会自动重启,但登录用户信息仍然保持在本地线程,系统依旧处于登录状态没有跳转到登录页面,导致后端公钥已经改变,但前端依旧用的是旧的后端公钥,所有导致加解密失败;解决:在访问index首页时也获取一下后端公钥,这样在开发的时候idea热部署后刷新页面就可以了(已提交最新代码,解决热部署后刷新页面还是API加解密失败问题;现在热部署后刷新页面即可)

更新

1、新增百度富文本的使用,但还没配置上传接口:

UEditor文档:http://fex.baidu.com/ueditor/#start-start

对应字段类型,mysql要改成longtext

一套完整的 后台管理系统,赚钱就靠它了!

2、新增“”记住我“”功能,也就是rememberMe,原理以及源码探究请看这位大佬的博客:

https://blog.csdn.net/qq_37142346/article/details/80114609

一套完整的 后台管理系统,赚钱就靠它了!

一套完整的 后台管理系统,赚钱就靠它了!

3、系统设置新增系统颜色,头部、左侧菜单的颜色可按心情切换(SQL文件已同步更新)

一套完整的 后台管理系统,赚钱就靠它了!

4、用户管理模块新增“当前在线用户”管理,可实时查看当前在线用户,以及对当前在线用户进行强制下线操作

一套完整的 后台管理系统,赚钱就靠它了!

代码地址

GitHub:https://github.com/huanzi-qch/base-admin

码云:https://gitee.com/huanzi-qch/base-admin