创建dockerfile entrypoint.sh后docker mysql 4.0.27启动问题 [英] docker mysql 4.0.27 start problem after creating dockerfile entrypoint.sh

查看:182
本文介绍了创建dockerfile entrypoint.sh后docker mysql 4.0.27启动问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我创建了一个docker镜像,我无法自动启动甚至启动mysql。
问题是在 entrypoint.sh 中回显 $$ ,我希望运行 mysqld_safe ,但不是。如果将行echo $ @ 更改为 mysqld_safe --user = mysql ,它将成功启动。我不知道什么是自动运行为 mysql_safe --user = mysql 的正确格式。在dockerfile CMD [] 中应该写什么才能正确运行 entrypoint.sh

I have created a docker image, and I have problem to start automatically or even start mysql. The problem is echo "$@" in entrypoint.sh, I expect to run mysqld_safe, but It doesn't. If a change the line echo "$@" to mysqld_safe --user=mysql it starts successfully. I don't know what is the correct form for run automatically as mysql_safe --user=mysql. What should to write in dockerfile CMD[] to run entrypoint.sh correctly.

我的代码是下一个:

-----------
Dockerfile:
-----------


## OS part
## -------
FROM debian:buster-slim

# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added
RUN groupadd -r mysql && useradd -r -g mysql mysql

#RUN apt-get update && apt-get install -y --no-install-recommends gnupg dirmngr && rm -rf /var/lib/apt/lists/*
RUN apt-get update && apt-get install -y --no-install-recommends gnupg dirmngr

# Add packages for testing
RUN apt-get install iproute2 iputils-ping net-tools vim traceroute less -y

## MYSQL part
##-----------
ENV PATH /usr/local/mysql/bin:$PATH
#ENV MYSQLDATA /usr/local/mysql/data

VOLUME /usr/local/mysql/

ADD  mysql-standard-4.0.27-pc-linux-gnu-i686 /usr/local/mysql
ADD  my.cnf /etc/

#RUN chown -R mysql /usr/local/mysql/ && chgrp -R mysql /usr/local/mysql/

COPY entrypoint.sh /usr/local/bin/
#RUN chmod +x /entrypoint.sh
EXPOSE 3306

ENTRYPOINT ["entrypoint.sh"]
CMD ["mysqld_safe"]


---------------
Entrypoint.sh:
---------------


#!/bin/bash
set -e

# global variable
setup_env() {
        MYSQLDATA="/usr/local/mysql/data"
        MYSQLBASE="/usr/local/mysql"
        MYSQL_ROOT_PASSWORD="password"
}

# init database
init__database_dir() {
        echo "Change rights ..."
        ls -la  "$MYSQLDATA"
        chown -R mysql "$MYSQLDATA"
        chgrp -R mysql "$MYSQLDATA"
        echo "Initializing database..."
        cd $MYSQLBASE
        scripts/mysql_install_db --user=mysql
}

temp_server_start() {
        mysqld_safe --user=mysql  &
}

temp_server_stop() {
        mysqladmin shutdown -uroot
        sleep 30
}

setup_db() {
        sleep 20
        echo "start password setting"
        mysql -e "GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '$MYSQL_ROOT_PASSWORD' WITH GRANT OPTION"
        echo "password ready"
}

# start mysql if it is exist.
main() {
        setup_env
        if [ -z "$(ls -A "$MYSQLDATA/mysql/")" ]; then
                init__database_dir
                temp_server_start
                setup_db
                temp_server_stop
        fi
        echo "start mysqld_safe"
        echo "$@"
}

main


推荐答案

我认为您忘记了在entrypoint.sh中传递参数。最后一行应该是

I think you forgot to pass the parameters in your entrypoint.sh. The last line should be

main "$@"

这篇关于创建dockerfile entrypoint.sh后docker mysql 4.0.27启动问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

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