在不同主机上的 Docker 中运行 cron 的问题 [英] Issues running cron in Docker on different hosts

查看:15
本文介绍了在不同主机上的 Docker 中运行 cron 的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我试图让一个 docker 容器运行来管理我的 cronjobs

Im trying to get a docker container running to mange my cronjobs

我在使用 centOS 6.5 基础的 docker 容器中运行一个非常简单的 cron 作为测试

im running a very simple cron as a test in a docker container using centOS 6.5 base

* * * * * /bin/echo "it works!" >> test.log

如果容器在 CoreOS 主机上运行,​​它工作正常,但是如果我在 ubuntu 13.10 主机上运行容器,则不会执行 cron.(我虽然主机并没有影响容器中运行的内容)

it works fine if the container is running on CoreOS host, however if I run the container on a ubuntu 13.10 host the cron is not executed. (I though the host did not effect what was running in the container)

两台主机都运行 docker 0.8

both hosts are running docker 0.8

我是否遗漏了一些明显的东西,或者这是一个错误?

am I missing something obvious, or it this a bug?

谢谢

推荐答案

简答

将此行添加到您的 dockerfile

add this line to your dockerfile

RUN sed -i '/session    required   pam_loginuid.so/c#session    required   pam_loginuid.so' /etc/pam.d/crond

长答案

据我所知,问题与 CoreOS 和内核之间的差异有关.温布图.这反过来又会导致 pam 安全问题.

from what I understand issue is related to differences in the kernal between CoreOS & Unbutu. this in-turn causes a pam security issue.

为了解决这个问题,我们首先需要为 cron 开启日志记录(因为我们在 docker 中正常启动没有被执行).运行

to figure it our first needed to turn on logging for cron (since we are in docker normal startup is not executed). run

service rsyslog start
service crond restart

cron 日志有这个错误(位于/var/log/cron)

the cron log had this error (located here /var/log/cron)

FAILED to open PAM security session (Cannot make/remove an entry for the specified session)

然后我查看了安全日志,它有这个错误(位于/var/log/secure)

so then I took a look at the security log, and it had this error (located here /var/log/secure)

pam_loginuid(crond:session): set_loginuid failed

更多的谷歌搜索,发现我需要修改我的 pam cond 配置(在这里找到/etc/pam.d/crond)编辑此文件并注释掉以下行

some more googling and found I needed to modify my pam cond config (found here /etc/pam.d/crond) edit this file and comment out the following line

#session    required   pam_loginuid.so

重启 crond 一切正常

restart crond and all should be good

这篇关于在不同主机上的 Docker 中运行 cron 的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