发布时间:2022-11-15 文章分类:编程知识 投稿人:王小丽 字号: 默认 | | 超大 打印

开心一刻

  公交车上,一位老大爷睡着了,身体依靠在背后的一位年轻小伙子身上

  小伙子一直保持站姿十几分钟,直到老人下车

  这位在校大学生,接受采访时说:”当时就觉得背后这个人很轻盈,以为是个姑娘!“

当 xxl-job 遇上 docker → 它晕了,我也乱了!

前提准备

  对 xxl-job、docker 要有基本的了解

  xxl-job

  直接看官网:xxl-ob,你想要的和不想要的,官网都有详细说明

  楼主也做了简单尝试:分布式任务调度平台 → XXL-JOB 初探、分布式任务调度平台 → XXL-JOB 实战

  示例版本:2.1.0

  docker

  网上资料很多,b站视频也挺多的(推荐:尚硅谷2022版Docker实战教程(docker教程天花板))

  楼主就不做介绍了(主要是楼主不知道呀!)

当 xxl-job 遇上 docker → 它晕了,我也乱了!

admin 和 executor 都单独部署

  部署很简单,我就不具体演示了(不是主角,没戏份!)

  直接看效果

  192.168.8.222 上部署xxl-job-admin

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  192.168.8.223 上部署xxl-job-executor

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  是不是很简单?

  效果也和我们预想的一样

admin 单独部署,executor通过 docker 部署

  192.168.8.223 安装docker,安装过程我就不演示了,直接看效果

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  docker版本20.10.21

  大家注意,伴随着docker的运行,多了一个网卡配置信息

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  有兴趣的可以查阅下:docker网络的bridge模式;这里先混个眼熟,注意IP172.17.0.1

  executor 和 docker 并存

  此时我们重启下xxl-job-executor,然后在xxl-job-admin重新注册下执行器

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  自动注册上来的机器IP是172.17.0.1,而非192.168.8.223,那么伴随而来的问题就是:xxl-job-admin访问不通xxl-job-executor

  我们改成手动注册,看看能否访问通

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  可以看到,手动注册不受docker的影响,能正常访问通

  而自动注册则受了docker的影响,注册的IP不对,至于如何解决,请继续往下看

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  executor 通过 docker 部署

  如何打将xxl-job-executor打成docker镜像,不是本文的内容,所以省略不演示(言外之意是需要大家自行去学习!)

  我们直接run执行器镜像

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  自动注册上来的IP172.17.0.2,很明显,问题(xxl-job-admin访问不通xxl-job-executor)再次出现

  那改成手动注册试试

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  哟嚯,xxl-job-admin还是访问不通xxl-job-executor

  放弃抵抗吧,别挣扎了

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  少年莫急,我们的xxl-job-executor是通过docker部署的,你有把docker容器的9999端口映射到宿主机吗

  (由于换了地方,IP也跟着变了192.168.8.222-> 10.5.13.222192.168.8.223 ->10.5.13.223

  重启下sample-executor:1.0

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  我就问你,是不是通了?

admin 和 executor 都通过 docker 部署

  executor通过docker部署,前面已经讲过了

  admin通过docker部署,请看我表演

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  自动注册还要试吗?

当 xxl-job 遇上 docker → 它晕了,我也乱了!

自动注册IP问题

  前面说了那么多,最终回归到一个问题:自动注册的IP为什么不是Docker宿主机的IP

  不管是xxl-job-admin还是xxl-job-executor,都是直接用的官方的代码,楼主可一行都没改

  那肯定是xxl-job自动注册没有做好docker的兼容呗

  这可不是我瞎说,githubxxl-job有很多相关的issue(191、630、1121、1658、1668)

  许大大在源码中也给出了解决方案,xxl-job-executor-sample-springboot有个类:XxlJobConfig.java,其中有如下说明

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  那试试呗,我们对xxl-job-executor-sample-springboot进行改造

  引入依赖

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  修改XxlJobConfig.java

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  添加配置

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  executor 和 docker 并存

  docker运行,但executor不通过docker部署

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  自动注册的ip竟然是:127.0.0.1,莫非要通过docker部署?

  executor 通过 docker 部署

  镜像我已经打包好:sample-executor:1.1,我们来看下效果

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  自动注册的ip是172.17.0.2,不是宿主机ip:10.5.13.223,莫非docker镜像打的有问题?

  我们进容器内看看日志

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  我们再看看容器内的网卡配置信息

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  请问这如何获取宿主机IP(10.5.13.223)?

  许大欺我?

当 xxl-job 遇上 docker → 它晕了,我也乱了!

总结

  1、就目前来看,一旦xxl-job-executor遇上Docker,自动注册就不对了

    知道如何处理的小伙伴,欢迎评论区留言

  2、自动注册不行了,那就用手动注册呗

当 xxl-job 遇上 docker → 它晕了,我也乱了!

  3、大家自己验证的时候,一定要注意docker与宿主机的端口映射