Почему проверка работоспособности консула возвращает пустой массив?
У нас есть файл docker-compose.yml:
version: '3'
services:
consul:
container_name: consul
command: agent -dev -config-dir=/consul/config
dns: 8.8.8.8
hostname: consul-docker
image: docker-registry.mycompany.net/ap/consul-ent:0.9.2
ports:
- "8500:8500"
volumes:
- ./consul/config/conf.json:/consul/config/conf.json
# https://github.com/gliderlabs/registrator
registrator:
command: consul://consul:8500
container_name: registrator
depends_on:
- consul
image: gliderlabs/registrator:latest
restart: always
volumes:
- /var/run/docker.sock:/tmp/docker.sock
myservice1:
container_name: myservice1
image: docker-registry.mycompany.net/ap/myservice1/develop:latest
ports:
- "8080:8080"
- "5000:5000"
# more services below
Когда я проверяю состояние работоспособности с помощью API contrib v1 по http://localhost:8500/v1/health/checks/myservice1, он возвращает пустой массив [].
Согласно docker ps и журналам myservice1, myservice1 готов.
myservice1 показывает зеленый на http://localhost:8500/ui/
myservice1 - это Java-микросервис на основе dropwizard.
Согласно https://www.consul.io/api/health.html пример ответа на
$ curl https://consul.rocks/v1/health/service/my-service
похоже:
[
{
"Node": {
"ID": "40e4a748-2192-161a-0510-9bf59fe950b5",
"Node": "foobar",
"Address": "10.1.10.12",
"Datacenter": "dc1",
"TaggedAddresses": {
"lan": "10.1.10.12",
"wan": "10.1.10.12"
},
"Meta": {
"instance_type": "t2.medium"
}
},
"Service": {
"ID": "redis",
"Service": "redis",
"Tags": ["primary"],
"Address": "10.1.10.12",
"Port": 8000
},
"Checks": [
{
"Node": "foobar",
"CheckID": "service:redis",
"Name": "Service 'redis' check",
"Status": "passing",
"Notes": "",
"Output": "",
"ServiceID": "redis",
"ServiceName": "redis",
"ServiceTags": ["primary"]
},
{
"Node": "foobar",
"CheckID": "serfHealth",
"Name": "Serf Health Status",
"Status": "passing",
"Notes": "",
"Output": "",
"ServiceID": "",
"ServiceName": "",
"ServiceTags": []
}
]
}
]
Согласно журналам регистратора, он видит myservice1 нормально и добавляет myservice1.
Любые идеи о том, почему я вижу [] ответ будет принята с благодарностью?
1 ответ
Я смог получить базовые проверки работоспособности после выполнения инструкций на https://gliderlabs.com/registrator/latest/user/backends/. У меня сложилось впечатление, что проверки работоспособности будут работать автоматически после настройки регистратора и консула. Мне нужно было настроить проверку HTTP, предоставив переменные окружения в docker-compose.yml, например:
SERVICE_80_CHECK_HTTP=/health/endpoint/path
SERVICE_80_CHECK_INTERVAL=15s
SERVICE_80_CHECK_TIMEOUT=1s # optional, Consul default used otherwise