当前位置: 首页 > news >正文

Java线程池基本概念

  • 全局和局部线程池
    • 全局线程池
      • 在Spring框架中,全局线程池如ThreadPoolTaskExecutor通常是作为Spring Bean存在的,它们的生命周期由Spring容器管理。当Spring容器关闭时,这些线程池也会被适当地清理和关闭。因此,开发者通常不需要手动关闭这些全局线程池
    • 局部线程池
      • 对于在方法内部或者某个局部作用域创建的线程池,它们是局部资源,不会被Spring容器管理。如果不关闭这些线程池,可能会导致线程泄漏,因为这些线程池会继续存在并占用系统资源,直到程序结束。因此,使用完局部线程池后,需要调用shutdown()或shutdownNow()方法来关闭线程池,释放资源。
    • 资源管理
      • 关闭线程池是为了合理管理资源,防止资源泄露和浪费。全局线程池由Spring容器管理,可以确保在应用关闭时得到妥善处理。而局部线程池如果没有正确关闭,可能会导致不必要的资源占用,甚至影响应用程序的稳定性。
    • 总结:全局线程池由于其与Spring容器的生命周期绑定,通常不需要手动关闭;而局部线程池需要在使用完毕后显式关闭,以避免资源泄露和其他潜在问题。
    • 多线程使用要设置超时时间不然会OOM
      • 默认:超时时间并不是一个固定的时间,而是取决于多种因素,包括Spring的配置、操作系统和Java虚拟机的配置等
      • 设置了最大活跃时间,会变成默认超时时间
      • 原因:线程资源未释放,如果线程执行的任务长时间无法完成,这些线程会持续占用系统资源,包括内存。当应用创建过多未完成任务的线程时,内存资源逐渐被消耗,最终可能导致内存不足,从而引发OO
  • 单个线程池和多个线程池
    • 案例区别
      • 某程序使用:
        • ThreadPoolExecutor ThreadPoolAll = new ThreadPoolExecutor(30,60);
      • 某程序使用:
        • ThreadPoolExecutor ThreadPoolA = new ThreadPoolExecutor(15,30);
        • ThreadPoolExecutor ThreadPoolB = new ThreadPoolExecutor(15,30);
    • 单个线程池的优势
      • 简单:只需要管理一个线程池,代码实现和维护相对简单。
      • 资源共享:所有任务都在同一个线程池中执行,可以更好地利用系统资源,避免资源碎片化即有效利用资源。
    • 多个线程池的优势
      • 线程池资源隔离:每个线程池都有其最大线程数限制,可以防止某个线程池占用过多资源,导致其他线程池资源不足。
      • 任务优先级:通过配置不同的线程池,可以根据任务优先级为不同类型的任务分配不同的资源。
      • 鲁棒性:如果某个线程池出现问题,不会影响到其他线程池的正常运行。
  • ThreadLocal
    • 存储原理
      • threadLocal内部维护了一个Map,用于存储线程ID到其对应变量副本的映射。当一个线程访问ThreadLocal时,它会通过线程ID在Map中找到对应的变量副本。这样,即使多个线程同时访问同一个ThreadLocal变量,它们也只会访问到自己线程的专属副本。
      • 线程ID是关键,主线程会有主线程的线程ID,子线程会有子线程的线程ID,根据ID找副本
    • 依赖部署内存
      • ThreadLocal并不直接依赖部署内存,因为它主要是在运行时为每个线程分配独立的变量副本。然而,ThreadLocal的实现需要消耗一定的内存资源,因为它需要为每个线程维护一个Map结构来存储变量副本。因此,在使用ThreadLocal时,需要关注它对系统内存的影响
    • 使用注意
      • 需要注意的是,ThreadLocal不会自动回收不再使用的线程变量副本。如果线程长时间运行且频繁使用ThreadLocal,可能导致内存泄漏。因此,在使用ThreadLocal时,要确保在线程结束时手动调用remove()方法,以释放内存资源。
      • 弱引用原因
      • k-v; k都有模块名称,来区分上游链路调用,通过模块名称+线程id,确保底层的ThreadLocalMap在不同工作区间工作
    • 操作
      • set
      • get
      • remove
    • 使用场景
      • 为每个线程分配一个独享的对象,如Connection
      • 保存全局变量,特别是在拦截器中获取用户信息的场景。这样可以让不同方法直接使用这些变量,避免参数传递的麻烦
      • 数据库连接池的应用
        • 好处
          • 1,在数据库连接池中使用ThreadLocal的主要原因是为了保证每个线程都有其独立的数据库连接,这样可以避免多个线程之间的连接干扰,提高系统的稳定性和性能。
          • 2,ThreadLocal可以为每个线程提供一个独立的数据库连接,确保多个线程操作数据库时不会出现资源竞争的问题。此外,当每个线程都拥有自己的数据库连接时,避免了频繁地从连接池中获取和归还连接的开销,因此可以提高性能
          • 3,ThreadLocal还可以确保在一个线程内,可能需要进行的多个数据库操作使用的是同一个连接,从而保证事务的一致性
            • 类似用户是一个主线程在应用配置的分布式事务中,主线程拥有线程id,这个线程id有两个数据库的connection链接副本,所以能保证事务的一致性
            • 多个用户,多个线程ID
        • 不使用ThreadLocal的影响
          • 每次需要数据库连接时,都必须从连接池中获取,而在操作完成后归还。这样的频繁操作会增加额外的开销
          • 如果多个线程共享同一个数据库连接,可能会出现数据混乱、连接状态被意外修改等问题。同时,要确保一个线程内的多个数据库操作使用同一个连接进行事务管理会变得复杂
        • 总结
          • 数据库连接池使用ThreadLocal的主要原因是为了保证每个线程都有一个独立的数据库连接,从而提高系统的稳定性和性能。ThreadLocal为每个线程提供了独立的资源副本,避免了资源竞争的问题,并且可以通过缓存连接来减少频繁获取和归还连接的开销。此外,ThreadLocal还有助于简化事务管理,确保多个数据库操作在同一事务内进行。如果不使用ThreadLocal,可能会导致资源竞争、数据混乱和事务一致性问题。

