第2次实践作业

dockerfile的相关知识 https://www.cnblogs.com/edisonchou/p/dockerfile_inside_introduction.html

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

1.拉取nginx镜像并运行

参考

查看是否已安装了 nginx

安装完成后,运行 nginx 容器

可以通过浏览器可以直接访问 8080 端口的 nginx 服务

2.修改nginx配置文件

参考

在目录中找到需要修改的配置文件

这个文件就是要修改的文件,目录为/etc/nginx/conf.d

在本地新建一个目录用来存放nginx配置文件和相关文件

在myweb文件夹里准备一个html文件,文件改名为index.html

在user/nginx目录下编辑dockerfile文件


在user/nginx目录下拷贝需要修改的default.conf文件

修改监听端口和web默认路径

完成以上步骤之后就准备好了一个项目文件夹

在新建自定义镜像前停掉之前的容器

构建自定义镜像

运行容器

在浏览器上访问local:8080,刷新一下

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

参考
在~/usr/目录下新建一个项目文件夹

拉取mysql镜像

编写dockerfile文件

#基础镜像
FROM mysql:5.7

#作者信息
MAINTAINER linui <1215349235@qq.com>

#设置root密码
ENV MYSQL_ROOT_PASSWORD 123

#设置不可免密登录
ENV MYSQL_ALLOW_EMPTY_PASSWORD no

#创建数据库
ENV MYSQL_DATABASE docker_mysql

#为docker_mysql创建新用户,该用户被授予操作docker_mysql的所以权限
ENV MYSQL_USER=docker
ENV MYSQL_PASSWORD=123456

#将所需文件放到容器中
COPY setup.sh /mysql/setup.sh
COPY schema.sql /mysql/schema.sql
COPY privileges.sql /mysql/privileges.sql

#设置容器启动时执行的命令
CMD ["sh", "/mysql/setup.sh"]


编写容器启动脚本setup.sh

#!/bin/bash
set -e

#查看mysql服务的状态,方便调试,这条语句可以删除
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脚本命令schema.sql

-- 创建数据库
create database `docker_mysql` default character set utf8 collate utf8_general_ci;

use docker_mysql;

-- 建表
DROP TABLE IF EXISTS user;

CREATE TABLE user (
  `id` varchar(10) NOT NULL,
  `name` varchar(10) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

-- 插入数据
INSERT INTO user (`id`, `name`)
VALUES
    ('031702504','LinRui');



mysql权限设置命令privileges.sql

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;



创建镜像


运行容器,这里需要注意一个地方就是初始化密码变量前有一个-e 这个参数就是相当于dockerfile中的env


查看容器的日志记录,启动过程与启动脚本setup.sh中所规范的步骤一致,数据导入和权限设置成功:

进入容器

  • 使用docker用户登录数据库:mysql -u docker -p
  • 输入之前设的密码通过登录验证
  • 切换至docker_mysql数据库:use docker_mysql;
  • 查看数据库中的表:show tables;
  • 查看表中的数据:select * from user;
    (注意语句后面的分号)

    查看容器内配置信息

(3)总结

1.刚开始看实验的题目然后去看教程和百度完全不知道要怎么做,而且对于整个dockerfile的理论也不懂,不知道怎么入手,后来看了教程视频才对dockerfile有了些了解,但是做实验的过程还是很艰难,在第一个实验找配置文件所在目录的时候卡了很久,以为配置文件是在本地,用了whereis等命令一直都没有找到,后来看了大佬的博客才发现原来是在容器内,然后被几个文件存放的位置搞得晕头转向,就只能一边尝试一边理解一边痛恨自己怎么这么菜......
2.做完第一个实验之后第二个实验就轻松多了,遇到的问题是容器在创建成功之后就停止了,发现dockerdile文件里面我的mysql是最新的,用docker logs查看日志发现unrecognized service错误,百度了半天无果,后来发现群里的记录,于是把版本改为5.7的试试,终于成功了

posted @ 2020-04-23 22:59  Lrrui  阅读(154)  评论(0编辑  收藏  举报