批量剔除consul无效服务
一、剔除consul无效服务
正常情况下,若是没有设置服务的健康检查剔除时间,则 consul不会主动的去清除掉失效的服务,所以就需要手动的来清理, 但是往往一个consul上又有多个失效的服务,一个一个剔除效率又太低,那么就需要通过脚本等形式进行批量剔除。
1.脚本
1.1单节点删除
vi clean_consul.sh
加入以下内容:
#!/bin/bash
# tiki 2021-06-22
#consul的地址
CONSUL_ADDRESS="192.168.2.4:8500"
#判断是否存在logs目录,不存在则创建
test -d logs || mkdir logs
echo -e "\n---------start "$(date "+%Y-%m-%d %H:%M:%S")"----------"
echo -e "\n---------start "$(date "+%Y-%m-%d %H:%M:%S")"----------" >> logs/clean-consul-`date +%Y%m%d`.log
# 获取当前consul中状态为critical的serviceID
CONSUL_CRITICAL=`curl -s -XGET http://${
CONSUL_ADDRESS}/v1/health/state/critical | python -m json.tool | grep ServiceID | awk '{print $2}' |sed 's/"//g' | sed 's/,//g'`
for critical in ${CONSUL_CRITICAL}
do
echo "${critical} 已删除"
echo "${critical} 已删除" >> logs/clean-consul-`date +%Y%m%d`.log
# 使用consul的API删除对应的serviceID
curl -XPUT http://${CONSUL_ADDRESS}/v1/agent/service/deregister/${critical}
done
echo -e "---------finish "$(date "+%Y-%m-%d %H:%M:%S")"----------\n"
echo -e "---------finish "$(date "+%Y-%m-%d %H:%M:%S")"----------\n" >> logs/clean-consul-`date +%Y%m%d`.log
但上述脚本只能删除注册在该consul节点上的无效服务,就算该节点是consul集群中的一个有效节点,也无法删除其他节点上的无效服务,
所以consul如果是个集群的话,则应该用下方脚本
1.2集群删除
1.2.1集群删除脚本1
将所有consul节点的地址都编入:
#!/bin/bash
# tiki 2021-06-22
#consul的地址
CONSUL_ADDRESS="192.168.2.4:8500 192.168.3.3:8500 192.168.3.2:8500 192.168.3.1:8500 192.168.3.6:8500"
#判断是否存在logs目录,不存在则创建
test -d logs || mkdir logs
echo -e "\n---------start "$(date "+%Y-%m-%d %H:%M:%S")"----------"
echo -e "\n---------start "