1. Consul常用命令

安裝部署Consul

  • 下載解壓,加入PATH。
    • 啓用單節點:consul agent -dev ./consul agent -server -ui -bootstrap-expect=1 -data-dir=/tmp/consul -advertise=127.0.0.1 -bind=0.0.0.0 -client=0.0.0.0 > /dev/null 2>&1 &
    • 查看consul成員:consul members (-detailed)

服務命令

  • 註冊服務:定義服務配置文件,啓動時指定–config-dir=目錄。目錄一般建立於/etc/consul.d
    echo ‘{“service”: {“name”: “web”, “tags”: [“rails”], “port”: 80}}’ > ./consul.d/web.json
  • 查詢服務:curl http://localhost:8500/v1/catalog/service/web
  • 查詢健康實例:curl 'http://localhost:8500/v1/health/service/web?passing

通過HTTP API來實現如下,參考地址:https://www.consul.io/api/agent/service.html

  • 獲取單個服務信息: curl http://127.0.0.1:8500/v1/agent/service/serviceIdxxxx

  • 獲取服務列表:curl http://10.173.2.130:38500/v1/agent/services

  • 獲取健康的服務(可根據名稱或ID):
    curl localhost:8500/v1/agent/health/service/name/servicenamexxx
    或curl localhost:8500/v1/agent/health/service/id/serviceidxxx
    或curl xxxx?format=text,及指定返回格式
    (默認情況下ID與serviceName相同,建議使用ID,因爲名稱不是唯一的),對於不存在的service會返回
    {
    “AggregatedStatus”: “critical”,
    “Service”: null,
    “Checks”: null
    }


/v1/agent/health/service/id/:service_id

  • 註冊服務:
    請求方式只支持PUT,請求參數過多時,建議放在文件裏面。
    curl --request PUT --data @emptySeatRateApp.json http://127.0.0.1:8500/v1/agent/service/register

  • 取消註冊:
    curl --request PUT http://127.0.0.1:8500/v1/agent/service/deregister/serviceId 或name

  • 啓用UI: consul agent -dev -client 0.0.0.0 -ui -config-dir=.
    注意:-client 0.0.0.0 表示所有客戶端都可以訪問

  • 獲取所有節點:
    http://127.0.0.1:8500/v1/agent/members?segment=_all

Consul其他命令

  • consul重載: consul reload,將會應用上次啓動的命令參數。

consul服務代理:
{
“service”: {
“name”: “webtest”,
“port”: 8080,
“connect”: { //爲webtest服務建立代理
“sidecar_service”: {
“proxy”: {
“upstreams”: [{ //代理服務器上游服務器
“destination_name”: “socat”,
“local_bind_port”: 9191 //代理服務器監聽端口,同時也是目標服務器與上游器間通信的端口?
}]
}
}
}
}
}

  • consul集羣:
    docker exec -d consul01 consul agent -ui -client 0.0.0.0 -server -bootstrap-expect=1 -data-dir=/tmp/consul -node=agent-one -enable-script-checks=true -bind=172.17.0.2
    docker exec -d consul02 consul agent -ui -client 0.0.0.0 -data-dir=/tmp/consul -node=agent-two -enable-script-checks=true -bind=172.17.0.3
    docker exec -d consul01 consul join 172.17.0.3

consul agent -server -bootstrap-expect=1
-data-dir=/tmp/consul -node=agent-one -bind=10.134.53.94
-enable-script-checks=true -config-dir=/usr/soft/consul.d

docker run --name consul01 -p 8500:8500 -d -i -t yckjdnmy/consul:v1 /bin/bash
docker run --name consul02 -p 8501:8500 -d -i -t yckjdnmy/consul:v1 /bin/bash

docker exec -d consul01 curl --request PUT http://127.0.0.1:8500/v1/agent/service/deregister/aifunc-aggregate-api-server-2-0-1-18-8080
docker exec -d consul01 curl --request PUT http://127.0.0.1:8500/v1/agent/service/deregister/aifunc-helmetdetect-api-server-2-0-1-27-8082
docker exec -d consul01 curl --request PUT http://127.0.0.1:8500/v1/agent/service/deregister/aifunc-helmetdetect-api-server-2-0-1-27-8082
docker exec -d consul01 curl --request PUT http://127.0.0.1:8500/v1/agent/service/deregister/yc-emptablerate-spring-cloud-client-ipAddress-9090

docker exec -d consul01 curl --request PUT http://127.0.0.1:8500/v1/agent/service/deregister/aifunc-aggregate-api-server-192-168-198-1-8080

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章