Медленный ответ на запрос Elasticsearch через консоль kibana
Фон сервера: 3-узловой кластер elasticsearch + kibana + logstash, работающий в среде docker. хост-сервер работает под управлением rhel7.7(2 процессора, 8 ГБ ОЗУ + 200 ГБ общего доступа).
Версии:
- elasticsearch 7.5.1
- кибана 7.5.1
- logstash 7.5.1
- filebeat 7.5.1 (работает на отдельном сервере)
## Cluster health status
{
"cluster_name" : "es-cluster",
"status" : "green",
"timed_out" : false,
"number_of_nodes" : 3,
"number_of_data_nodes" : 3,
"active_primary_shards" : 116,
"active_shards" : 232,
"relocating_shards" : 0,
"initializing_shards" : 0,
"unassigned_shards" : 0,
"delayed_unassigned_shards" : 0,
"number_of_pending_tasks" : 0,
"number_of_in_flight_fetch" : 0,
"task_max_waiting_in_queue_millis" : 0,
"active_shards_percent_as_number" : 100.0
}
## Node status
172.20.1.3 60 91 13 0.98 1.30 1.45 dilm - elasticsearch2
172.20.1.4 57 91 13 0.98 1.30 1.45 dilm - elasticsearch3
172.20.1.2 61 91 14 0.98 1.30 1.45 dilm * elasticsearch
## Host server TOP output
top - 11:37:10 up 11 days, 22:30, 3 users, load average: 0.74, 1.29, 1.47
Tasks: 210 total, 1 running, 209 sleeping, 0 stopped, 0 zombie
%Cpu(s): 4.4 us, 0.8 sy, 0.0 ni, 94.8 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 7999840 total, 712736 free, 5842300 used, 1444804 buff/cache
KiB Swap: 3071996 total, 2794496 free, 277500 used. 1669472 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
48491 vtha837 20 0 4003724 713564 23880 S 5.0 8.9 1:57.53 java
59023 vtha837 20 0 6796456 1.5g 172556 S 2.7 20.3 28:18.07 java
59006 vtha837 20 0 6827100 1.5g 176840 S 1.7 19.9 30:03.59 java
760 vtha837 20 0 6877220 1.5g 180752 S 0.7 19.9 24:37.88 java
59610 vtha837 20 0 1663436 258152 7336 S 0.3 3.2 16:51.84 node
## Kibana environment variables I used for kibana docker image
environment:
SERVER_NAME: "kibana"
SERVER_PORT: 9548
ELASTICSEARCH_PASSWORD: ${ES_PASSWORD}
ELASTICSEARCH_HOSTS: "http://elasticsearch:9550"
KIBANA_DEFAULTAPPID: "dashboard/Default"
LOGGING_QUIET: "true"
XPACK_SECURITY_ENCRYPTIONKEY: ${KIBANA_XPACK_SEC_KEY}
XPACK_SECURITY_SESSIONTIMEOUT: 600000
Проблема: A. Когда я запускаю запросы elasticsearch через консоль kibana, на консоль возвращалось не менее 20000 мсек. Но если я запускаю тот же запрос напрямую (elasticsearch) через curl, postman или chrome, для получения вывода B требуется менее 200 мсек. Даже это происходит, когда я загружаю приборную панель kibana (не все время), получаю следующее сообщение об ошибке и не загружая некоторые графики. но я не вижу никаких исключений или ошибок в журналах консоли
Error in visualization
[esaggs] > Request to Elasticsearch failed: {"error":{}}
Если я обновлю страницу, я увижу все графики.
Профиль производительности Chrome напрямую обращается к URL-адресу запроса elasticsearch:http://testnode.mycompany.com.nz:9550/_cat/indices
Профиль производительности Chrome через консоль разработчика kibana elasticsearch query Query:GET /_cat/indices
Чего я не понимаю, так это то, что если я запускаю один и тот же файл docker compose на своем ноутбуке (windoes 10, 16GB, i7 2cpu, рабочий стол докера), я не сталкиваюсь с какой-либо медленностью ни в консольном запросе kibana, ни в прямом запросе elasticseach.
Любой, у кого есть эта проблема и признателен, дайте мне знать, как это исправить?
Заранее спасибо.
1 ответ
Проблема заключается в обнаружении службы докеров. По какой-то причине обнаружение службы докеров не произошло. как только я меняю хост elasticsearch на IP, получаю реальную производительность.
В docker-compose Предыдущая конфигурация кибаны
ELASTICSEARCH_HOSTS: "http://elasticsearch:9550"
Новая конфигурация
ELASTICSEARCH_HOSTS: "http://172.20.1.2:9550"
более подробную информацию см. на странице обсуждения elasticsearch