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

前情回顾
在当 xxl-job 遇上 docker → 它晕了,我也乱了!,有两个场景没给大家演示,先补上
executor 和 admin 在同一台宿主机上通过 docker 部署

这里有必要给大家简单讲一下 Docker 的 bridge 网络模式

docker0 类似一个交换机,它有很多接口,每个接口叫 veth ,在宿主机和容器内分别创建一个虚拟接口,并让他们彼此联通(这样一对接口叫 veth pair )
每个容器实例内部也有一块网卡,其接口叫 eth0 ; docker0 上面的每个 veth 匹配某个容器内部的 eth0 ,两两配对,一一匹配
如此,将同个宿主机上的所有容器都连接到同个内部网络上,那么这些容器之间的网络是互通的
所以这种情况下, xxl-job-admin 是可以掉通 xxl-admin-executor 的,因为它们在同一个内部网络上
executor 和 admin 都通过 docker 部署,但不在同一个宿主机
上一篇提到了,但没告诉大家结果,也不知道大家有没有去验证,这里再给大家演示下

从结果来看, xxl-job-admin 是访问不通 xxl-job-executor 的,想知道为什么吗?

两台宿主机的 docker0 分别构成了一个内部网络,但这两个内部网络是隔离的、不通的!
这就好比我的局域网的 192.168.1.115 访问你的局域网的 192.168.1.118 ,你说能访问得通吗?
自动注册
关于自动注册的问题,很多小伙伴在上一篇的评论区给出一些解决方案,我来给大家试试水
docker compose
xxl-job-admin 镜像不需要改动,以 docker-compose 进行编排部署即可, docker-compose.yml 内容如下

xxl-job-executor 需要修改下配置

用 服务名 替换具体的ip
改完之后重新生成 xxl-job-executor 的镜像 sample-executor-compose:1.2
然后以 docker-compose 进行编排部署, docker-compose.yml 内容如下

我们来看下效果

额,自动注册好了!你们是不是爱上我了?

etcd + flannel
配置过程就不演示了,可参考:docker使用 Flannel(etcd+flannel)网络、etcd安装和所遇到的坑

当IP情况类似如上所示,则说明配置成功了
我们再来看看 xxl-job 的自动注册

xxl-job-executor 自动注册的IP 10.10.96.2 , xxl-job-admin 可以正常调度 xxl-job-executor
k8s
k8s 集群搭建过程不是那么简单,但也不是很复杂;搭建好的集群信息如下

在 k8s 集群部署 xxl-job-admin 、 xxl-job-executor 成功后,我们来看下 xxl-job 的自动注册

如你所见,自动注册是可以正常调度的!
我们再来看下 xxl-job-admin 、 xxl-job-executor 所在节点

sample-xxl-job-admin-56bb76f846-7rnmw 在节点 docker221
sample-xxl-job-executor-78c4997dd4-562hw 在节点 docker220
不在同一个节点哦!
总结
1、三种方式(docker compose、etcd+flannel、k8s)选哪一种,需要结合具体情况来定
如果想实现简单点,那就选 docker compose
如果已经使用了 k8s ,那就用 k8s 方式就行了
实现方式肯定还有其他的,比如 etcd + flannel 只是属于打通内部网络的一种
2、环境的搭建,楼主都省略了,有两点目的
2.1 考虑到篇幅问题,如果把搭建环境的详细过程都加进来,整篇篇幅就太长了,担心你们看的累
2.2 希望大家都去尝试搭建一下,受过伤才会刻骨铭心,楼主是深有感触

你们不要觉得我坏,我就是坏!!!

