生活工程体验信仰哲学精神
快软网
精神世界
探索历史
哲学文学
艺术价值
信仰创造
境界审美
体验技术
技能工具
工程信息
医学生产
生活运用
操作能力

美团动态线程池实践思路,开源了

12月28日 顾昀汐投稿
  背景
  使用线程池ThreadPoolExecutor过程中你是否有以下痛点呢?
  1。代码中创建了一个ThreadPoolExecutor,但是不知道那几个核心参数设置多少比较合适
  2。凭经验设置参数值,上线后发现需要调整,改代码重启服务,非常麻烦
  3。线程池相对开发人员来说是个黑盒,运行情况不能及时感知到,直到出现问题
  如果你有以上痛点,动态可监控线程池(DynamicTp)或许能帮助到你。
  如果看过ThreadPoolExecutor的源码,大概可以知道它对核心参数基本都有提供setget方法以及一些扩展方法,可以在运行时动态修改、获取相应的值。
  现在大多数的互联网项目其实都会微服务化部署,有一套自己的服务治理体系,微服务组件中的分布式配置中心扮演的就是动态修改配置,实时生效的角色。那么我们是否可以结合配置中心来做运行时线程池参数的动态调整呢?答案是肯定的,而且配置中心相对都是高可用的,使用它也不用过于担心配置推送出现问题这类事儿,而且也能减少研发动态线程池组件的难度和工作量。
  综上,可以总结出以下的背景
  广泛性:在Java开发中,想要提高系统性能,线程池已经是一个90以上的人都会选择使用的基础工具
  不确定性:项目中可能会创建很多线程池,既有IO密集型的,也有CPU密集型的,但线程池的参数并不好确定;需要有套机制在运行过程中动态去调整参数
  无感知性,线程池运行过程中的各项指标一般感知不到;需要有套监控报警机制在事前、事中就能让开发人员感知到线程池的运行状况,及时处理
  高可用性,配置变更需要及时推送到客户端;需要有高可用的配置管理推送服务,配置中心是现在大多数互联网系统都会使用的组件,与之结合可以大幅度减少开发量及接入难度
  简介
  基于以上背景分析,我们对线程池ThreadPoolExecutor做一些扩展增强,主要实现以下目标
  1。实现对运行中线程池参数的动态修改,实时生效
  2。实时监控线程池的运行状态,触发设置的报警策略时报警,报警信息推送办公平台
  3。定时采集线程池指标数据,配合像grafana这种可视化监控平台做大盘监控
  经过多个版本的迭代,目前最新版本v1。0。9具有以下特性
  代码零侵入:所有配置都放在配置中心,对业务代码零侵入
  轻量简单:基于SpringBoot实现,引入starter,接入只需简单4步就可完成,顺利3分钟搞定
  高可扩展:框架核心功能都提供SPI接口供用户自定义个性化实现(配置中心、配置文件解析、通知告警、监控数据采集、任务包装等等)
  线上大规模应用:参考美团线程池实践,美团内部已经有该理论成熟的应用经验
  多平台通知报警:提供多种报警维度(配置变更通知、活性报警、容量阈值报警、拒绝触发报警、任务执行或等待超时报警),已支持企业微信、钉钉、飞书、邮件报警,同时提供SPI接口可自定义扩展实现
  监控:定时采集线程池指标数据,支持通过MicroMeter、JsonLog日志输出、Endpoint三种方式,可通过SPI接口自定义扩展实现
  任务增强:提供任务包装功能,实现TaskWrapper接口即可,如MdcTaskWrapper、TtlTaskWrapper、SwTraceTaskWrapper,可以支持线程池上下文信息传递
  兼容性:JUC普通线程池和Spring中的ThreadPoolTaskExecutor也可以被框架监控,Bean定义时加DynamicTp注解即可
  可靠性:框架提供的线程池实现Spring生命周期方法,可以在Spring容器关闭前尽可能多的处理队列中的任务
  多模式:参考Tomcat线程池提供了IO密集型场景使用的EagerDtpExecutor线程池
  支持多配置中心:基于主流配置中心实现线程池参数动态调整,实时生效,已支持Nacos、Apollo、Zookeeper、Consul、Etcd,同时也提供SPI接口可自定义扩展实现
  中间件线程池管理:集成管理常用第三方组件的线程池,已集成Tomcat、Jetty、Undertow、Dubbo、RocketMq、Hystrix、Grpc等组件的线程池管理(调参、监控报警)
  架构设计
  框架功能大体可以分为以下几个模块
  1。配置变更监听模块2。服务内部线程池管理模块3。三方组件线程池管理模块4。监控模块5。通知告警模块
  代码结构
  1。adapter模块:主要是适配一些第三方组件的线程池管理,目前已经实现的有SpringBoot内置的三大web容器(Tomcat、Jetty、Undertow)、Dubbo、RocketMq、Hystrix、Grpc的线程池管理,后续会接入其他常用组件的线程池管理。2。common模块:主要是一些各个模板都会用到的类,解耦依赖,复用代码,大家日常开发中可能也经常会这样做。3。core模块:该框架的核心代码都在这个模块里,包括动态调整参数,监控报警,以及串联整个项目流程都在此。4。example模块:提供一个简单使用示例,方便使用者参照5。extension模块:放一些扩展功能实现,比如基于redis的流控扩展、邮件发送扩展、skywalking上下文传递扩展等6。logging模块:用于配置框架内部日志的输出,目前主要用于输出线程池监控指标数据到指定文件7。starter模块:提供独立功能模块的依赖封装、自动配置等相关。
  配置变更监听模块
  1。监听特定配置中心的指定配置文件(已实现Nacos、Apollo、Zookeeper、Consul、Etcd),可通过内部提供的SPI接口扩展其他实现
  2。解析配置文件内容,内置实现yml、properties、json配置文件的解析,可通过内部提供的SPI接口扩展其他实现
  3。通知线程池管理模块实现参数的刷新
  服务内部线程池管理模块
  1。服务启动时从配置中心拉取配置,生成线程池实例注册到内部线程池注册中心以及Spring容器中
  2。接受配置监听模块的刷新事件,实现线程池参数的刷新
  3。代码中通过依赖注入(推荐)或者DtpRegistry。getDtpExecutor()方法根据线程池名称来获取线程池实例
  三方组件线程池管理
  1。服务启动获取第三方中间件的线程池,被框架管理起来
  2。接受参数刷新、指标收集、通知报警事件,进行相应的处理
  监控模块
  实现监控指标采集以及输出,默认提供以下三种方式,也可通过内部提供的SPI接口扩展其他实现
  1。默认实现JsonLog输出到磁盘,可以自己采集解析日志,存储展示
  2。MicroMeter采集,引入MicroMeter相关依赖,暴露相关端点,采集指标数据,结合Grafana做监控大盘
  3。暴雷自定义Endpoint端点(dynamictp),可通过http方式实时访问
  通知告警模块
  对接办公平台,实现通知告警功能,已支持钉钉、企微、飞书、邮件,可通过内部提供的SPI接口扩展其他实现,通知告警类型如下
  1。线程池主要参数变更通知
  2。阻塞队列容量达到设置的告警阈值
  3。线程池活性达到设置的告警阈值
  4。触发拒绝策略告警,格式:AB,A:该报警项前后两次报警区间累加数量,B:该报警项累计总数
  5。任务执行超时告警,格式:AB,A:该报警项前后两次报警区间累加数量,B:该报警项累计总数
  6。任务等待超时告警,格式:AB,A:该报警项前后两次报警区间累加数量,B:该报警项累计总数
  项目地址
  gitee地址:https:gitee。comdromaradynamictpgithub地址:https:github。comdromaradynamictp