相关文章:

Java线程池基本概念

全局和局部线程池 全局线程池 在Spring框架中,全局线程池如ThreadPoolTaskExecutor通常是作为Spring Bean存在的,它们的生命周期由Spring容器管理。当Spring容器关闭时,这些线程池也会被适当地清理和关闭。因此,开发者通常不需要手…...

智能车联网安全发展形势、挑战

一、技术演进加速车联网安全环境复杂变化 当前,5G、大数据、大算力、大模型等技术正加速在车联网领域实现融合应用。车联网的网络通信能力、感知计算水平以及创新业务应用都在快速发展,与此同时,车联网的网络安全环境也在随之演进变化&#…...

AWS概述

AWS概述EMR Serverless Aamzon Web Services提供了一系列全球范围的云产品,包括计算、存储、数据库、分析、网络、移动、开发工具、管理工具、IoT、安全和企业应用:按需交付、及时可用、采用随用随付的定价模式。你可以畅享200多种服务,从数据…...

MySQL常见面试题自测

文章目录 MySQL基础架构一、说说 MySQL 的架构?二、一条 SQL语句在MySQL中的执行过程 MySQL存储引擎一、MySQL 提供了哪些存储引擎?二、MySQL 存储引擎架构了解吗?三、MyISAM 和 InnoDB 的区别? MySQL 事务一、何谓事务&#xff1…...

c语言回顾-函数递归

1.递归的介绍 1.1什么是递归 递归是指在一个函数的定义中调用自身的过程。简单来说,递归是一种通过重复调用自身来解决问题的方法。 递归包括两个关键要素:基本情况和递归情况。基本情况是指当问题达到某个特定条件时,不再需要递归调用&am…...

消息队列-RabbitMQ-延时队列实现

