docker部署服务无法自动注册xxl-job问题排查和解决

最近部署了一个服务,使用docker部署(network:host模式),2个节点的服务自动注册xxl-job,但是测试环境没有问题,生产环境一直注册失败,虽然可以在项目配置中使用**"** 类似这样的配置**"**:job.executor.address=ip:port 将地址写死,但是目前不支持写多个地址,那么任务执行只有一个节点,有单点故障且效率不高问题。

问题排查:

生产环境自动注册时,注册上的地址是:172.10.x.x, 这是服务器网桥的网卡。当docker容器使用bridge模式时会使用容器的ip。于是查看生产服务器的网络模式如下:

复制代码
docker network ls

发现目标服务默认使用的是网桥模式,查看当前容器的网桥模式进行确认:

复制代码
docker inspect itda-business|grep host

发现目前使用的是主机模式, 于是重启docker服务:

复制代码
service docker restart

但是结果自动注册的还是: 172.10.x.x,对比查看测试环境服务的网络模式:

复制代码
docker network ls

虽然有几个无关的前端服务默认是网桥模式,但是网桥模式中并没有看到目标服务。不确定是什么原因导致生产服务器主机模式无法生效。思考目前的现状是:docker部署都是基于主机模式,于是将生产服务器的网桥进行删除,解决了该问题。删除网桥的脚本如下:

bash 复制代码
#!/bin/bash
#本脚本删除的是br-开头的网桥
BRIDGE_LIST=$(sudo brctl show | cut -f 1 | grep br-)
echo "即将删除的网桥是:"$BRIDGE_LIST
for i in $BRIDGE_LIST
do
    sudo ifconfig $i down
    sudo brctl delbr $i
done
echo "删除之后用主机网桥状态如下:"
echo sudo brctl show

需要注意的是,如果有其他服务没有配置network,默认是网桥模式,还需要再重新生成docker, 否则网桥模式的服务不可用。即使服务器又配置了网桥,之前的目标服务仍然是主机模式哈。

复制代码
docker stop xxx-business && docker rm xxx-business && docker-compose up -d

参考文章:

https://blog.51cto.com/u_16213382/7451505

https://www.cnblogs.com/chenxiaoy/p/10016801.html

相关推荐
java_logo5 小时前
Docker 部署 WordPress 全流程
运维·docker·容器·word·php·1024程序员节
武子康7 小时前
Java-159 MongoDB 副本集容器化 10 分钟速查卡|keyfile + –auth + 幂等 init 附 docker-compose
java·数据库·mongodb·docker·性能优化·nosql·1024程序员节
wodongx1238 小时前
从一开始部署Android项目Sonarqube的自动化扫码+通知+增量扫描功能(Win环境、Docker,基于Jenkins)
运维·docker·jenkins·1024程序员节
java_logo9 小时前
Docker 部署 Elasticsearch 全流程手册
大数据·运维·mongodb·elasticsearch·docker·容器
Stay Passion10 小时前
Docker 组件:Docker Swarm
运维·docker·容器
路過的好心人10 小时前
Docker + Rabbitmq 集群部署
docker·容器·rabbitmq
青0721松12 小时前
千云低代码平台ETMS-k8s实施部署
低代码·云原生·容器
源来猿往13 小时前
基于window/ubuntu安装rknn-toolkit2【docker】
docker·1024程序员节·rknn-toolkit2
小小的木头人13 小时前
基于Docker 搭建 Prometheus & Grafana 环境
运维·docker·容器·grafana·prometheus
KevinPedri16 小时前
测试:uk8s创建监控和告警同步飞书等渠道
docker·kubernetes·云计算·1024程序员节