记一次因ThreadPoolExecutor多线程导致服务器内存压满问题

news/2024/7/8 5:10:14 标签: 服务器, java

经过下载服务器内存数据得知是通过多线程业务处理查询list集合数据没有得到正确释放导致的。

首先先了解一下list集合数据的存放和回收(可能说的不对,请谅解【挠头】)

存放:

        当我们创建一个list或者从数据库查询出的数据用list集合进行接收时,比如

                List<User> user = new ArrayList<User>;

                user.add("张三");

                user.add("李四");

                user.add("王二麻子");

        这个时候我们实际上是在堆内存中创建了一个list实例,并将list的引用放在栈内存的变量中

        user是一个引用,存放在栈内存中,List<User>对象以及集合里的元素("张三","李四","王二麻子")存放在堆内存里。

回收:

        当我们业务处理完成,且调用方法执行结束后,伟大而又优秀的gc就会把内存里的数据回收掉,来释放内存空间。

好,接下来进入今天的正题,废话不多说,直接贴代码

java">public void autoMatic() throws InterruptedException {
		List<ChannelShopTemplate> template = baseService.list();//查询关联商城模板的渠道
		int taskCount = template.size();
		int maxThreadCount = template.size(); // 最多同时执行多少个任务
		ThreadPoolExecutor executor = new ThreadPoolExecutor(maxThreadCount, // 核心线程数和最大线程数都为5
				maxThreadCount, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<>());
		for (int i = 0; i < taskCount; i++) {
			executor.submit(new Task(template.get(i).getTemplateId()));
			System.out.println("当前线程池中线程数:" + executor.getPoolSize());
			// 如果当前线程池中的线程数量已经达到最大线程数,暂停1秒钟后继续添加任务
			while (executor.getPoolSize() == maxThreadCount) {
				Thread.sleep(1000);
			}
		}
		executor.shutdown();
	}

每个线程都会从数据库查询大量数据,如果能正常释放回收,那么就没问题,

经过模拟排查定位出服务器内存压满的原因就是压根没回收,中间的一行代码Thread.sleep(1000);因为用的是while就会一直在这里睡,直接眼睛一闭不睁了,所以导致后面线程关闭和gc回收工作就卡住了。问题解决,心也碎了。

行了,结束,今天就到辶


http://www.niftyadmin.cn/n/5536583.html

相关文章

iOS项目怎样进行二进制重排

什么是二进制重排 &#xff1f; 在iOS项目中&#xff0c;二进制重排&#xff08;Binary Reordering 或者 Binary Rearrangement&#xff09;是一种优化技术&#xff0c;主要目的是通过重新组织应用程序的二进制文件中的代码和数据段&#xff0c;来提高应用程序的性能&#xff…

一 、分布式软总线原理

分布式软总线(Distributed Soft Bus)是HarmonyOS(鸿蒙操作系统)中的关键技术之一,它负责提供设备间统一的分布式通信能力,使得不同终端设备能够像在同一台设备上一样进行高速、低延迟的数据传输和任务协同。在C++实现分布式软总线时,主要涉及以下几个核心部分: 设备发现…

DP学习——策略模式

学而时习之&#xff0c;温故而知新。 敌人出招&#xff08;使用场景&#xff09; 业务中需要多个算法可替换&#xff0c;而不能重构代码时&#xff0c;怎么办&#xff1f; 到你出招 这个时候就要出策略模式这一招了。 具体招式 策略模式的招式&#xff0c;就是把需要替换…

开源205W桌面充电器,140W+65W升降压PD3.1快充模块(2C+1A口),IP6557+IP6538

开源一个基于IP6557和IP6538芯片的205W升降压快充模块&#xff08;140W65W&#xff09;&#xff0c;其中一路C口支持PD3.1协议&#xff0c;最高输出28V5A&#xff0c;另一路是A口C口&#xff0c;最高输出65W&#xff08;20V3.25A&#xff09;&#xff0c;可搭配一个24V10A的开关…

ActiViz实战:鼠标交互和vtkCommand的问题

文章目录 前言一、消失的vtkCallbackCommand二、自定义命令vtkCommand1、自定义一个左键双击事件的命令2、使用观察者/命令模式3、结果 三、vtkObject类中的事件1、vtkCommand中所有的事件2、鼠标事件测试3、如何添加左键的双击事件 四、总结 前言 在C的VTK中&#xff0c;我们…

昇思25天学习打卡营第17天|GAN图像生成

模型简介 GAN模型的核心在于提出了通过对抗过程来估计生成模型这一全新框架。在这个框架中&#xff0c;将会同时训练两个模型——捕捉数据分布的生成模型G和估计样本是否来自训练数据的判别模型D 。 在训练过程中&#xff0c;生成器会不断尝试通过生成更好的假图像来骗过判别…

redis学习(001 介绍)

黑马程序员Redis入门到实战教程&#xff0c;深度透析redis底层原理redis分布式锁企业解决方案黑马点评实战项目 总时长 42:48:00 共175P 此文章包含第1p-第p4的内容 文章目录 介绍差异对比事务区别 认识redis 介绍 两种键值对方式对比 差异对比 事务区别 认识redis

Java中的消息中间件与异步通信实现

Java中的消息中间件与异步通信实现 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 消息中间件和异步通信在现代软件系统中扮演着重要角色。它们可以帮助解耦系…