我一直在寻找在云原生应用程序中设置工作节点的方法。我计划让一组自动缩放的工作节点从队列中提取作业,这没什么特别的。
我只是想知道,是否有任何最佳实践方法来确保(例如 ruby)脚本始终运行?我目前的假设是,您有一个正在运行的脚本,该脚本会轮询队列中的作业并在作业查询未返回新作业时休眠几秒钟左右。
真正引起我注意的是 AWS Elastic Beanstalk 文档的 Linux 自定义配置部分中的服务 key 。
00_start_service.config
services:
sysvinit:
<name of service>:
enabled: true
ensureRunning: true
files: "<file name>"
sources: "<directory>"
packages:
<name of package manager>:
<package name>: <version>
commands:
<name of command>:
http://docs.aws.amazon.com/elasticbeanstalk/latest/dg/customize-containers-ec2.html
他们给出的例子是这样的..
services:
sysvinit:
myservice:
enabled: true
ensureRunning: true
我发现示例和文档非常模糊,我不知道如何使用此配置 key 启动和运行我自己的服务,这意味着我什至不知道这是否是我想要或需要使用的。我试过创建一个 ruby 可执行文件并将名称放在字段中,但没有成功。
我向 AWS 论坛询问了更多说明,但没有收到任何回复。
如果有人对如何实现这一目标有任何见解或方向,我将不胜感激。谢谢!
最佳答案
我决定不使用 EB 配置文件的“服务”部分,而只使用“命令”..
我用 ruby 构建了一个服务监视器,用于监视给定的系统进程(在本例中是我的服务)。
服务本身是一个无限循环的脚本,基于对队列服务的长轮询时间而产生延迟。
cron 作业每分钟运行一次监视器,如果服务关闭,它会重新启动。
关于ruby - 保持 Ruby 服务在 Elastic Beanstalk 上运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17154791/