投诉 评论 转载

有风度,难以征服的星座,不解释、不迎合、不羡慕,活出独立人生 《菜根谭》有言:“藏巧于拙,用晦而明,寓清于浊,以屈为伸,真涉世之一壶,藏身之三窟也。”一个谦虚不张扬的人,低调且从容,在观照内心的同时,总会寻找一些办法来提升精神……机电一体化技术专业主要学什么?机电一个月能挣多少钱热评聚热点 机械电子工程专业俗称机电一体化,是机械工程与自动化的一种。机械电子工程专业包括基础理论知识和机械设计制造方法,计算机软硬件应用能力,能承担各类机电产品和系统的设计、制造、……性能续航的新高峰,小米13:满血版骁龙8G2MIUI14,对 现在高通全新一代旗舰平台骁龙8Gen2也是重磅发布了,在当时高通骁龙峰会上,有不少厂商是官宣了将在下一代旗舰手机上会首批搭载使用,如频繁冲击高端的小米,现在据悉小米13系列堆料……【歌词】TheEternalMystery歌手:DreamD HomToYeah制作DreamTheaterTheDarkEternalNightNoonedaredtoSpeakoftheterribledanger……深睡眠,多长时间算睡眠质量好?热传聚热点网 人在夜间睡眠,正常情况下是8小时睡眠时间,可以分为4个睡眠周期,每2个小时左右为1个周期。刚开始睡眠的34个小时的睡眠,是最好的睡眠,也叫黄金时期。深睡眠可以达到睡眠周期……法院送判决书被告不收怎么办热闻聚热点网 问:法院送判决书被告不收怎么办律师解答:法院送判决书被告不收,送达人可以邀请有关基层组织或者所在单位的代表到场,说明情况,将判决书留在被告住所,并且记录送达过程,可……同样是光瓶酒,李渡为何这么“秀”,卖的比茅台还贵,这是为什么 提起光瓶酒,大家可以想到什么?光瓶酒一直都代表着平价酒,口粮酒。但是直到这款酒的出现,刷新了大家对于光瓶酒的认知,虽然它的外包装看起来平平无奇,但是它的售价却是高达上千元……美团动态线程池实践思路,开源了热议聚热点网 背景使用线程池ThreadPoolExecutor过程中你是否有以下痛点呢?1。代码中创建了一个ThreadPoolExecutor,但是不知道那几个核心参数设置多……【歌词】学着爱自己歌手:张明洋热闻聚热点网 熄戏作词:李晗梓然作曲:李晗寇长城编曲:FRIT录音混音:李晗演唱:李晗歌词编辑:狸子1299734652我深深呼吸却还是会心痛……跨境电商寒冬将至?AUKEY傲基天猫旗舰店终止经营热传聚热点 2022年11月末,AUKEY傲基天猫旗舰店首页正式贴出店铺终止经营公告,拟于2022年12月24日自主终止经营。天猫aukey旗舰店首页公告AUKEY是谁?……【歌词】PREYRemix歌手:IveGirls热议聚热点网 prey演唱:小熊饼干FinallyfounditjustapreyIjustagreei’mnotgreatButtoneverregainIs……有天赋,情商高的星座,做事靠谱,拥有让人放心的能力热博聚热点 作家池莉说过:“靠谱,说起来简单,落下去复杂。”做人做事靠谱的人通常也就拥有让人放心的能力,这种能力,其实说到底就是会让人觉得跟他在一起,或者说交代他的事情总会能够……
融资买入股票卖了后自动还融资吗热文聚热点网 早餐手抓饼,家里有面粉就能做,1次做上30张,5分钟就搞定热 【歌词】LongWalkHome歌手:Teenagersin 军训的日记热博聚热点网 这两个OG:中文说唱比赛从没赢过帅哥说唱鼻祖热议聚热点网 商业秘密的法律保护?热评聚热点网 张丹峰直播带货翻车,称西宁是广西省会,被网友吐槽没文化热博聚 夜宵你最喜欢吃什么食物?热评聚热点网 高质量内容并不等同于文章原创【易云智能yyzn。com】热评 招聘效率的提高秘诀AI智能招聘热评聚热点网 中国代表团专家:中国为和平合作发展而来热传聚热点网 一张尘封数十年的照片,一片引擎盖收割83条命,奔驰为此退赛3
消化不良脾胃不好,常按这几个穴位,或可快速调好微信怎么查老公给我一年的记录(微信查看某个人的转账记录)年立陶宛为何被德国割走了海岸线学会这4种治疗耳聋,耳鸣的良方!80岁不受耳。。。紫色矮牵牛的花语含义是什么名和利,救不了刘涛第三十章训练小区底商扰民物业管吗价格美丽,硬件出众!vivoXFold2和XFlip正式开售 朱元璋为什么没把皇位传给自己的儿子,而是给了孙子朱允炆?酷跑平板电脑哪款好人生三大喜事,遇老乡榜上有名娶娇妻

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找新乡渭南铜川松江山南雅安松原荃湾淮北昭通平凉鞍山赤峰苗栗保亭池州渝北株洲陇南濮阳三沙秀山密云鸡西