http://www.chendd.cn/information/viewInformation/experienceShare/296.a
dockerFile本地安装MySQL5.7.25,这种安装方法就是将前面学习Linux时安装MySQL的方式给转换成了DockerFile的方式,假设之前是分十个步骤一步一步的去设置安装,现在则是将所有的过程及步骤写在DockerFile文件中一个命令所有的东西都搞定,从某种程度中来讲也算是非常简化了安装过程。
#自定义Docker-MySQL5.7镜像
#基础镜像
FROM centos:latest
#签名
MAINTAINER chendd<[email protected]>
#定义环境变量
ENV WORK_HOME /usr/local
#设置进入容器后的主目录
WORKDIR $WORK_HOME
RUN yum -y install numactl
RUN yum -y install libaio
#拷贝说明文件
COPY readme.txt $WORK_HOME/readme.txt
#RUN echo "output...."
#拷贝并解压mysql
ADD mysql-5.7.25-linux-glibc2.12-x86_64.tar.gz $WORK_HOME
#修改MySQL的解压文件夹名称-----TODO
RUN mv $WORK_HOME/mysql-5.7.25-linux-glibc2.12-x86_64 $WORK_HOME/mysql
#COPY mysql $WORK_HOME/mysql
#增加系统mysql用户组
RUN groupadd mysql
RUN useradd -g mysql mysql
RUN chown -R mysql /usr/local/mysql
RUN chgrp -R mysql /usr/local/mysql
RUN mkdir /usr/local/mysql/data
VOLUME ["/usr/local/mysql/data"]
RUN cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
#RUN /usr/local/mysql/bin/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
RUN /usr/local/mysql/bin/mysqld --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data --initialize
#覆盖MySQL安装时的几个文件
COPY mysql-files/my.cnf /etc/my.cnf
#support-files/mysql.server文件也可以在此步骤由本地宿主机上的文件提供
#增加mysql的bin目录的环境变量
ENV PATH $PATH:$WORK_HOME/mysql/bin
#默认端口开放
EXPOSE 3306
#容器启动后执行以下命令,启动mysql
CMD ["/usr/local/mysql/bin/mysqld_safe"]
如果你对我的前面一篇Linux安装MySQL的教程有点熟悉的话,实际上上述的过程就是在一步一步的重复以前的安装方式,但由于它是基于本地安装包的方式,故这么干也有它的优势,但目前已经发现了两个弊端,在我的新手水平范围内无法解决,作为遗留问题留给往后再去解决吧,分别是:
(1)安装文件一共不到700M,生成的镜像文件大小超过10G;
(2)挂载数据库文件的数据卷总是失败;
(3)需要在my.cnf文件中设置免密码登录,跳过密码后进入容器手动更改mysql数据库下的user表,将root用户的host值修改为‘%’,同时再二次修改密码后取消跳过密码;