死信队列 DLX,全称为Dead-Letter-Exchange,死信交换机,死信邮箱。当消息在一个队列中变成死信之后,它能重新发送到另外一个交换器中,这个交换器就是DLX,绑定DLX的队列就称为死信队列。 导致死信的几种原因: ● 消息…...

【热门开源项目推荐】满足不同程序员的需求与关注点

目录 前言一、热门开源项目介绍二、使用开源热门项目的优势(一)经济方面(二)技术方面(三)社区支持及协作方面 三、程序员选择项目模型建议(一)关键步骤(二)示…...

一文理清GO语言日志库实现开发项目中的日志功能(rotatelogs/zap分析)

一文理清GO语言日志库实现开发项目中的日志功能(rotatelogs/zap分析) rotatelogs rotatelogs 是一个用于管理日志文件的 Go 语言库,它提供了自动轮换、压缩和删除旧日志文件的功能。这个库可以帮助你更好地管理和维护你的应用程序日志。要使…...

【Go语言精进之路】构建高效Go程序:了解string实现原理并高效使用

🔥 个人主页:空白诗 🔥 热门专栏:【Go语言精进之路】 文章目录 引言一、Go语言的字符串类型1.1 字符串的定义1.2 字符串的零值可用1.3 字符串的不可变性1.4 字符串的拼接1.5 字符串的常用方法1.6 实际使用示例 二、字符串的内部表…...

HDFS 常见命令

在HDFS创建文件夹:hdfs dfs -mkdir /test 复制本地文件到HDFS中某个目录下:hdfs dfs -put /本地路径 /hdfs 路径 查看文件内容:hdfs dfs -cat /test.txt 查看当前文件夹目录:hdfs dfs -ls / 查看文件夹中的文件数:…...

示例:WPF中应用Grid的SharedSizeGroup设置整齐的布局

一、目的&#xff1a;应用Grid的SharedSizeGroup设置整齐的布局 二、实现 <ItemsControl ItemsSource"{local:GetStudents Count5}"><ItemsControl.ItemTemplate><DataTemplate><Grid ShowGridLines"True"><Grid.ColumnDefinit…...

React的form表单自定义校验规则

使用antd开发的过程中&#xff0c;必定会遇到需要对form表单进行必填校验的处理&#xff0c;正常情况下&#xff0c;我们都会一个空的必填校验&#xff0c;如下&#xff1a;一般我们只需要简单配置rules即可 <FormItem label"管理员姓名" {...itemLayout.wholeLi…...

一种新的一维时间序列信号盲解卷积算法(以旋转机械故障诊断为例,MATLAB环境)

一种新的一维时间序列信号盲解卷积算法&#xff08;以旋转机械故障诊断为例&#xff0c;MATLAB环境&#xff09;&#xff0c;可作为深度学习信号前处理过程&#xff0c;水个SCI不是问题。 机械设备的状态信号中往往蕴含着大量的设备异常信息。如何从繁多的机械状态信号中提取足…...

618电商是社区网站入局的好时机吗?

近日&#xff0c;随着618大促的临近&#xff0c;许多内容平台像B站、小红书等纷纷被电商活动所充斥&#xff0c;让用户感觉仿佛被电商绑架一般。这种用户体验的极度不佳让人开始思考&#xff0c;难道这就是互联网社区的未来发展方向吗&#xff1f; 在所有平台性质的社区中&…...

不知道密码,一样能卸载瑞星esm防病毒终端安全防护系统

离开单位后试图卸载瑞星的时候却发现还需要密码&#xff0c;真是烦死了。研究了几分钟后找到了完美卸载方法。 首先&#xff0c;让我们请出老流氓360安全卫士&#xff0c;下载好它&#xff0c;让右键菜单出现使用 360强力删除这一选项。 之后&#xff0c;进入安全模式&#x…...

Chromium 开发指南2024 Mac篇-安装和配置depot_tools工具(三)

