zoukankan      html  css  js  c++  java
  • 第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的试试,终于成功了

  • 相关阅读:
    Linux crontab 命令
    tcpdump抓包工具
    tcpdump过滤某个端口
    ARM处理器基础Cortex-M4
    rtems floating poing switch
    ARM处理器的堆栈和函数调用,以及与Sparc的比较
    关于调用堆栈,任务堆栈
    如何测试嵌入式处理器的CPU使用率
    关于嵌入式实时操作系统的实时性
    RTEMS API
  • 原文地址:https://www.cnblogs.com/Linrrui/p/12764057.html
Copyright © 2011-2022 走看看