第2次实践作业

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

好多未知错误要百度啊,又是一门百度嵌入式学科^^_

1.1从 docker hub拉取nginx作为基础镜像

sudo docker pull nginx

1.2创建一个容器并运行

sudo docker run -it nginx /bin/bash

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

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

在主目录下可以看见配置文件

用vim修改配置文件,以及编写dockerfile

1.4build dockerfile

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

出现success则为build成功

1.5创建容器并映射主机端口

sudo docker run -p 8000:1106 -d mynginx:test

打开浏览器访问localhost:8000

打开浏览器,出现之前编写的html内容

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

2.1创建并mysql文件夹

mkdir ~/mysql
cd ~/mysql

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

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

2.4使用vim指令编写导入数据的mysql脚本命令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
(1106,'zyj');

2.5使用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 docker@'%' identified by '123456' with grant option;
-- use privileges
flush privileges;

2.6build dockerfile

sudo docker build -t mysql:test

2.7创建并运行容器,查看容器状态

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

2.8进入容器的shell终端,使用用户账号输入密码后进入mysql,使用docker_mysql数据库,并查看table表,使用select指令

sudo docker exec -it <容器ID> /bin/bash
mysql -u docker -p
use docker_mysql
show table;
select * from test;

3.总结

这次过程中有个指令使用错误导致一直无法访问到localhost:8000,sudo docker run -p 8000:1106 -d mynginx:test
指令-d 用成了指令 -t所以无法访问到。

posted @ 2020-04-23 15:48  夜色怡人、  阅读(175)  评论(0编辑  收藏  举报