0
Я загружаю весеннее загрузочное приложение с встроенным причалом/tomcat, и у меня появилось странное поведение. Я использую apache ab для тестированияТест нагрузки на весну: некоторые запросы застряли
ab -n 100000 -c 1000 http://127.0.0.1:8080/ping
Server Software:
Server Hostname: 127.0.0.1
Server Port: 8080
Document Path: /ping
Document Length: 2 bytes
Concurrency Level: 1000
Time taken for tests: 5.253 seconds
Complete requests: 100000
Failed requests: 0
Total transferred: 17000000 bytes
HTML transferred: 200000 bytes
Requests per second: 19038.05 [#/sec] (mean)
Time per request: 52.526 [ms] (mean)
Time per request: 0.053 [ms] (mean, across all concurrent requests)
Transfer rate: 3160.61 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 37 222.1 0 3006
Processing: 0 7 21.9 3 855
Waiting: 0 7 21.7 3 853
Total: 0 44 228.0 4 3052
Percentage of the requests served within a certain time (ms)
50% 4
66% 7
75% 9
80% 11
90% 22
95% 39
98% 1004
99% 1017
100% 3052 (longest request)
Так что какой-то запрос застрял где-то.
С причалу я пробовал разные значения:
_maxThreads, _minThread
с котом:
max-connections, max-threads, min-spare-threads
В профайлер я нашел следующее:
org.eclipse.jetty.util.thread.QueuedThreadPool$2.run() 16,215ms
org.eclipse.jetty.util.thread.QueuedThreadPool.access$800
org.eclipse.jetty.util.thread.QueuedThreadPool.iddleJobPoll
org.eclipse.jetty.util.BlockingArrayQueue.poll 13,915ms
Спасибо!
Я не уверен, что я действительно понимаю, что заставляет вас думать, что какой-то запрос застрял где-то? – jchampemont
привет. почему 98% составляет 1 с? 98% заявок - это нормально. но 2% получили много времени. Что-то странное. с параметрами -k (keepAlive) лучше –