MySQL 服务器 Upstart 脚本在启动时不起作用

Row*_*wno 5 server mysql boot upstart openvz

出于某种原因,MySQL 服务器的 Upstart 脚本在我启动服务器时不起作用,但是一旦服务器启动并且我sudo start mysql手动执行它就会起作用。

我正在运行安装了 Ubuntu 10.04 和 MySQL 版本 5.1.41(来自存储库的最新稳定版本)的 OpenVZ VPS。MySQL 是全新安装,没有更改配置。

/etc/init/mysql.conf:

# MySQL Service

description     "MySQL Server"
author          "Mario Limonciello <superm1@ubuntu.com>"

start on (net-device-up
          and local-filesystems
      and runlevel [2345])
stop on runlevel [016]

respawn

env HOME=/etc/mysql
umask 007

pre-start script
    #Sanity checks
    [ -r $HOME/my.cnf ]
    [ -d /var/run/mysqld ] || install -m 755 -o mysql -g root -d /var/run/mysqld
    # Load AppArmor profile
    if aa-status --enabled 2>/dev/null; then
        apparmor_parser -r /etc/apparmor.d/usr.sbin.mysqld || true
    fi
    LC_ALL=C BLOCKSIZE= df --portability /var/lib/mysql/. | tail -n 1 | awk '{ exit ($4<4096) }'
end script

exec /usr/sbin/mysqld

post-start script
    for i in `seq 1 30` ; do
        /usr/bin/mysqladmin --defaults-file="${HOME}"/debian.cnf ping && {
            exec "${HOME}"/debian-start
            # should not reach this line
            exit 2
        }
        sleep 1
    done
    exit 1
end script
Run Code Online (Sandbox Code Playgroud)

Row*_*wno 7

事实证明,Upstart 启动作业在 OpenVZ 上可能会出现问题。

改变:

start on (net-device-up
          and local-filesystems
      and runlevel [2345])
Run Code Online (Sandbox Code Playgroud)

到:

start on runlevel [2345]
Run Code Online (Sandbox Code Playgroud)

为我解决了问题。