![龙之队|一次线上JVM内存溢出分析,GC分析、MAT、gcviewer]()
终于找到了与tomcat相关的类了 , 开心!!!!!
?public class Nio2Endpoint extends AbstractJsseEndpoint {...@Overridepublic void bind() throws Exception {?// Create worker collectionif (getExecutor() == null) {createExecutor();// 统一在这个方法创建线程池}if (getExecutor() instanceof ExecutorService) {threadGroup = AsynchronousChannelGroup.withThreadPool((ExecutorService) getExecutor());}// AsynchronousChannelGroup needs exclusive access to its executor serviceif (!internalExecutor) {log.warn(sm.getString("endpoint.nio2.exclusiveExecutor"));}?serverSock = AsynchronousServerSocketChannel.open(threadGroup);socketProperties.setProperties(serverSock);InetSocketAddress addr = new InetSocketAddress(getAddress(), getPortWithOffset());serverSock.bind(addr, getAcceptCount());?// Initialize SSL if neededinitialiseSsl();}...@Overridepublic void startInternal() throws Exception {?if (!running) {allClosed = false;running = true;paused = false;?if (socketProperties.getProcessorCache() != 0) {processorCache = new SynchronizedStack<>(SynchronizedStack.DEFAULT_SIZE,socketProperties.getProcessorCache());}if (socketProperties.getBufferPool() != 0) {nioChannels = new SynchronizedStack<>(SynchronizedStack.DEFAULT_SIZE,socketProperties.getBufferPool());}?// Create worker collectionif (getExecutor() == null) {createExecutor();// 统一在这个方法创建线程池}?initializeConnectionLatch();startAcceptorThread();}}...}/** * AprEndpoint使用JNI的接口来获得对Socket的访问 * NioEndpoint 同步 * Nio2Endpoint 异步 */// 调用 NioEndpoint、Nio2Endpoint、AprEndpoint的父类AbstractEndpoint#createExecutor()方法public abstract class AbstractEndpoint {...// 创建线程池public void createExecutor() {internalExecutor = true;TaskQueue taskqueue = new TaskQueue();// 找到了我们的类 TaskThreadFactoryTaskThreadFactory tf = new TaskThreadFactory(getName() + "-exec-", daemon, getThreadPriority());executor = new ThreadPoolExecutor(getMinSpareThreads(), getMaxThreads(), 60, TimeUnit.SECONDS,taskqueue, tf);taskqueue.setParent( (ThreadPoolExecutor) executor);}...}?【龙之队|一次线上JVM内存溢出分析,GC分析、MAT、gcviewer】上面涉及到Tomcat的网络NIO架构 , 大家更感兴趣的可以百度搜索相关文章 。 Nio2Endpoint的作用大致就是为Http请求分配线程执行 , 到这里大概明白byte[]数组就是分配在每一个tomact线程中 , 因为使用了Nio , 就会有Buffer概念 , 那么这部分的内存是不能回收的 , 系统启动之后就一直不变 。 而且随着配置的tomcat线程server.tomcat.maxThreads越多占用的内存空间就越大 。
随着配置的tomcat线程越多占用的内存空间就越大?
这个时候我联想到了配置文件 , 查看原来配置文件:application.yml
server:port: 80tomcat:uri-encoding: UTF-8maxHttpPostSize: 10240000maxHttpHeaderSize: 10240000maxThreads: 500acceptCount: 500maxConnections: 600minSpareThreads: 100
推荐阅读
-
智能家居科技 14还能这么用?揪出凶手,到底谁在窥探你的隐私?,iOS
-
视频|真 · 拦路虎!的哥开车偶遇东北虎,默默对视20分钟……
-
OLED|扭转国产OLED行业口碑!卢伟冰称1.5K将是手机行业新主流
-
-
谷歌|几个月前嘲笑iPhone取消耳机孔的谷歌:终于自己破功了
-
金正恩视察灾区重建工作 胞妹陪同前往 系两个月来首次露面
-
林正英真的会茅山术吗,林正英怎么会懂那么多茅山道术-
-
-
张歆艺|张歆艺穿制服躺床上玩闹,穿短裙单脚卖力抬高,姿势豪迈不怕走光
-
-
产妇没有奶水如何催奶,刚生了孩子没有奶水怎么办怎么催奶-
-
-
未说育儿|这些行为最“伤”胎儿,你每天都在做,孕妈要知道
-
腾讯科技网易聆讯后资料披露董事会成员名单,去年向高管及董事支付1760万薪酬
-
答摩健康|为什么你做的明年计划不靠谱?因为你是用今年的脑子想的!
-
数据宝|仅24只,数说A股:基金扎堆的牛股大跌6%!“小而美”股票名单来了
-
中国基金报|重要信号!货币ETF规模激增330亿 啥情况?
-
三分亮剑|危险决定直接影响邻国安全,韩国启动紧急应对,日本不再遮遮掩掩
-
江苏经济报@江苏227家交通运输企业获融资授信8亿元
-