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

在当 xxl-job 遇上 docker → 它晕了,我也乱了!,有两个场景没给大家演示,先补上

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

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

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

两台宿主机的 docker0 分别构成了一个内部网络,但这两个内部网络是隔离的、不通的!
这就好比我的局域网的 192.168.1.115 访问你的局域网的 192.168.1.118 ,你说能访问得通吗?
关于自动注册的问题,很多小伙伴在上一篇的评论区给出一些解决方案,我来给大家试试水
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 内容如下

我们来看下效果

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

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

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

xxl-job-executor 自动注册的IP 10.10.96.2 , xxl-job-admin 可以正常调度 xxl-job-executor
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 希望大家都去尝试搭建一下,受过伤才会刻骨铭心,楼主是深有感触

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

1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
print"Enteryourpassword:"pass=STDIN.noecho(&:gets)puts"Yourpasswordis#{pass}!"输出:Enteryourpassword:input.rb:2:in`':undefinedmethod`noecho'for#>(NoMethodError) 最佳答案 一开始require'io/console'后来的Ruby1.9.3 关于ruby-为什么不能使用类IO的实例方法noecho?,我们在StackOverflow上
我正在尝试在我的远程服务器上运行以下命令(通过capistrano或ssh):bundleexecRAILS_ENV=productionscript/delayed_jobstart但我收到此错误消息:bundler:notexecutable:script/delayed_job以前从未见过这个,谷歌也没有适合我的东西。知道可能是什么问题吗? 最佳答案 也许它没有运行权限?尝试运行这个命令chmod+xscript/delayed_job然后再次执行文件。 关于ruby-on-rai
我对此有点困惑。我在RoR项目中的最终目标是从我的数据库中获取单个随机配置文件。我想它应该是这样的:@profile=Profile.find_by_user_id(rand(User.count))它一直抛出错误,因为user_id0不存在,所以我把它的一部分拿出来检查发生了什么:@r=rand(User.count)每次都返回0。发生什么了?我注册了5个假用户和5个相关配置文件来测试这个。如果我将Profile.find_by_user_id(rand(User.count))重写为Profile.find_by_user_id(3)它工作得很好。User.count也在工作。所以
这个问题困扰了我一段时间。这不是一件困难的事情,但我不知道为什么没有简单的方法来做到这一点,我敢打赌有但我没有看到。我只想取一个散列,像这样:cars={:bob=>'Pontiac',:fred=>'Chrysler',:lisa=>'Cadillac',:mary=>'Jaguar'}然后做类似的事情cars[:bob,:lisa]得到{:bob=>'Pontiac',:lisa=>'Cadillac'}我这样做了,效果很好:classHashdefpick(*keys)Hash[select{|k,v|keys.include?(k)}]endendruby-1.8.7-p249
在纯Rubyirb中,不能输入{if:1}。该语句不会终止,因为irb认为if不是符号,而是if语句的开始。那么为什么Rails可以有before_filter接受if作为参数?该指南的代码如下:classOrderunless也会发生同样的事情。 最佳答案 这是一个irb问题,而不是Ruby。bash=>ruby-e"puts({if:1})"bash=#{:if=>1}您可以改用pry。它将正确读取输入。https://github.com/pry/pry 关于ruby-on-rai
Enumerable#each和Enumerable#map的区别在于返回的是接收者还是映射后的结果。回到接收者是微不足道的,你通常不需要在each之后继续一个方法链,比如each{...}.another_method(我可能没见过这样的案例。即使你想回到接收者那里,你也可以通过tap来实现)。所以我认为所有或者大部分使用Enumerable#each的情况都可以用Enumerable#map代替。我错了吗?如果我是对的,each的目的是什么?map是否比each慢?编辑:我知道当您对返回值不感兴趣时使用each是一种常见的做法。我对这种做法是否存在不感兴趣,但感兴趣的是,除了从
我目前正在尝试将包含数字82,000的散列counts["email"]除以包含值130万的变量total。当我运行putscounts["email"]/total时,我得到0。为什么我不能对这些进行除法? 最佳答案 您正在执行除法,尽管不是您预期的那样。在Ruby中有许多不同的整数除法:#Integerdivision:5/4#=>1#Floatingpointdivision:5.fdiv(4)#=>1.25#Rationaldivision:5.quo(4)#=>Rational(5,4)您还可以将其中一个整数转换为Floa
例如,如果我们defc=(foo)p"hello"endc=3c=(3)并且不会打印“hello”。我知道它可以被self.c=3调用,但为什么呢?可以通过哪些其他方式调用它? 最佳答案 c=3(和c=(3),完全等同于它)总是被解释为局部变量赋值。你可能会说只有当方法c=没有在self上定义时,它才应该被解释为局部变量赋值,但是这有很多问题:至少MRI需要在解析时知道在给定范围内定义了哪些局部变量。但是,在解析时并不知道给定的方法是否已定义。所以ruby直到运行时才知道c=3是否定义了变量c或者调用了方法c=,这意味着它不会知
我需要在数据库更新前后比较一些Rails(2.3.11)模型属性值,因此我首先查找我的记录并将现有属性值保存在哈希中,如下所示:id=params[:id]work_effort=WorkEffort.find(id)ancestor_rollup_fields={:scheduled_completion_date=>work_effort.scheduled_completion_date}work_effort.update_attributes(params.except(:controller,:action))#etcetera请注意,我坚持使用符号作为哈希键的“最佳实践”