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

xxl,job,遇上,docker · 浏览次数 : 4910

小编点评

## 2.1.0 docker 部署小程序的步骤及其问题解答 **步骤一:准备** * 使用 `docker` 命令安装 Docker 容器。 * 下载并安装 `docker-compose.yml` 文件。 * 将 `sample-executor:1.0` 的镜像文件保存到本地。 **步骤二:使用 Docker Compose 部署小程序** 1. 创建 `docker-compose.yml` 文件,内容如下: ```yaml version: "3.8" services: executor: image: your_docker_image restart: unless-stopped ports: - 9999:9999 admin: image: your_docker_image restart: unless-stopped ports: - 80:80 ``` 2. 运行 `docker-compose up -d` 命令,启动容器。 **问题解答** 1. **自动注册问题:** * 使用 `docker-compose exec -it executor bash` 命令进入 `executor` 容器,运行 `hostname` 命令,检查其 IP 地址是否和 `admin`容器相同。 * 如果 `executor` 容器的 IP 地址不是 `admin` 容器的 IP,则说明自动注册失败。 2. **手动注册问题:** * 使用 `docker-compose exec -it admin bash` 命令进入 `admin` 容器,修改 `XxlJobConfig.java` 文件,设置 IP 地址和端口。 * 使用 `docker-compose exec -it admin bash` 命令进入 `admin` 容器,运行 `hostname` 命令,检查其 IP 地址是否和 `executor` 容器相同。 3. **Docker镜像与宿主机的端口映射问题:** * 使用 `docker-compose exec -it admin bash` 命令进入 `admin` 容器,检查 `docker` 容器的端口映射信息。 * 使用 `docker-compose exec -it executor bash` 命令进入 `executor` 容器,检查 `docker` 容器的端口映射信息。 **总结** * 使用 `docker-compose` 可以轻松地部署和管理多个容器。 * 自动注册可能因容器之间网络设置或其他因素而失败。 * 手动注册需要修改配置文件并进入容器设置 IP 地址和端口。 * 确保端口映射信息正确,才能正常通信。

正文

开心一刻

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

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

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

前提准备

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

  xxl-job

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

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

  示例版本: 2.1.0 

  docker

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

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

admin 和 executor 都单独部署

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

  直接看效果

  192.168.8.222 上部署 xxl-job-admin 

  192.168.8.223 上部署 xxl-job-executor 

  是不是很简单?

  效果也和我们预想的一样

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

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

   docker 版本 20.10.21 

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

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

  executor 和 docker 并存

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

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

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

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

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

  executor 通过 docker 部署

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

  我们直接 run 执行器镜像

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

  那改成手动注册试试

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

  放弃抵抗吧,别挣扎了

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

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

  重启下 sample-executor:1.0 

  我就问你,是不是通了?

admin 和 executor 都通过 docker 部署

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

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

  可以看到,手动注册是没有问题滴

  自动注册还要试吗?

自动注册IP问题

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

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

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

  这可不是我瞎说, github 上 xxl-job 有很多相关的 issue (191630112116581668

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

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

  引入依赖

  修改 XxlJobConfig.java 

  添加配置

  executor 和 docker 并存

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

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

  executor 通过 docker 部署

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

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

  我们进容器内看看日志

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

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

  许大欺我?

总结

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

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

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

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

与当 xxl-job 遇上 docker → 它晕了,我也乱了!相似的内容:

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

开心一刻 公交车上,一位老大爷睡着了,身体依靠在背后的一位年轻小伙子身上 小伙子一直保持站姿十几分钟,直到老人下车 这位在校大学生,接受采访时说:”当时就觉得背后这个人很轻盈,以为是个姑娘!“ 前提准备 对 xxl-job、docker 要有基本的了解 xxl-job 直接看官网:xxl-ob,你想

当 xxl-job 遇上 docker → 它晕了,但我不能乱!

开心一刻 某次住酒店,晚上十点多叫了个外卖 过了一阵儿,外卖到了 因为酒店电梯要刷卡,所以我下楼去接 到了电梯口看到个模样不错的妹纸 我:是你么? 妹纸愣了下:嗯! 于是拉上进电梯回房间,正准备开始呢 我俩的电话同时响了 按下接听键,一男一女同时问:我到电梯口了,你人呢? 尴尬了,取错外卖了 然后一

前端说你的API接口太慢了,怎么办?

当有千万条海量数据时,前端调取接口发现接口响应的太慢,前端这时让你优化一下接口,你说有几千万条数据,觉得自己尽力了,前端觉得你好菜,别急,读完这篇文章,让前端喊你一声:大佬,厉害!!! 常用的方法总结 通过合理的分页加载、索引优化、数据缓存、异步处理、压缩数据等手段,可以有效地优化接口性能,提升系统

.NET App 与Windows系统媒体控制(SMTC)交互

当你使用Edge等浏览器或系统软件播放媒体时,Windows控制中心就会出现相应的媒体信息以及控制播放的功能,如图。 SMTC (SystemMediaTransportControls) 是一个Windows App SDK (旧为UWP) 中提供的一个API,用于与系统媒体交互。接入SMTC的好

如何安全地访问互联网

当你深夜在浏览器中输入 www.baidu.com 时有没有想过,除了月黑风高的夜和本机的浏览记录,还有谁知道你访问了它呢?要搞清楚这件事,首先我们要了解一下访问网站时,这其中发生了什么。 如果你在 10 年之前访问网站,大概率会在浏览器的地址栏中看到这样的网址 http://www.baidu.c

当面试官问出“Unsafe”类时,我就知道这场面试废了,祖坟都能给你问出来!

一、写在开头 依稀记得多年以前的一场面试中,面试官从Java并发编程问到了锁,从锁问到了原子性,从原子性问到了Atomic类库(对着JUC包进行了刨根问底),从Atomic问到了CAS算法,紧接着又有追问到了底层的Unsafe类,当问到Unsafe类时,我就知道这场面试废了,这似乎把祖坟都能给问冒烟

JS 实现鼠标框选(页面选择)时返回对应的代码或文本内容

当用户进行鼠标框选选择了页面上的内容时,把选择的内容进行上报。 分为以下几点: 选择文案时 选择图片、svg、iframe、video、audio 等标签时 选择 input、select、textarea 等标签时 选择input、textarea 标签内容时 选择类似   字符时 键盘全选时 鼠...

当装饰者模式遇上Read Through缓存,一场技术的浪漫邂逅

在《经验之谈:我为什么选择了这样一个激进的缓存大Key治理方案》一文中,我提到在系统中使用的缓存是旁路缓存模式,有读者朋友问,有没有用到过其他的缓存模式,本文将结合一个我曾经工作中的案例,使用装饰者模式实现Read Through缓存模式,助你轻松掌握设计模式和缓存。

LOTO示波器软件PC缓存(波形录制与回放)功能

当打开PC缓存功能后, 软件将采用先进先出的原则排队对示波器采集的每一帧数据, 进行帧缓存。 当发现屏幕中有感兴趣的波形掠过时, 鼠标点击软件的(暂停)按钮, 可以选择回看某一帧的波形。一帧数据的量 是 当前用户选择时基档位缓冲区总数据大小。不同时基档位缓冲区大小不同,因此具体一帧能存储多长时间根据

Java面试题:如果你这样做,你会后悔的,两次启动同一个线程~~~

当一个线程被启动后,如果再次调start()方法,将会抛出IllegalThreadStateException异常。 这是因为Java线程的生命周期只有一次。调用start()方法会导致系统在新线程中运行执行体,但是如果线程已经结束,则不能再次使用,需要重新创建一个新的线程对象并调用start()...