zoukankan      html  css  js  c++  java
  • 第2次实践作业

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

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

    (1)获取nginx镜像pull nginx
    sudo docker pull nginx
    




    (2)编写Dockerfile、 default.conf和index.html文件

    新建一个目录专门存放这三个文件

    vim Dockerfile
    vim default.conf
    vim index.html
    

    ①Dockerfile文件

    在同一个目录文件下,编写Dockerfile文件(不是dockerfile)

    FROM nginx
    MAINTAINER y00
    RUN apt-get update && apt-get install -y nginx vim net-tools
    COPY default.conf /etc/nginx/conf.d/
    COPY index.html /home/y00/docker1/
    WORKDIR /home/y00/docker1/
    EXPOSE 8000
    

    ②default.conf文件

    将listen 端口改为8000

    ③index.html文件

    (3)构建镜像

    sudo docker build -t y00nginx:1.0 .
    

    构建成功

    (4)运行并进入容器测试

    sudo docker run --name y00nginx -d -p 8081:8000 y00nginx:1.0
    



    查看网络配置

    浏览器测试

    (5)遇到的错误

    原本在Dockerfile中设定需要安装apt-utils,由于网络问题没下载下来。。。

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

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

    (1)pull mysql 5.7

    sudo docker pull mysql:5.7
    

    (2)编写Dockerfile、privileges.sql、setup.sh、schema.sql

    同样新建一个文件夹存放着四个文件

    ①Dockerfile文件

    #设置基础镜像信息
    FROM mysql:5.7
    
    #镜像作者信息
    MAINTAINER y00mysql
    
    #设置免密登录
    ENV MYSQL_ALLOW_EMPTY_PASSWORD no
    ENV MYSQL_ROOT_PASSWORD=123456
    
    #将所需文件放到容器中
    COPY setup.sh /home/y00/docker2/setup.sh
    COPY schema.sql /home/y00/docker2/schema.sql
    COPY privileges.sql /home/y00/docker2/privileges.sql
    
    #设置容器启动时执行的命令
    CMD ["sh", "/mysql/setup.sh"]
     
    

    ②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 < /home/y00/docker2/schema.sql
    echo '3.导入数据完毕....'
    
    sleep 3
    echo `service mysql status`
    
    #重新设置mysql密码
    echo '4.开始修改密码....'
    mysql < /home/y00/docker2/privileges.sql
    echo '5.修改密码完毕....'
    
    #sleep 3
    echo `service mysql status`
    echo 'mysql容器启动完毕,且数据导入成功'
    
    tail -f /dev/null
    

    ③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` bigint(20) NOT NULL,
      `email` varchar(255) DEFAULT NULL,
      `username` varchar(255) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
    
    -- 插入数据
    INSERT INTO `user` (`id`,  `email`,  `username`)
    VALUES
    	(0,'john.doe@example.com','user');
    

    ④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;
    

    (3)构建镜像

    sudo docker build -t y00mysql .
    

    (4)运行并进入容器测试

    sudo docker run --name mysql1 -p 3306:3306 -d y00mysql
    

    容器内启动mysql

    查看user表

    查看数据库

    查看容器启动日志

    查看配置情况

    遇到的错误

    依照提示在命令后加上-A就不会出现警告了


    漏掉分号不能出结果,加上就好了

    三、小结

    在遇到错误的时候先看报错再看日志文件(使用docker logs xxx查看程序输出的错误信息)能比较快找到错误,构建镜像的时候RUN写在一行,可以减少镜像的层数,指定挂载的卷。由于这次实验做得比较晚,参考了很多博客和其他同学的做法,所以基本没怎么出错。

  • 相关阅读:
    legend2---开发日志12(vue如何进一步学习)
    为什么现在的年轻人生育的欲望越来越低?(转自知乎)
    legend2---开发日志13(layer_mobile的content传入dom 出现【object object】如何解决)
    legend2---项目总结(legend2的意义)
    legend2---开发日志11(如何提高终极开发效率)
    公司项目架构的演变过程(转)
    创业公司如何实施敏捷开发(敏捷开发简单流程)(转)
    创业公司一年工作总结(转)(公司失败原因)
    LayaAir引擎开发HTML5最简单教程(面向JS开发者)
    [ACM] HDU 2295 Radar (二分法+DLX 重复覆盖)
  • 原文地址:https://www.cnblogs.com/YU0000/p/12766661.html
Copyright © 2011-2022 走看看