【系列7】使用Dockerfile创建带mysql的Centos Docker镜像

下面用官方的rpm源包安装mysql过慢不主张采用yum这种方式

   1. 下载文件
   从GitHub Dockerpool社区下载MySQL镜像项目:
[root@docker1 ~]# git clone https://github.com/DockerPool/mysql.git
Cloning into 'mysql'...
remote: Counting objects: 19, done.
remote: Compressing objects: 100% (15/15), done.
remote: Total 19 (delta 4), reused 19 (delta 4), pack-reused 0
Unpacking objects: 100% (19/19), done.
查看内容,包括已经写好的Dockerfile和若干脚本:
[root@docker1 ~]# cd mysql/
[root@docker1 mysql]# ls
create_db.sh  Dockerfile  import_sql.sh  LICENSE  my.cnf  mysqld_charset.cnf  README.md  run.sh   

#本文参考了「tutum」的 Dockerfile

FROM docker.io/centos:latest


MAINTAINER Waitfish 


#设置环境变量,所有操作都是非交互式的

ENV DEBIAN_FRONTEND noninteractive


RUN echo "Asia/Shanghai" > /etc/timezone

#注意这里要更改系统的时区设置,因为在Web应用中经常会用到时区这个系统变量,默认的centos会让你的应用此程序发生不可思议的效果哦


#安装mysql服务

RUN yum update -y && \

  yum install wget rpm -y && \

  #wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm && \  #下载速度太慢

  wget http://dev.mysql.com/get/mysql57-community-release-el7-7.noarch.rpm && \

  #rpm -ivh mysql-community-release-el7-5.noarch.rpm --nosignature && \

  yum localinstall mysql57-community-release-el7-7.noarch.rpm -y && \

  rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 && \

  yum install mysql-community-server -y


# 删除预安装的数据库文件

RUN rm -rf /var/lib/mysql/*


# 添加文件夹下的 MYSQL 配置文件

ADD my.cnf /etc/mysql/conf.d/my.cnf

ADD mysqld_charset.cnf /etc/mysql/conf.d/mysqld_charset.cnf


# 添加 MYSQL 的脚本

ADD import_sql.sh /import_sql.sh

ADD run.sh /run.sh

RUN chmod 755 /*.sh


# 设置环境变量,用户名以及秘密

ENV MYSQL_USER admin

ENV MYSQL_PASS **Random**


# 设置主从复制模式下的环境变量

ENV REPLICATION_MASTER **False**

ENV REPLICATION_SLAVE **False**

ENV REPLICATION_USER replica

ENV REPLICATION_PASS replica


# 设置可以允许挂载的卷,可以用来备份数据库和配置文件

VOLUME  ["/etc/mysql", "/var/lib/mysql"]


# 设置可以映射的端口

EXPOSE 3306


# 设置自启动的脚本

CMD ["/run.sh"]

*********************************************************************************************************************************************************************************************************************************************************************************

快速创建带mysql的Centos Docker镜像

[root@docker1 mysql]# ls

create_db.sh   my.cnf   mysql-community-libs-5.7.18-1.el7.x86_64.rpm    RPM

Dockerfile    mysql-community-client-5.7.18-1.el7.x86_64.rpm  mysql-community-server-5.7.18-1.el7.x86_64.rpm  Running

import_sql.sh  mysql-community-common-5.7.18-1.el7.x86_64.rpm  mysqld_charset.cnf                     run.sh

LICENSE      mysql-community-devel-5.7.18-1.el7.x86_64.rpm   README.md



下面需要事先下载如下的RPM包:

mysql-community-common-5.7.18-1.el7.x86_64.rpm

mysql-community-libs-5.7.18-1.el7.x86_64.rpm

mysql-community-devel-5.7.18-1.el7.x86_64.rpm

mysql-community-client-5.7.18-1.el7.x86_64.rpm

mysql-community-server-5.7.18-1.el7.x86_64.rpm


[root@docker1 mysql]# cat Dockerfile 

#本文参考了「tutum」的 Dockerfile

FROM sshd:centos


MAINTAINER Waitfish 


#设置环境变量,所有操作都是非交互式的

ENV DEBIAN_FRONTEND noninteractive


RUN echo "Asia/Shanghai" > /etc/timezone

#注意这里要更改系统的时区设置,因为在Web应用中经常会用到时区这个系统变量,默认的centos会让你的应用此程序发生不可思议的效果哦


ADD mysql-community* /


#安装mysql服务 --nosignature 去掉校验安装

RUN yum update -y && \

  yum install wget rpm -y && \

  #rpm -e mariadb-libs* --nodeps && \

  #yum install libaio* libnuma* net-tools* perl* -y && \

  yum install numactl perl libaio net-tools -y && \

  yum install gcc* ncurses ncurses-devel -y && \

  rpm -ivh mysql-community-common* --nosignature && \

  rpm -ivh mysql-community-libs* --nosignature && \

  rpm -ivh mysql-community-devel* --nosignature && \

  rpm -ivh mysql-community-client* --nosignature && \

  rpm -ivh mysql-community-server* --nosignature


# 删除预安装的数据库文件

RUN rm -rf /var/lib/mysql/*


# 添加文件夹下的 MYSQL 配置文件

ADD my.cnf /etc/mysql/conf.d/my.cnf

ADD mysqld_charset.cnf /etc/mysql/conf.d/mysqld_charset.cnf


# 添加 MYSQL 的脚本

ADD import_sql.sh /import_sql.sh

ADD run.sh /run.sh

RUN chmod 755 /*.sh


# 设置环境变量,用户名以及秘密

ENV MYSQL_USER admin

ENV MYSQL_PASS **Random**


# 设置主从复制模式下的环境变量

ENV REPLICATION_MASTER **False**

ENV REPLICATION_SLAVE **False**

ENV REPLICATION_USER replica

ENV REPLICATION_PASS replica


# 设置可以允许挂载的卷,可以用来备份数据库和配置文件

VOLUME  ["/etc/mysql", "/var/lib/mysql"]


# 设置可以映射的端口

EXPOSE 3306


# 设置自启动的脚本

CMD ["/run.sh"]




本文转自 Mr_sheng 51CTO博客,原文链接:http://blog.51cto.com/sf1314/2046751



优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/503761

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。