容器的配置和存储
1. 创建资源
开始实验之前,您需要先创建实验相关资源。
- 在实验室页面,单击创建资源。
- (可选)在实验室页面左侧导航栏中,单击云产品资源列表,可查看本次实验资源相关信息(例如IP地址、子用户信息等)。
说明:资源创建过程需要3~5分钟(视资源不同开通时间有所差异,ACK等资源开通时间较长)。完成实验资源的创建后,您可以在云产品资源列表查看已创建的资源信息,例如:子用户名称、子用户密码、AK ID、AK Secret、资源中的项目名称等。
实验环境一旦开始创建则进入计时阶段,建议学员先基本了解实验具体的步骤、目的,真正开始做实验时再进行创建。
资源创建成功,可在左侧的资源卡片中查看相关资源信息以及RAM子账号信息
2. 配置和存储的快速上手
在上面的实验中我们学习了容器的网络用法和网络模型,接下来我们来学习几种配置容器中的服务,以及管理容器存储系统的方式。
- 容器环境变量
在容器的配置中,最简单的方式是配置容器的环境变量。当我们使用docker run运行容器是,可以添加-e参数为容器设置环境变量。在配置环境变量时,也可以和-p参数一样同时设置多个-e参数。
参数配置完成后,进入容器使用echo命令输出设置的环境变量。验证-e参数的使用。
docker run -it --name env1 -e ECHO=环境变量 -e NUM=123456 busybox
echo $ECHO $NUM exit
- 容器文件复制
容器中的另一个存储方式是使用docker cp命令,在宿主机和容器之间进行文件的复制。在文件复制时容器中文件的描述方式为,容器名:容器文件路径。
我们在宿主机中通过echo命令创建文件local.txt。然后创建容器file1,接下来通过docker cp复制到容器中。最后在容器中通过cat命令显示文件命令。
echo 本机生成的文件 > local.txt docker run -itd --name file1 busybox docker cp local.txt file1:/local.txt docker exec file1 cat local.txt
- 文件的挂载
除了使用docker cp文件复制的办法之外,我们还可以在创建容器的时候使用-v参数将宿主机中的文件直接挂在到容器中。该参数的用法为-v 宿主机文件的绝对路径:容器文件的绝对路径。相比较docker cp这种办法的优势是可以在一条命令中完成容器的配置。
docker run -itd --name file2 -v $(pwd)/local.txt:/mount.txt busybox docker exec file2 cat mount.txt
3. MYSQL镜像的基本用法
在上一个步骤中,我们讲解了容器的管理和存储的基本用法。接下来我们用一个MySQL容器来演示这些用法的具体实战。为了实验演示,我们先来学习一下MySQL容器的基本用法。
传统启动MySQL服务的方式,是在操作系统中安装MySQL的服务,并且通过systemctl命令进行启动,但是这种方式需要在系统目录中复制相应的文件,同时向系统中注册服务。这样的流程不但复杂,一旦服务的文件或者配置被破坏或者篡改会导致服务不可用,且难以定位问题。
因此在使用了Docker之后,我们可以从官方仓库中下载已经配置好的MySQL容器镜像。然后直接通过镜像的方式启动服务。这样做不会再宿主机的系统中保存任何文件和配置。服务的稳定性大大提高。
- MySQL容器的启动配置
在本实验中我们使用mysql容器的8.0版本进行实验。我们来看一下MySQL容器镜像的启动配置方式,MySQL数据开是通过网络对外提供服务得,当服务启动后,默认会打开并监听3306端口,用来接受客户端得各种命令。
在这里我们使用默认得Bridge网络模型,同时使用-p参数设置端口映射,将MySQL得服务暴露到宿主机得网卡上。
除此之外在启动MySQL容器得时候,我们还可以通过设置MYSQL_ROOT_PASSWORD环境变量得方式,设置MySQL中root用户得初始化密码。这里我们使用-e参数来设置。
在配置好启动命令之后,我们启动容器,并且使用bash登录到容器中,验证环境变量得配置成功。
docker pull mysql:8.0 docker run -itd --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=[MYSQL密码] mysql:8.0 docker exec -it mysql bin/bash
echo $MYSQL_ROOT_PASSWORD exit
- 进入MySQL服务的控制台
MySQL服务启动后,我们可以使用mysql命令登录服务得控制台,该命令的用法为mysql -u用户名 -p,其中-p表示登录账户需要密码。命令执行后输入在上一个步骤中设置的密码即可进入控制台。
docker exec -it mysql mysql -uroot -p [输入MYSQL密码]
- MySQ控制台验证命令
在MySQL控制台中,我们可以使用status命令查看服务的运行状态,使用show Database;查看服务中的数据库,也可以使用help命令查看其他命令的用法。
status show Databases; help exit
4. 复制修改MYSQL配置文件
在MySQL容器中,环境变量只能对一些简单的属性进行配置,实际上大多数属性都是通过位于/etc/mysql/my.cnf的配置文件进行管理的。接下来我们来学习如何使用文件复制的方式进行配置管理。
- 查看MySQL配置属性值
在MySQL服务中包含了大量的属性值,这些属性值影响服务的运行状态。如果希望修改属性值,就需要修改my.cnf配置文件。在本次实验中,我们使用一个对服务影响不大的属性general_log来演示配置文件的用法。
首先我们先进入控制台,然后使用show variables命令查看设置前的属性值。可以发现属性值现在为OFF。
docker exec -it mysql mysql -uroot -p[MYSQL密码] show variables like 'general_log'; exit
- 复制修改配置文件
如果单纯的为了修改配置,我们可以直接在容器中修改配置文件。但是为了防止容器被删除或者被破坏时,修改好的配置文件丢失,我们先使用docker cp将配置文件复制到宿主机中的/root/mysql/config/目录中作为副本。
mkdir -p /root/mysql/config/ docker cp mysql:/etc/my.cnf /root/mysql/config/my.cnf cat /root/mysql/config/my.cnf
- 当配置文件复制完毕后,我们使用vi编辑该文件,在[mysqld]段落的末尾添加如下内容,修改后的段落如下。
- 输入/secure-file-priv按回车可快速定位,修改secure-file-priv的值为NULL。
- 添加general_log = 1
- 需要先按i键进入编辑模式。
- 编辑完成之后按esc退出编辑模式。
- 然后按大写的ZZ保存并退出vim。
vi /root/mysql/config/my.cnf
general_log = 1
5. 挂载MYSQL配置文件
在上一步我们完成了配置文件的复制和修改,接下来我们来将配置文件应用到容器服务中
- 应用配置文件
我们将配置文件复制回容器中,为了让配置文件生效,我们需要使用docker restart命令重新启动容器。
docker cp /root/mysql/config/my.cnf mysql:/etc/my.cnf docker restart mysql
- 查看配置结果
容器重启之后,我们再次进入控制台查看属性值,会发现新的属性值已经生效。
docker exec -it mysql mysql -uroot -p [MYSQL密码] show variables like 'general_log'; exit
- 挂载方式应用配置文件
在上面的步骤中,我们演示了使用docker cp复制修改MySQL配置文件的方式。这种方式需要先修改配置文件,然后重启服务。步骤比较繁琐。除此之外,我们还可以使用-v参数,在容器创建时,就将配置文件挂载到容器中。
需要注意的时,如果使用-v参数挂载宿主机文件时,容器的挂载位置已经有文件存在,曾宿主机中的文件会覆盖容器中的文件。
容器创建成功后,我们查询MySQL属性,会发现新的属性值已经生效。由此可见这种文件挂载的方式明显比文件复制的方式要简便高效。
docker run -itd --name mysql-mount -e MYSQL_ROOT_PASSWORD=[MYSQL密码] -v /root/mysql/config/my.cnf:/etc/my.cnf mysql:8.0 docker exec -it mysql-mount mysql -uroot -p [MYSQL密码] show variables like 'general_log'; exit
实验地址:https://developer.aliyun.com/adc/scenario/f9384030b533400c94a363495400ba40