Почему проверка работоспособности консула возвращает пустой массив?

У нас есть файл 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
Другие вопросы по тегам