Hippo-4J 通过对 JDK 线程池增强,以及扩展三方框架底层线程池等功能,为业务系统提高线上运行保障能力
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Go to file
chen.ma b988b1a4e7
修复阻塞队列默认容量大小.
3 years ago
hippo4j-auth 修改过滤权限路径名称. 3 years ago
hippo4j-common 客户端线程池实时参数查看, 返回最后刷新时间. 3 years ago
hippo4j-config 修复阻塞队列默认容量大小. 3 years ago
hippo4j-console 前端项目迭代更新. 3 years ago
hippo4j-discovery 清理不健康节点时打印日志. 3 years ago
hippo4j-example 动态线程池添加测试用例. 3 years ago
hippo4j-server Convert yaml format to properties. 3 years ago
hippo4j-spring-boot-starter 客户端线程池实时参数查看, 返回最后刷新时间. 3 years ago
hippo4j-tools 操作日志记录时指定默认租户. 3 years ago
.gitignore first commit 4 years ago
LICENSE Change license. 3 years ago
README.md Update README.md 3 years ago
pom.xml 添加日志组件. 3 years ago

README.md

🔥   动态线程池Hippo4J系统包含 Server 端及 SpringBoot Client 端需引入的 Starter.

LICENSE


为什么写这个项目?

美团线程池文章 介绍中,因为业务对线程池参数没有合理配置,触发过几起生产事故,进而引发了一系列思考。最终决定封装线程池动态参数调整,扩展线程池监控以及消息报警等功能

在开源平台找了挺多动态线程池项目,从功能性以及健壮性而言,个人感觉不满足企业级应用

因为对动态线程池比较感兴趣,加上想写一个有意义的项目,所以决定自己来造一个轻量级的轮子

想给项目起一个简单易记的名字,类似于 Eureka、Nacos、Redis后和朋友商量决定以动物命名Hippo4J


它解决了什么问题?

线程池在业务系统应该都有使用到,帮助业务流程提升效率以及管理线程,多数场景应用于大量的异步任务处理

虽然线程池提供了我们许多便利,但也并非尽善尽美,比如下面这些问题就无法很好解决


如果线程池的配置涉及到上述问题,那么就有可能需要发布业务系统来解决;如果发布后参数仍不合理,继续发布......

Hippo4J 很好解决了这个问题,它将业务中所有线程池统一管理,遇到上述问题不需要发布系统就可以替换线程池参数


它有什么特性?

应用系统中线程池并不容易管理。参考美团的设计Hippo4J 按照租户、项目、线程池的维度划分。再加上系统权限,让不同的开发、管理人员负责自己系统的线程池操作

举个例子,小编在一家公司的公共组件团队,团队中负责消息、短链接网关等项目。公共组件是租户,消息或短链接就是项目


模块 模块名称 注释
hippo4j-auth 用户权限 用户、角色、权限等功能
hippo4j-common 公共模块 -
hippo4j-config 配置中心 提供线程池准实时更新功能
hippo4j-console 控制台 对接前端项目
hippo4j-discovery 注册中心 提供线程池项目实例注册、续约、下线等功能
hippo4j-spring-boot-starter Starter 客户端依赖组件
hippo4j-example 示例项目 -
hippo4j-server 服务端 Server 集成各组件
hippo4j-tools 抽象工具类 GitHub 变更监控、操作日志等组件

Hippo4J 除去动态修改线程池,还包含实时查看线程池运行时指标、负载报警、配置日志管理等


如何运行 Demo

目前动态线程池功能已经完成,可以直接把代码拉到本地运行。导入 Hippo4J 初始化 SQL 语句

  1. 启动 hippo4j-server 模块下 ServerApplication 应用类
  2. 启动 hippo4j-example 模块下 ExampleApplication 应用类

🌟   Hippo4J 已集成前端项目,详情参考 Run Console


通过接口修改线程池中的配置。HTTP POST 路径:http://localhost:6691/v1/cs/configs Body 请求体如下:

{
    "ignore": "tenantId、itemId、tpId 代表唯一线程池,请不要修改",
    "tenantId": "prescription",
    "itemId": "dynamic-threadpool-example",
    "tpId": "message-produce",
    "coreSize": 10,
    "maxSize": 15,
    "queueType": 9,
    "capacity": 100,
    "keepAliveTime": 10,
    "rejectedType": 3,
    "isAlarm": 0,
    "capacityAlarm": 81,
    "livenessAlarm": 82
}

接口调用成功后,观察 dynamic-threadpool-example 控制台日志输出,日志输出包括不限于此信息即为成功

[🔥 MESSAGE-PRODUCE] Changed thread pool. coreSize :: [11=>10], maxSize :: [15=>15], queueType :: [9=>9]
capacity :: [100=>100], keepAliveTime :: [10000=>10000], rejectedType :: [7=>7]

现阶段已集成钉钉消息推送后续会持续接入企业微信、邮箱、飞书、短信等通知渠道。可以通过添加钉钉群体验消息推送群号31764717


配置变更


报警通知


项目代码功能还在持续开发,初定发布 1.0.0 RELEASE 完成以下功能。部署了 Server 服务,只需要引入 Starter 组件到业务系统中,即可完成动态修改、监控、报警等特性


查看源码能收获什么?

目前还没有发布 Release 版本,小伙伴可以阅读框架源码,查看框架中好的设计理念或者编码技巧

在项目开发过程中,借鉴了 Nacos、Eureka、Seata、ShardingSphere 等中间件项目的优雅设计


Github Stars 趋势

如果小伙伴查看源码设计有所收获,辛苦点个 🚀 Star ,方便后续查看

Stargazers over time


致谢

Hippo4J 项目基于或参考以下项目:

  1. Nacosan easy-to-use dynamic service discovery, configuration and service management platform for building cloud native applications.

  2. EurekaAWS Service registry for resilient mid-tier load balancing and failover.

  3. ShardingSphereBuild criterion and ecosystem above multi-model databases

  4. mzt-biz-log支持Springboot基于注解的可使用变量、可以自定义函数的通用操作日志组件

  5. equator:一个用于比较两个对象的所有属性是否全部相等,并且可以获取所有不相等的属性的比对器


最后

小编是个有代码洁癖的程序员,项目中的代码开发完全遵守阿里巴巴代码规约,也推荐大家使用,培养好的编码习惯

对于这个项目,是否有什么不一样看法,欢迎在 Issue 一起沟通交流;或者添加小编微信进交流群