2020系统综合实践 第二次实践作业

一.实现一个自定义的web容器服务

要求标明镜像作者信息,安装必要的工具以方便维护;设定你自己的web存放目录,安全起见,请将默认的监听端口80更改为你自定义的端口,并且声明暴露的端口,容器启动时,能直接进入web代码的存放目录。

(1)从 docker hub拉取nginx作为基础镜像

sudo docker pull nginx

(2)创建一个容器并运行

执行pwd命令,可以查看工作目录在根目录下

sudo docker run -it nginx /bin/bash
pwd

(3)复制运行中nginx容器的配置文件,为后续修改监听端口备用

sudo docker cp <容器ID>:/etc/nginx/conf.d/default.conf .

也可以设置第二个参数指定复制到宿主机的目录

sudo docker cp <容器ID>:路径/文件 本地路径

可以看到宿主机根目录下已经出现了default.confw文件

使用 vim default.conf 指令来修改监听端口和默认的工作目录

(4)编写dockerfile文件

(5)build dockerfile

sudo docker build -f dockerfile -t mynginx:test .

注意 配置文件要和 dockerfile文件放到同一目录下,出现success则表示build成功

(6)创建容器并映射主机端口

sudo docker run -p 8000:2020 -t mynginx:test /bin/bash

可以看到此时容器的工作目录变为自定义的web

查看容器端口的映射

(7)打开浏览器访问:localhost:8000

二.实现一个自定义的数据库容器服务

要求标明镜像作者信息,为了方便维护,需要能够查看容器内的配置信息,包括但不限于网络、应用配置文件等。在环境变量中设置好数据库的root密码且不允许空密码登录,创建一个测试数据库,指定用户名和密码。

(1)创建并mysql文件夹

mkdir ~/mysql
cd ~/mysql

(2)使用vim指令编辑dockerfile文件

vim dockerfile
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)使用vim指令编写容器启动脚本setup.sh

vim setup.sh
#!/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

(3)使用vim指令编写导入数据的mysql脚本命令schema.sql:

vim schema.sql
-- 创建数据库
create database `docker_mysql` default character set utf8 collate utf8_general_ci;
 
use docker_mysql;
 
-- 建表
DROP TABLE IF EXISTS test;
 
CREATE TABLE test (
 `id` bigint(20) NOT NULL,
 `name` varchar(255) DEFAULT ""
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
 
-- 插入数据
INSERT INTO test (`id`, `name`)
VALUES
  (2020,'monster');

(4)使用vim指令编写权限设置命令privileges.sql

vim privileges.sql
use mysql;
select host, user from user;
-- 新建用户为如下命令:
create user docker identified by '123456';
-- 将docker_mysql数据库的权限授权给创建的docker用户,密码为123456:
grant all on docker_mysql.* to [email protected]'%' identified by '123456' with grant option;
-- use privileges
flush privileges;

(5)build dockerfile

sudo docker build -t mysql:test

(6)创建并运行容器,查看容器状态

sudo docker run -d -p 13306:3306 mysql:test
sudo docker ps -a

(7)进入容器的shell终端,使用用户账号输入密码后进入mysql,使用docker_mysql数据库

sudo docker exec -it <容器ID> /bin/bash
mysql -u docker -p
use docker_mysql

(8)查看tableb表,且用select指令查看测试数据

show table;
select * from test
;

总结

过程一度十分艰难;实践一的问题主要在于端口号的映射;从正在运行的容器里面复制配置文件到宿主机;实践二的问题在于编写的setup.sh不适合docker hub最新版mysql的配置,只能使用mysql5.7的版本。

来源:https://www.cnblogs.com/ljw1999/p/12739761.html