- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解利用Dockerfile构建mysql镜像并实现数据的初始化及权限设置由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文提要 。
本文目的不仅仅是创建一个mysql的镜像,而是在其基础上再实现启动过程中自动导入数据及数据库用户的权限设置,并且在新创建出来的容器里自动启动mysql服务接受外部连接,主要是通过dockerfile和shell脚本实现这一过程.
搭建步骤 。
1、首先创建dckerfile:
1
2
3
4
5
6
7
8
9
10
11
12
|
from mysql:5.7
#设置免密登录
env
mysql_allow_empty_password
yes
#将所需文件放到容器中
copy setup.sh
/mysql/setup
.sh
copy schema.sql
/mysql/schema
.sql
copy privileges.sql
/mysql/privileges
.sql
#设置容器启动时执行的命令
cmd [
"sh"
,
"/mysql/setup.sh"
]
|
2、编写容器启动脚本setup.sh:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
#!/bin/bash
set
-e
#查看mysql服务的状态,方便调试,这条语句可以删除
echo
`service mysql status`
echo
'1.启动mysql....'
#启动mysql
service mysql start
sleep
3
echo
`service mysql status`
echo
'2.开始导入数据....'
#导入数据
mysql <
/mysql/schema
.sql
echo
'3.导入数据完毕....'
sleep
3
echo
`service mysql status`
#重新设置mysql密码
echo
'4.开始修改密码....'
mysql <
/mysql/privileges
.sql
echo
'5.修改密码完毕....'
#sleep 3
echo
`service mysql status`
echo
`mysql容器启动完毕,且数据导入成功`
tail
-f
/dev/null
|
这里是先导入数据,然后才是设置用户和权限,是因为mysql容器一开始为免密登录,dockerfile中有如下设置:env mysql_allow_empty_password yes,此时执行导入数据命令不需要登录验证操作,如果是先执行权限操作,那么导入数据则需要登录验证,整个过程就麻烦了许多.
3、需要导入数据的mysql脚本命令schema.sql:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
-- 创建数据库
create
database
`docker_mysql`
default
character
set
utf8
collate
utf8_general_ci;
use docker_mysql;
-- 建表
drop
table
if exists `
user
`;
create
table
`
user
` (
`id`
bigint
(20)
not
null
,
`created_at`
bigint
(40)
default
null
,
`last_modified`
bigint
(40)
default
null
,
`email`
varchar
(255)
default
null
,
`first_name`
varchar
(255)
default
null
,
`last_name`
varchar
(255)
default
null
,
`username`
varchar
(255)
default
null
,
primary
key
(`id`)
) engine=innodb
default
charset=latin1;
-- 插入数据
insert
into
`
user
` (`id`, `created_at`, `last_modified`, `email`, `first_name`, `last_name`, `username`)
values
(0,1490257904,1490257904,
'john.doe@example.com'
,
'john'
,
'doe'
,
'user'
);
|
因为是测试,所以随便写了一个建表语句,如果是真实项目肯定不止这一张表,直接将建表语句覆盖过来就好.
4、mysql权限设置命令privileges.sql:
1
2
3
4
5
6
7
8
|
use mysql;
select
host,
user
from
user
;
-- 因为mysql版本是5.7,因此新建用户为如下命令:
create
user
docker identified
by
'123456'
;
-- 将docker_mysql数据库的权限授权给创建的docker用户,密码为123456:
grant
all
on
docker_mysql.*
to
docker@
'%'
identified
by
'123456'
with
grant
option
;
-- 这一条命令一定要有:
flush
privileges
;
|
5、创建镜像 。
1
|
docker build -t 13
/docker-mysql
.
|
docker build 为创建镜像命令,名称为13/docker-mysql,'.'表示当前目录,即dockerfile文件所在的目录,创建过程如下:
执行docker images查看该镜像是否存在于镜像列表中:
创建成功.
6、启动容器 。
1
|
docker run -d -p 13306:3306 13
/docker-mysql
|
启动容器,并将端口映射到本地的13306端口,命令行如图所示:
容器启动成功.
查看容器的日志记录,启动过程与启动脚本setup.sh中所规范的步骤一致,数据导入和权限设置成功:
验证结果 。
1、通过进入容器在命令行验证 。
启动时容器的id为9db491b1d760,因此执行exec命令进入容器:
1
|
docker
exec
-it 9db491b1d760
/bin/bash
|
这个命令不要直接使用,因为在你机器上id可能不同,替换掉id值即可.
前文中创建了docker_mysql数据库,并在此数据库中创建了user表,同时将数据库的连接授权赋予了新建的docker用户,因此验证过程为:
整个过程如下:
通过图中的结果对比,与前文一致,验证成功.
2、通过mysql客户端管理软件验证 。
通过图中的结果对比,与前文一致,验证成功.
结语 。
本篇文章是单独介绍了一下创建mysql镜像的步骤,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:http://www.cnblogs.com/han-1034683568/p/6941337.html?utm_source=tuicool&utm_medium=referral 。
最后此篇关于详解利用Dockerfile构建mysql镜像并实现数据的初始化及权限设置的文章就讲到这里了,如果你想了解更多关于详解利用Dockerfile构建mysql镜像并实现数据的初始化及权限设置的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在尝试使用谷歌云构建触发器来构建我的 docker 容器。不幸的是,构建没有找到我的 docker 文件。它不在我的存储库的根目录中,但我认为我可以指定一个相对路径。显然我配置错误了。下面是我的
我可以像这样构建一个 Dockerfile docker build -t deepak/ruby . 但是对于一个不名为Dockerfile的Dockerfile # DOCKER-VERSION
是否可以命名构建阶段?我正在搜索类似以下示例的内容: ARG NAME FROM python:3.7-alpine as modul-${NAME} # ... 如果我尝试这个例子,就会发生这个错误
在我的 Dockerfile 中,我需要使用命令替换来添加一些环境变量。我想设置 ENV PYTHONPATH /usr/local/$(python3 -c 'from distutils impo
以下Dockerfile包含四个COPY层: COPY README.md ./ COPY package.json ./ COPY gulpfile.js ./ COPY __BUILD_NUMBE
我正在尝试从我创建的 Dockerfile 中拉取 tomcat,并使用以下命令拉取 centos: FROM centos RUN docker run -it tomcat 然后现在我正在创建一个
我不确定是否应该为我的 Node.js 应用程序创建不同的 Dockerfile 文件。一种用于没有开发依赖项的生产,另一种用于包含开发依赖项的测试。 或者一个基本上是开发Dockerfile.dev
我拥有的是多个相似且简单的dockerfile 但我想要的是有一个单一的基础 dockerfile 和我的 dockerfile将他们的变量传递给它。 在我的例子中,dockerfile 之间的唯一区
我有一个应用程序有两个 Dockerfile ,说 Dockerfile.foo和 Dockerfile.bar ,预计将为 docker-compose.yml 的两个不同服务生成两个不同的图像.
我是一个 docker maven 插件新手。 如果我理解得很好,根据Spotify's Dockerfile Maven documentation ,应该将 Dockerfile 放在我的项目的根
我正在设置一个docker容器,将在this article之后在nginx服务器上为我的Angular 5应用程序提供服务。 本文提出了这个Dockerfile: # Stage 0, based
大家好, 我是 docker 的新手,我想容器化我的 ASP.NET Core 应用程序,但出现错误,我无法继续构建我的图像 这是我的示例 Dockerfile FROM microsoft/dotn
我想在不使用注册表的情况下链接 Dockerfiles,这可以通过 FROM 实现吗?陈述? 以两个 Dockerfile 为例: Dockerfile /some/other/dir/Dockerf
我尝试在公共(public) dockerhub 上通过我自己的镜像安装 Airflow,但它在本地运行完美,但当我尝试在 Openshift 上使用它时。我在下面收到此错误。 `ERROR: Cou
此 dockerfile 工作正常。但是如何在 dockerfile 中执行命令? FROM alpine RUN apk add --update sqlite && rm -rf /var/cac
当我尝试设置自动构建时,我的 Docker Hub 存储库中的 Dockerfile 为空。如果我触发构建:- Build failed: Dockerfile not found at ./Dock
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 1年前关闭。 Improve this
我目前正在将一个巨大的 DockerFile 拆分为单独的 DockerFile,但是在巨大的 DockerFile 中定义的一些变量需要在单独的 DockerFile 中使用。 Docker 是否有
我有一个 Dockerfile 可以创建我想在这里使用的构建镜像:~/build/Dockerfile 然后我使用一个标准镜像来部署 从 ~/build/Dockerfile 构建的图像没有在任何地方
我运行这个: ➜ frontend git:(master) ✗ docker-compose up Building web ERROR: Cannot locate specified Dock
我是一名优秀的程序员,十分优秀!