1.引言 在前两篇指南中&#xff0c;我们详细介绍了在 macOS 环境下编译 Chromium 所需的硬件要求和系统依赖&#xff0c;并具体讲解了如何正确安装和配置 Xcode。通过这些步骤&#xff0c;您已经为编译 Chromium 打下了坚实的基础。然而&#xff0c;编译 Chromium 还需要配置一…...

微信小程序-路由和页面跳转API

一.wx.navigateTo wx.navigateTo是通过编程实现页面跳转&#xff0c;和navigator组件组件中&#xff0c;open-type"navigate"属性类似&#xff0c;是保留当前页面跳转新的页面&#xff0c;不适用tabbar页面。 //保留当前页面&#xff0c;跳转到非tabbar页面wx.navig…...

PWR电源控制

一、PWR简介 1、PWR&#xff08;Power Control&#xff09;电源控制 &#xff08;1&#xff09;PWR负责管理STM32内部的电源供电部分&#xff0c;可以实现可编程电压监测器和低功耗模式的功能 &#xff08;2&#xff09;可编程电压监测器&#xff08;PVD&#xff09;可以监控…...

【记录46】【案例】echarts 柱状图

echarts环境4.1.0 <template><div id"threefour"></div> </template> <script> import * as echarts from "echarts" export default {name:"",components:{},data(){return {}},methods:{getdata(){var myChart…...

Github2024-06-12 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-06-12统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目4JavaScript项目2Lua项目1PHP项目1Blade项目1非开发语言项目1TypeScript项目1Shell项目1从零开始构建你喜爱的技术 创建周期:2156 天…...

茶艺师服务师傅小程序APP源码(APP+小程序+公众号+H5)

&#x1f375;茶艺师服务小程序&#xff1a;品味生活的茶艺新体验&#x1f331; &#x1f33f;一、引言&#xff1a;茶艺师服务小程序&#xff0c;让生活更有味 在繁忙的生活中&#xff0c;品一杯香茗&#xff0c;感受茶文化的韵味&#xff0c;是许多人向往的休闲方式。然而&…...

【正则表达式】入门

参考视频&#xff1a;10分钟快速掌握正则表达式_哔哩哔哩_bilibili 这个网站用来测试写的正则表达式效果&#xff1a;regex101: build, test, and debug regex 示例&#xff1a; 限定符 ? 表示前一个字符可有可无 比如这里输入&#xff1a;de? 匹配结果可以得到d和de * 前…...

制造业为什么需要ERP企业管理软件?

如今&#xff0c;传统的制造业管理方式逐渐变得力不从心~库存积压、生产效率低下、供应链混乱…想象一下&#xff0c;如果你的企业仍然依赖于手工记录订单、库存和财务数据&#xff0c;那么每当市场发生变动时&#xff0c;你就需要花费大量的时间和精力去重新调整生产计划、更新…...

JavaScript Prototype

JavaScript Prototype JavaScript 是一种高级的、解释执行的编程语言&#xff0c;广泛应用于网页和服务器端开发。JavaScript 的核心特性之一是其原型继承机制&#xff0c;这是理解 JavaScript 对象模型的关键。 什么是 Prototype&#xff1f; 在 JavaScript 中&#xff0c;…...

Web Works API 和 Promise 的对比和区别

Web Workers 和 Promise 都是强大的工具&#xff0c;用于不同的异步处理场景。Web Workers 适用于需要并行处理的复杂任务&#xff0c;通过后台线程避免阻塞主线程。而 Promise 则简化了单线程中的异步操作管理&#xff0c;使代码更加清晰和结构化。根据具体需求选择合适的技术…...

jeecg快速启动(附带本地运行可用版本下载)

版本整理&#xff08;windows x64位&#xff09;&#xff1a; redis&#xff1a;3.0.504 MYSQL&#xff1a;5.7 Maven&#xff1a;3.9.4(setting文件可下载) Nodejs&#xff1a;v16.20.2&#xff08;建议不要安装默认路径下&#xff0c;如已安装在c盘&#xff0c;运行yarn报…...

【PPT教程】一键重置幻灯片背景的方法,新建幻灯片带默认背景

目的是替换18届的研电赛ppt背景为19届 这里写目录标题 1.设计->设置背景格式2.图片或纹理填充->插入3.选择需要替换为背景的照片4.点击下方的应用到全部 1.设计->设置背景格式 2.图片或纹理填充->插入 3.选择需要替换为背景的照片 4.点击下方的应用到全部 此时全部…...

NVIDIA新模型Nemotron-4:98%的训练数据是合成生成的,你敢信?

获取本文论文原文PDF&#xff0c;请公众号 AI论文解读 留言&#xff1a;论文解读 标题&#xff1a;Nemotron-4 340B Technical Report 模型概述&#xff1a;Nemotron-4 340B系列模型的基本构成 Nemotron-4 340B系列模型包括三个主要版本&#xff1a;Nemotron-4-340B-Base、…...

深度神经网络——什么是NLP(自然语言处理)?

自然语言处理&#xff08;NLP&#xff09; 是对使计算机能够处理、分析、解释和推理人类语言的技术和工具的研究和应用。 NLP 是一个跨学科领域&#xff0c;它结合了语言学和计算机科学等领域已建立的技术。 这些技术与人工智能结合使用来创建聊天机器人和数字助理&#xff0c;…...

05-5.5.1 哈夫曼树

&#x1f44b; Hi, I’m Beast Cheng &#x1f440; I’m interested in photography, hiking, landscape… &#x1f331; I’m currently learning python, javascript, kotlin… &#x1f4eb; How to reach me --> 458290771qq.com 喜欢《数据结构》部分笔记的小伙伴可以…...

有了域名就可以做网站了吗/职业技能培训有哪些

1.spring运行期例外(unchecked Exception)事务可以回滚,用户例外(checked Exception,即try...catch...finally块)事务不回滚;2.若要checked Exception回滚,在需要回滚的方法前添加注解:Transactional(rollbackForException.class)3.要unchecked Exception不回滚,在需要回滚的方…...

网站未备案做seo会被k吗/个人网站推广

Syn攻击是最常见又最容易被利用的一种攻击手法&#xff0c;利用TCP协议的缺陷&#xff0c;发送大量伪造TCP连接请求&#xff0c;常用假冒的IP发来海量的SYN包&#xff0c;被攻击的服务器回应SYNACK&#xff0c;因为对方是假冒的IP&#xff0c;永远收不到包并且不会回应&#xf…...

做海报的网站/app推广方法

环境 MySQL 5.1 命令行工具 问题 MySQL修改字段允许为空 解决 alter table topic modify state int(4) null; 语法总结 alter table表名 modify 字段名字段类型(长度) null; 参考资料 http://bbs.csdn.net/topics/370119711...

织梦做网站简单吗/游戏推广员是做什么的

1. 回顾 上一章&#xff0c;我们介绍了项目的目标和架构&#xff1a; DaprNet6K8S最小原型项目架构和实现-01-架构篇_敦格-CSDN博客DaprNet6K8S最小原型项目架构和实现-01-架构篇https://blog.csdn.net/shuaihj/article/details/122963744?spm1001.2014.3001.5501 这一章&…...

网站建设投资大概每年需要多少钱/网络营销师资格证报名

在Python中&#xff0c;一个.py文件就称之为一个模块&#xff08;Module&#xff09;。 模块有什么好处&#xff1f; 大大提高了代码的可维护性。便于代码引用&#xff0c;不必从零开始。当一个模块编写完毕&#xff0c;就可以被其他地方引用。我们在编写程序的时候&#xff…...

河源市规划建设局网站/杭州关键词排名系统

网络部计算机知识讲座活动策划书盐城工学院计算机与网络协会计算机知识讲座划书枣院学院计算机与网络协会2010年10月一、企划书名称&#xff1a;盐城工学院计算机与网络协会计算机知识讲座二、企 划 者&#xff1a;盐城工学院计算机与网络协会三、活动 目的&#xff1a; 大一新…...