当 xxl-job 遇上 docker → 它晕了,但我不能乱!的更多相关文章
- .NET遇上Docker - 使用Docker Compose组织Ngnix和.NETCore运行
本文工具准备: Docker for Windows Visual Studio 2015 与 Visual Studio Tools for Docker 或 Visual Studio 2017 ...
- .NET遇上Docker - Harbor的安装与基本使用
Harbor是一个开源企业级Docker注册中心,可以用于搭建私有的Docker Image仓库.可以实现权限控制等. 安装Harbor 首先,需要安装Docker和Docker Compose,参考 ...
- .NET遇上Docker - Docker集成Cron定时运行.NETCore(ConsoleApp)程序.md
配置项目的Docker支持 对于VS中Docker的配置,依旧重复一些废话. 给项目添加Docker支持,VS2015可以直接使用Docker for VS插件,VS2017在安装时选择容器支持.VS ...
- 当DOCKER遇上ESXI
特别是你要为DOCKER窗口设置静态IP,且和公司局域网打成一片的时候, 苦逼的测试就会开始,我差不多前前后后测试了四五天,一百多个容器报废. NETNS,NSENTER,PIPWORK,各种镜像合下 ...
- LoadRunner - 当DiscuzNT遇上了Loadrunner(中) (转发)
当DiscuzNT遇上了Loadrunner(中) 在上文中,介绍了如果录制脚本和设置脚本执行次数.如果经过调试脚本能够正常工作的话,就可以设置并发用户数并进行压力测试了. 首先我们通过脚本编辑界面上 ...
- 前端遇上Go: 静态资源增量更新的新实践
前端遇上Go: 静态资源增量更新的新实践https://mp.weixin.qq.com/s/hCqQW1F8FngPPGZAisAWUg 前端遇上Go: 静态资源增量更新的新实践 原创: 洋河 美团 ...
- 微服务中台落地 中台误区 当中台遇上DDD,我们该如何设计微服务
小结: 1. 微服务中台不是 /1堆砌技术组件就是中台 /2拥有服务治理就是中台 /3增加部分业务功能就是中台 /4Cloud Native 就是中台 https://mp.weixin.qq.com ...
- MVC遇上bootstrap后的ajax表单模型验证
MVC遇上bootstrap后的ajax表单验证 使用bootstrap后他由他自带的样式has-error,想要使用它就会比较麻烦,往常使用jqueyr.validate的话只有使用他自己的样式了, ...
- 敏捷遇上UML-需求分析及软件设计最佳实践(郑州站 2014-6-7)
邀请函: 尊敬的阁下:我们将在郑州为您奉献高端知识大餐,当敏捷遇上UML,会发生怎样的化学作用呢?首席专家张老师将会为您分享需求分析及软件设计方面的最佳实践,帮助您掌握敏捷.UML及两者相结合的实 ...
- 敏捷遇上UML—软创基地马年大会(广州站 2014-4-19)
我们将在广州为您奉献高端知识大餐,当敏捷遇上UML,会发生怎样的化学作用呢?首席专家张老师将会为您分享需求分析及软件设计方面的最佳实践,帮助您掌握敏捷.UML及两者相结合的实战技巧. 时间:2 ...
随机推荐
- Docker部署ELK
这里不采用逐个docker镜像的方式,而是直接使用elk三者聚合在一起的镜像. 镜像地址:https://hub.docker.com/r/sebp/elk 前提操作: $ vim /etc/sysc ...
- Netty 学习(六):创建 NioEventLoopGroup 的核心源码说明
Netty 学习(六):创建 NioEventLoopGroup 的核心源码说明 作者: Grey 原文地址: 博客园:Netty 学习(六):创建 NioEventLoopGroup 的核心源码说明 ...
- Python实验报告(第四周
一.实验目的和要求 学会应用列表.元组.字典等序列: 二.实验环境 软件版本:Python 3.10 64_bit 三.实验过程 1.实例1:输出每日一贴 (1)在IDLE中创建一个名称为tips.p ...
- POJ2686 Traveling by Stagecoach (状压DP)
将车票的使用情况用二进制表示状态,对其进行转移即可. 但是我一开始写的代码是错误的(注释部分),看似思路是正确的,但是暗藏很大的问题. 枚举S,我们要求解的是dp[S][v],这个是从u转移过来的,不 ...
- POJ3280 Cheapest Palindrome (区间DP)
dp[i][j]表示将字符串子区间[i,j]转化为回文字符串的最小成本. 1 #include<cstdio> 2 #include<algorithm> 3 #include ...
- Linux文本相关命令
Linux文本相关命令 目录 Linux文本相关命令 文本排序命令 文本去重命令 基础命令cut 文本三剑客 sed awk grep 文本排序命令 sort 常用参数: -n:以数值大小进行排序 - ...
- 自主创建mybtis管理应用,用以横向管理数据源
这个是我写的第一个随手小记,一晃眼做后端开发也有7年多了,现在也准备将一些杂七杂八的资料整理下.也算是回顾这7年中做的比较有意思的东西了. 这个需求是我17年做的,当时的应用场景是仓储库比较多,随时会 ...
- NodeJS 服务 Docker 镜像极致优化指北
这段时间在开发一个腾讯文档全品类通用的 HTML 动态服务,为了方便各品类接入的生成与部署,也顺应上云的趋势,考虑使用 Docker 的方式来固定服务内容,统一进行制品版本的管理.本篇文章就将我在服务 ...
- 2022-08-05-欢迎使用_Typecho
layout: post cid: 1 title: 欢迎使用 Typecho slug: start date: 2022/08/05 14:21:51 updated: 2022/08/05 14 ...
- 测试开发HTTP请求过程(一)
测试开发HTTP请求过程 HTTP请求过程: 首先要熟悉http请求过程: 1,服务端建立socket监听 2,客户端发送http请求 3,客户端与服务端建立socket连接 4,客户端------t ...