Docker.io init.d脚本无法启动容器

Mar*_*elo 11 ubuntu init.d openerp docker odoo

我在dir"/ opt/odoo /"上有一个带有odoo的容器.

"/etc/init.d/odoo-server"上的init脚本

#!/bin/bash
### BEGIN INIT INFO
# Provides:          odoo
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Start openerp daemon at boot time
# Description:       Enable service provided by daemon.
# X-Interactive:     true
### END INIT INFO
## more info: http://wiki.debian.org/LSBInitScripts

PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin
DAEMON=/opt/odoo/openerp-server
NAME=odoo
DESC=odoo
CONFIG=/etc/odoo-server.conf
LOGFILE=/var/log/odoo/odoo-server.log
PIDFILE=/var/run/${NAME}.pid
USER=odoo
export LOGNAME=$USER

test -x $DAEMON || exit 0
set -e

function _start() {
    start-stop-daemon --start --quiet --pidfile $PIDFILE --chuid $USER:$USER --background --make-pidfile --exec $DAEMON -- --config $CONFIG --logfile $LOGFILE
}

function _stop() {
    start-stop-daemon --stop --quiet --pidfile $PIDFILE --oknodo --retry 3
    rm -f $PIDFILE
}

function _status() {
    start-stop-daemon --status --quiet --pidfile $PIDFILE
    return $?
}


case "$1" in
        start)
                echo -n "Starting $DESC: "
                _start
                echo "ok"
                ;;
        stop)
                echo -n "Stopping $DESC: "
                _stop
                echo "ok"
                ;;
        restart|force-reload)
                echo -n "Restarting $DESC: "
                _stop
                sleep 1
                _start
                echo "ok"
             ;;
        status)
                echo -n "Status of $DESC: "
                _status && echo "running" || echo "stopped"
                ;;
        *)
                N=/etc/init.d/$NAME
                echo "Usage: $N {start|stop|restart|force-reload|status}" >&2
                exit 1
                ;;
esac

exit 0
Run Code Online (Sandbox Code Playgroud)

那我呢

root@cca438c81a87:/# update-rc.d odoo-server defaults
 Adding system startup for /etc/init.d/odoo-server ...
   /etc/rc0.d/K20odoo-server -> ../init.d/odoo-server
   /etc/rc1.d/K20odoo-server -> ../init.d/odoo-server
   /etc/rc6.d/K20odoo-server -> ../init.d/odoo-server
   /etc/rc2.d/S20odoo-server -> ../init.d/odoo-server
   /etc/rc3.d/S20odoo-server -> ../init.d/odoo-server
   /etc/rc4.d/S20odoo-server -> ../init.d/odoo-server
   /etc/rc5.d/S20odoo-server -> ../init.d/odoo-server
Run Code Online (Sandbox Code Playgroud)

当我用docker启动docker时启动odoo-server无法启动,当我在docker /etc/init.d/odoo-server里面运行时启动它可以运行正常...

怎么了?

use*_*103 15

Docker容器通常没有正常运行的init系统.如果您只是运行单个服务 - 只需启动它.

如果您需要更复杂的东西,请查看supervisordrunit.

容器不是虚拟机.

  • *"容器不是虚拟机."*< - 这是最糟糕的废话,由docker开发人员发明,解释了为什么他们的软件即使在最简单的init脚本中也会导致最糟糕的错误.事实是,它们之间没有明显的区别,并且*不应该是*.您提供的软件能够提供半解决方案来解决docker bug,因此您的答案值得一试. (6认同)

Evg*_*kiy 5

如果你正在寻找一个与init系统完全相同的Docker镜像,请看一下phusion baseimage


pet*_*ica 5

现在我在几个小时的工作中找到了这个错误。

问题原因start-stop-daemondebian系统的主要守护进程启动器/测试器/停止器工具通过检查守护进程进程的虚拟软链接来检查守护进程的存在/proc/<pid>/exe(它应该指向启动的进程的二进制映像) )。

现在的问题是,在 docker 中,这个软链接默认是不起作用的。这是因为docker在默认安装时必须使用严格的安全策略(主要用于运行身份不明的软件)。

该任务有很多解决方法,有些需要更改容器的权限设置,有些则不需要。两个例子:

  • 您将初始化脚本更改为不使用和start-stop-daemon标志--test--exec
  • 您可以通过为命令提供--cap-add=SYS_ADMIN选项来启动 docker 容器docker run(不用担心,它不会为您的 docker 容器提供任何 sysadm 权限,这可能只是高效使用的预防措施)

除此之外,systemd在 docker 中也不起作用,尽管它可能是 systemd 的一个缺点,就像 docker 一样。可以使用upstartsystemd代替。


PS:docker 开发者/倡导者经常说“容器不是虚拟机”之类的。但是,在日常体验中,两者之间并没有那么明显的区别,并且为了高效地使用该软件,至少对类似 VPS 功能的最低限度支持肯定是有用的。希望docker的开发在不久的将来也能集中精力在这个方向上。