mirror of https://github.com/longtai-cn/hippo4j
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.
81 lines
5.0 KiB
81 lines
5.0 KiB
# Dynamic and observable thread pool framework
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/dfcb4/dfcb4f17aca8c227cfb3e832dd694ea4caa818ef" alt="License"](http://www.apache.org/licenses/LICENSE-2.0)
|
|
[data:image/s3,"s3://crabby-images/13d87/13d8790912a2753a0abb9a35e1fdcfacb5f750e2" alt="Build Status"](https://github.com/opengoofy.hippo4j)
|
|
|
|
data:image/s3,"s3://crabby-images/a13ee/a13ee73dc529c52bba050d76071cdf248a6c3387" alt=""
|
|
data:image/s3,"s3://crabby-images/f40e1/f40e12adae1000724480364507c6e0a1cab17899" alt=""
|
|
data:image/s3,"s3://crabby-images/f0ad4/f0ad4d40693467b8f1f7109c325a67c6f68b1aac" alt=""
|
|
[data:image/s3,"s3://crabby-images/91f56/91f568c4c1fa0bb6d902089172452c650bad6526" alt="Docker Pulls"](https://store.docker.com/community/images/hippo4j/hippo4j-server)
|
|
[data:image/s3,"s3://crabby-images/8a8ad/8a8adbe320a87a3f03979ec57672fa87ba5887b4" alt="codecov"](https://codecov.io/gh/opengoofy/hippo4j)
|
|
[data:image/s3,"s3://crabby-images/bbe08/bbe08b18178ce282eb7930e3349ae1bc3707edbf" alt="EN doc"](https://github.com/opengoofy/hippo4j/blob/develop/README-EN.md)
|
|
|
|
| **Stargazers Over Time** | **Contributors Over Time** |
|
|
|:---------------------------------------------------------------------------------------------------------------------:|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------:|
|
|
| [data:image/s3,"s3://crabby-images/fcbcf/fcbcf6b99c97ca542244f32d8105ad6ab11bf578" alt="Stargazers over time"](https://api.star-history.com/svg?repos=opengoofy/hippo4j&type=Date) | [data:image/s3,"s3://crabby-images/f3d74/f3d74e4dbace1c3cf02b565a8444b1c12559ba54" alt="Contributor over time"](https://www.apiseven.com/en/contributor-graph?chart=contributorOverTime&repo=opengoofy/hippo4j) |
|
|
|
|
### Thread pool pain points
|
|
|
|
---
|
|
|
|
A thread pool is a tool for managing threads based on the idea of pooling.
|
|
|
|
Using a thread pool reduces the overhead of creating and destroying threads and avoids running out of system resources due to too many threads.
|
|
|
|
The use of thread pools is essential in highly concurrent and high-volume task processing scenarios.
|
|
|
|
If you have actually used thread pools in your projects, I believe you may have encountered the following pain points:
|
|
|
|
- Thread pools are defined randomly, with too many thread resources, causing high server load.
|
|
|
|
- The thread pool parameters are not easily evaluated and the business is at risk of failure.
|
|
- Thread pool task execution time exceeds the average execution cycle and developers are not informed.
|
|
- Thread pool tasks pile up and affect business operations.
|
|
- Wireless process pool monitoring when the service has timeouts, meltdowns, and other problems.
|
|
- Thread pools do not support the passing of runtime variables, such as MDC contexts.
|
|
- When a project is closed, a large number of running thread pool tasks are discarded.
|
|
- Thread pool running, task execution stopped, don't know the problem.
|
|
|
|
### What is Hippo4j
|
|
|
|
---
|
|
|
|
Hippo4j through the JDK thread pool enhancements, as well as extending the three-party framework underlying thread pools and other features for business systems to improve online operational security capabilities.
|
|
|
|
The following functional support is provided:
|
|
|
|
- Global Control - Managing Application Thread Pool Instances.
|
|
|
|
- Dynamic changes - dynamically changing thread pool parameters at application runtime.
|
|
- Notify alarms - Four built-in alarm notification policies.
|
|
- Run Monitoring - Real-time view of thread pool runtime data.
|
|
- Feature extensions - support for thread pooling task passing contexts, etc.
|
|
- Multiple Modes - Two built-in usage modes: Configuration Center Mode and No Middleware Mode.
|
|
- Container Management - Tomcat, Jetty, Undertow container thread pool runtime view and thread count changes.
|
|
- Framework adaptation - Dubbo, Hystrix, Polaris, RabbitMQ, RocketMQ and other consumer thread pool runtime data view and thread count changes.
|
|
|
|
### Quick Start
|
|
|
|
---
|
|
|
|
For local presentation purposes, see [Quick start](https://hippo4j.cn/docs/user_docs/user_guide/quick-start).
|
|
|
|
Demo Environment: [http://console.hippo4j.cn/index.html](http://console.hippo4j.cn/index.html).
|
|
|
|
### Who is using
|
|
|
|
---
|
|
|
|
More companies with access are welcome to register at [registration address](https://github.com/opengoofy/hippo4j/issues/13), registration is only for product promotion.
|
|
|
|
### Contributors
|
|
|
|
---
|
|
|
|
Thanks to all the developers who contributed to the project. If interested in contributing, refer to [good first issue](https://github.com/opengoofy/hippo4j/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22).
|
|
|
|
<a href="https://github.com/opengoofy/hippo4j/graphs/contributors">
|
|
<img src="https://contrib.rocks/image?repo=opengoofy/hippo4j" />
|
|
</a>
|