Discuz! Board

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 3182|回复: 2
打印 上一主题 下一主题

Docker 安装 MySQL

[复制链接]

697

主题

1142

帖子

4086

积分

认证用户组

Rank: 5Rank: 5

积分
4086
跳转到指定楼层
楼主
发表于 2018-1-15 14:36:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 java 于 2018-1-15 15:20 编辑

首先检查 MySQL 是否已安装
yum list installed | grep mysql
如果有的话 停止启用系统已有的mysql
systemctl stop mysqld
systemctl disable mysqld


http://www.runoob.com/docker/docker-install-mysql.html

通过 Dockerfile构建

创建Dockerfile
首先,创建目录mysql,用于存放后面的相关东西。
  1. runoob@runoob:~$ mkdir -p ~/mysql/data ~/mysql/logs ~/mysql/conf
复制代码
data目录将映射为mysql容器配置的数据文件存放路径
logs目录将映射为mysql容器的日志目录
conf目录里的配置文件将映射为mysql容器的配置文件
进入创建的mysql目录,创建Dockerfile
vi Dockerfile
把 https://github.com/docker-librar ... ster/5.6/Dockerfile 中的文件内容复制进去
  1. FROM debian:jessie

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

  4. # add gosu for easy step-down from root
  5. ENV GOSU_VERSION 1.7
  6. RUN set -x \
  7.         && apt-get update && apt-get install -y --no-install-recommends ca-certificates wget && rm -rf /var/lib/apt/lists/* \
  8.         && wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \
  9.         && wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \
  10.         && export GNUPGHOME="$(mktemp -d)" \
  11.         && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \
  12.         && gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \
  13.         && rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \
  14.         && chmod +x /usr/local/bin/gosu \
  15.         && gosu nobody true \
  16.         && apt-get purge -y --auto-remove ca-certificates wget

  17. RUN mkdir /docker-entrypoint-initdb.d

  18. # FATAL ERROR: please install the following Perl modules before executing /usr/local/mysql/scripts/mysql_install_db:
  19. # File::Basename
  20. # File::Copy
  21. # Sys::Hostname
  22. # Data::Dumper
  23. RUN apt-get update && apt-get install -y perl pwgen --no-install-recommends && rm -rf /var/lib/apt/lists/*

  24. RUN set -ex; \
  25. # gpg: key 5072E1F5: public key "MySQL Release Engineering <mysql-build@oss.oracle.com>" imported
  26.         key='A4A9406876FCBD3C456770C88C718D3B5072E1F5'; \
  27.         export GNUPGHOME="$(mktemp -d)"; \
  28.         gpg --keyserver ha.pool.sks-keyservers.net --recv-keys "$key"; \
  29.         gpg --export "$key" > /etc/apt/trusted.gpg.d/mysql.gpg; \
  30.         rm -r "$GNUPGHOME"; \
  31.         apt-key list > /dev/null

  32. ENV MYSQL_MAJOR 5.6
  33. ENV MYSQL_VERSION 5.6.38-1debian8

  34. RUN echo "deb http://repo.mysql.com/apt/debian/ jessie mysql-${MYSQL_MAJOR}" > /etc/apt/sources.list.d/mysql.list

  35. # the "/var/lib/mysql" stuff here is because the mysql-server postinst doesn't have an explicit way to disable the mysql_install_db codepath besides having a database already "configured" (ie, stuff in /var/lib/mysql/mysql)
  36. # also, we set debconf keys to make APT a little quieter
  37. RUN { \
  38.                 echo mysql-community-server mysql-community-server/data-dir select ''; \
  39.                 echo mysql-community-server mysql-community-server/root-pass password ''; \
  40.                 echo mysql-community-server mysql-community-server/re-root-pass password ''; \
  41.                 echo mysql-community-server mysql-community-server/remove-test-db select false; \
  42.         } | debconf-set-selections \
  43.         && apt-get update && apt-get install -y mysql-server="${MYSQL_VERSION}" && rm -rf /var/lib/apt/lists/* \
  44.         && rm -rf /var/lib/mysql && mkdir -p /var/lib/mysql /var/run/mysqld \
  45.         && chown -R mysql:mysql /var/lib/mysql /var/run/mysqld \
  46. # ensure that /var/run/mysqld (used for socket and lock files) is writable regardless of the UID our mysqld instance ends up having at runtime
  47.         && chmod 777 /var/run/mysqld \
  48. # comment out a few problematic configuration values
  49.         && find /etc/mysql/ -name '*.cnf' -print0 \
  50.                 | xargs -0 grep -lZE '^(bind-address|log)' \
  51.                 | xargs -rt -0 sed -Ei 's/^(bind-address|log)/#&/' \
  52. # don't reverse lookup hostnames, they are usually another container
  53.         && echo '[mysqld]\nskip-host-cache\nskip-name-resolve' > /etc/mysql/conf.d/docker.cnf

  54. VOLUME /var/lib/mysql

  55. COPY docker-entrypoint.sh /usr/local/bin/
  56. RUN ln -s usr/local/bin/docker-entrypoint.sh /entrypoint.sh # backwards compat
  57. ENTRYPOINT ["docker-entrypoint.sh"]

  58. EXPOSE 3306
  59. CMD ["mysqld"]
复制代码
再创建 docker-entrypoint.sh 文件
把 https://github.com/docker-librar ... ocker-entrypoint.sh 的内容复制进去
  1. #!/bin/bash
  2. set -eo pipefail
  3. shopt -s nullglob

  4. # if command starts with an option, prepend mysqld
  5. if [ "${1:0:1}" = '-' ]; then
  6.         set -- mysqld "$@"
  7. fi

  8. # skip setup if they want an option that stops mysqld
  9. wantHelp=
  10. for arg; do
  11.         case "$arg" in
  12.                 -'?'|--help|--print-defaults|-V|--version)
  13.                         wantHelp=1
  14.                         break
  15.                         ;;
  16.         esac
  17. done

  18. # usage: file_env VAR [DEFAULT]
  19. #    ie: file_env 'XYZ_DB_PASSWORD' 'example'
  20. # (will allow for "$XYZ_DB_PASSWORD_FILE" to fill in the value of
  21. #  "$XYZ_DB_PASSWORD" from a file, especially for Docker's secrets feature)
  22. file_env() {
  23.         local var="$1"
  24.         local fileVar="${var}_FILE"
  25.         local def="${2:-}"
  26.         if [ "${!var:-}" ] && [ "${!fileVar:-}" ]; then
  27.                 echo >&2 "error: both $var and $fileVar are set (but are exclusive)"
  28.                 exit 1
  29.         fi
  30.         local val="$def"
  31.         if [ "${!var:-}" ]; then
  32.                 val="${!var}"
  33.         elif [ "${!fileVar:-}" ]; then
  34.                 val="$(< "${!fileVar}")"
  35.         fi
  36.         export "$var"="$val"
  37.         unset "$fileVar"
  38. }

  39. _check_config() {
  40.         toRun=( "$@" --verbose --help --log-bin-index="$(mktemp -u)" )
  41.         if ! errors="$("${toRun[@]}" 2>&1 >/dev/null)"; then
  42.                 cat >&2 <<-EOM
  43.                         ERROR: mysqld failed while attempting to check config
  44.                         command was: "${toRun[*]}"
  45.                         $errors
  46.                 EOM
  47.                 exit 1
  48.         fi
  49. }

  50. # Fetch value from server config
  51. # We use mysqld --verbose --help instead of my_print_defaults because the
  52. # latter only show values present in config files, and not server defaults
  53. _get_config() {
  54.         local conf="$1"; shift
  55.         "$@" --verbose --help --log-bin-index="$(mktemp -u)" 2>/dev/null | awk '$1 == "'"$conf"'" { print $2; exit }'
  56. }

  57. # allow the container to be started with `--user`
  58. if [ "$1" = 'mysqld' -a -z "$wantHelp" -a "$(id -u)" = '0' ]; then
  59.         _check_config "$@"
  60.         DATADIR="$(_get_config 'datadir' "$@")"
  61.         mkdir -p "$DATADIR"
  62.         chown -R mysql:mysql "$DATADIR"
  63.         exec gosu mysql "$BASH_SOURCE" "$@"
  64. fi

  65. if [ "$1" = 'mysqld' -a -z "$wantHelp" ]; then
  66.         # still need to check config, container may have started with --user
  67.         _check_config "$@"
  68.         # Get config
  69.         DATADIR="$(_get_config 'datadir' "$@")"

  70.         if [ ! -d "$DATADIR/mysql" ]; then
  71.                 file_env 'MYSQL_ROOT_PASSWORD'
  72.                 if [ -z "$MYSQL_ROOT_PASSWORD" -a -z "$MYSQL_ALLOW_EMPTY_PASSWORD" -a -z "$MYSQL_RANDOM_ROOT_PASSWORD" ]; then
  73.                         echo >&2 'error: database is uninitialized and password option is not specified '
  74.                         echo >&2 '  You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD'
  75.                         exit 1
  76.                 fi

  77.                 mkdir -p "$DATADIR"

  78.                 echo 'Initializing database'
  79.                 # "Other options are passed to mysqld." (so we pass all "mysqld" arguments directly here)
  80.                 mysql_install_db --datadir="$DATADIR" --rpm --keep-my-cnf "${@:2}"
  81.                 echo 'Database initialized'

  82.                 SOCKET="$(_get_config 'socket' "$@")"
  83.                 "$@" --skip-networking --socket="${SOCKET}" &
  84.                 pid="$!"

  85.                 mysql=( mysql --protocol=socket -uroot -hlocalhost --socket="${SOCKET}" )

  86.                 for i in {30..0}; do
  87.                         if echo 'SELECT 1' | "${mysql[@]}" &> /dev/null; then
  88.                                 break
  89.                         fi
  90.                         echo 'MySQL init process in progress...'
  91.                         sleep 1
  92.                 done
  93.                 if [ "$i" = 0 ]; then
  94.                         echo >&2 'MySQL init process failed.'
  95.                         exit 1
  96.                 fi

  97.                 if [ -z "$MYSQL_INITDB_SKIP_TZINFO" ]; then
  98.                         # sed is for https://bugs.mysql.com/bug.php?id=20545
  99.                         mysql_tzinfo_to_sql /usr/share/zoneinfo | sed 's/Local time zone must be set--see zic manual page/FCTY/' | "${mysql[@]}" mysql
  100.                 fi

  101.                 if [ ! -z "$MYSQL_RANDOM_ROOT_PASSWORD" ]; then
  102.                         export MYSQL_ROOT_PASSWORD="$(pwgen -1 32)"
  103.                         echo "GENERATED ROOT PASSWORD: $MYSQL_ROOT_PASSWORD"
  104.                 fi

  105.                 rootCreate=
  106.                 # default root to listen for connections from anywhere
  107.                 file_env 'MYSQL_ROOT_HOST' '%'
  108.                 if [ ! -z "$MYSQL_ROOT_HOST" -a "$MYSQL_ROOT_HOST" != 'localhost' ]; then
  109.                         # no, we don't care if read finds a terminating character in this heredoc
  110.                         # https://unix.stackexchange.com/questions/265149/why-is-set-o-errexit-breaking-this-read-heredoc-expression/265151#265151
  111.                         read -r -d '' rootCreate <<-EOSQL || true
  112.                                 CREATE USER 'root'@'${MYSQL_ROOT_HOST}' IDENTIFIED BY '${MYSQL_ROOT_PASSWORD}' ;
  113.                                 GRANT ALL ON *.* TO 'root'@'${MYSQL_ROOT_HOST}' WITH GRANT OPTION ;
  114.                         EOSQL
  115.                 fi

  116.                 "${mysql[@]}" <<-EOSQL
  117.                         -- What's done in this file shouldn't be replicated
  118.                         --  or products like mysql-fabric won't work
  119.                         SET @@SESSION.SQL_LOG_BIN=0;
  120.                         DELETE FROM mysql.user WHERE user NOT IN ('mysql.sys', 'mysqlxsys', 'root') OR host NOT IN ('localhost') ;
  121.                         SET PASSWORD FOR 'root'@'localhost'=PASSWORD('${MYSQL_ROOT_PASSWORD}') ;
  122.                         GRANT ALL ON *.* TO 'root'@'localhost' WITH GRANT OPTION ;
  123.                         ${rootCreate}
  124.                         DROP DATABASE IF EXISTS test ;
  125.                         FLUSH PRIVILEGES ;
  126.                 EOSQL

  127.                 if [ ! -z "$MYSQL_ROOT_PASSWORD" ]; then
  128.                         mysql+=( -p"${MYSQL_ROOT_PASSWORD}" )
  129.                 fi

  130.                 file_env 'MYSQL_DATABASE'
  131.                 if [ "$MYSQL_DATABASE" ]; then
  132.                         echo "CREATE DATABASE IF NOT EXISTS \`$MYSQL_DATABASE\` ;" | "${mysql[@]}"
  133.                         mysql+=( "$MYSQL_DATABASE" )
  134.                 fi

  135.                 file_env 'MYSQL_USER'
  136.                 file_env 'MYSQL_PASSWORD'
  137.                 if [ "$MYSQL_USER" -a "$MYSQL_PASSWORD" ]; then
  138.                         echo "CREATE USER '$MYSQL_USER'@'%' IDENTIFIED BY '$MYSQL_PASSWORD' ;" | "${mysql[@]}"

  139.                         if [ "$MYSQL_DATABASE" ]; then
  140.                                 echo "GRANT ALL ON \`$MYSQL_DATABASE\`.* TO '$MYSQL_USER'@'%' ;" | "${mysql[@]}"
  141.                         fi

  142.                         echo 'FLUSH PRIVILEGES ;' | "${mysql[@]}"
  143.                 fi

  144.                 echo
  145.                 for f in /docker-entrypoint-initdb.d/*; do
  146.                         case "$f" in
  147.                                 *.sh)     echo "$0: running $f"; . "$f" ;;
  148.                                 *.sql)    echo "$0: running $f"; "${mysql[@]}" < "$f"; echo ;;
  149.                                 *.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${mysql[@]}"; echo ;;
  150.                                 *)        echo "$0: ignoring $f" ;;
  151.                         esac
  152.                         echo
  153.                 done

  154.                 if [ ! -z "$MYSQL_ONETIME_PASSWORD" ]; then
  155.                         "${mysql[@]}" <<-EOSQL
  156.                                 ALTER USER 'root'@'%' PASSWORD EXPIRE;
  157.                         EOSQL
  158.                 fi
  159.                 if ! kill -s TERM "$pid" || ! wait "$pid"; then
  160.                         echo >&2 'MySQL init process failed.'
  161.                         exit 1
  162.                 fi

  163.                 echo
  164.                 echo 'MySQL init process done. Ready for start up.'
  165.                 echo
  166.         fi
  167. fi

  168. exec "$@"
复制代码
并增加此文件的执行权限
  1. chmod +x ./docker-entrypoint.sh
复制代码
通过Dockerfile创建一个镜像,替换成你自己的名字
  1. runoob@runoob:~/mysql$ docker build -t mysql .
复制代码
创建完成后,我们可以在本地的镜像列表里查找到刚刚创建的镜像
runoob@runoob:~/mysql$ docker images |grep mysql

使用mysql镜像
运行容器


runoob@runoob:~/mysql$ docker run -p 3306:3306 --name mysql -v $PWD/conf/my.cnf:/etc/mysql/my.cnf -v $PWD/logs:/logs -v $PWD/data:/mysql_data -e MYSQL_ROOT_PASSWORD=123456 -d mysql5.6:5.6 --restart=always

命令说明:
-p 3306:3306:将容器的3306端口映射到主机的3306端口
-v $PWD/conf/my.cnf:/etc/mysql/my.cnf:将主机当前目录下的conf/my.cnf挂载到容器的/etc/mysql/my.cnf
-v $PWD/logs:/logs:将主机当前目录下的logs目录挂载到容器的/logs
-v $PWD/data:/mysql_data:将主机当前目录下的data目录挂载到容器的/mysql_data
-e MYSQL_ROOT_PASSWORD=123456:初始化root用户的密码
mysql5.6:5.6 --- imageID: mysql镜像ID
--restart:always:始终重启  Docker容器开机自动启动
回复

使用道具 举报

697

主题

1142

帖子

4086

积分

认证用户组

Rank: 5Rank: 5

积分
4086
沙发
 楼主| 发表于 2018-1-15 15:33:11 | 只看该作者
本帖最后由 java 于 2018-1-15 16:02 编辑

Version '5.6.38-1debian8' for 'mysql-server' was not found

修改Dockerfile 把 38 改为 31
应该是网络的问题?
回复 支持 反对

使用道具 举报

697

主题

1142

帖子

4086

积分

认证用户组

Rank: 5Rank: 5

积分
4086
板凳
 楼主| 发表于 2018-1-15 16:07:16 | 只看该作者
本帖最后由 java 于 2018-1-15 16:29 编辑

上面方法没成功 
方法二、docker pull mysql
查找Docker Hub上的mysql镜像
  1. [hechengjin@localhost mysql]$ docker search mysql
  2. NAME                                                   DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
  3. mysql                                                  MySQL is a widely used, open-source relati...   5556      [OK]      
复制代码
这里我们拉取官方的镜像,标签为5.6
  1. docker pull mysql:5.6
复制代码
等待下载完成后,我们就可以在本地镜像列表里查到REPOSITORY为mysql,标签为5.6的镜像。


使用mysql镜像运行容器
  1. docker run -p 3306:3306 --name mysql -v $PWD/conf/:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/mysql_data -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6
复制代码
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|firemail ( 粤ICP备15085507号-1 )

GMT+8, 2024-11-29 15:27 , Processed in 0.059352 second(s), 18 queries .

Powered by Discuz! X3

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表