Abstract: This is an improper delay problem found in specific code, which in extreme cases can blow up memory.
This article is shared by Huawei Cloud community “Improper use of delay in threads”, originally written by: technology torchbearers.
background
This is a problem with improper latency found in specific code, which in extreme cases can blow up memory.
Code DevLicenseServiceRoaDelegateImpl. Java
Definition:
Use:
SignalRefreshHelp definition
The biggest problem with this code is the improper use of the latency algorithm, which in extreme cases can cause memory inflation and severely affect the performance of the server program.
Do not use sleep to implement delays
Using Sleep to implement latency may seem intuitive, but this must be done with extreme care in a highly concurrent, multi-request, long-running service.
This is because a very important measure of service application performance is QPS, which is the processing power of the service application. Generally, the larger the better;
The total concurrency capacity of the server is equal to QPS per thread; QPS for a single thread = 1000 ms/(milliseconds for processing a request);
So the QPS of the thread above <= 1000/10000 = 0.1 (because the thread slept 10000 milliseconds)
The processing logic here is wrong! There are also serious performance concerns, but fortunately there aren’t many calls to the API that cause serious problems.
The developer’s intention is to delay the execution of a task by 10 seconds after it is created, processing the sequence diagram below
If the time points T1 and T2 are close together, the threads executing job1 and job2 are also close together.
But the reality is this:
Even if the creation times of job1 and joB2 are close, joB2 takes 10 seconds longer than expected. The more consecutively submitted tasks, the easier it is to pile up. These stacked tasks are stored in the blocking queue and deleted until the processing is completed. If there are too many of these requests, memory can easily explode.
The solution
Choose the appropriate data structure. The default queue associated with the thread pool is LinkedBlockingQueue, with no delay control, and DelayQueue can be used
Internal DelayQueue uses PriorityQueue to sort by time; You need to encapsulate the request data yourself using the Delayed interface
Here’s an example
Test the code by adding three tasks that need to be delayed for 10 seconds
Test results:
In line with expectations
Click to follow, the first time to learn about Huawei cloud fresh technology ~