当前位置 博文首页 > 文章内容

    iMessages丶的博客:Dockerfile,DockerCompose学习笔记(进阶篇)

    作者:shunshunshun18 栏目:未分类 时间:2021-12-02 22:42:31

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



    容器数据卷

    将应用和环境打包成一个镜像!
    数据?如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化
    MySQL,容器删除了,删库跑路!需求:MySQL数据可以存储在本地!
    容器之间可以有一个数据共享技术!Docker容器中产生的数据,同步到本地!
    这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linux上面!

    ![此处输入图片的描述][2]

    三种挂载: 匿名挂载、具名挂载、指定路径挂载

    -v 容器内路径 #匿名挂载
    -v 卷名:容器内路径 #具名挂载
    -v /宿主机路径:容器内路径 #指定路径挂载 docker volume ls 是查看不到的

    docker run -it -v 主机目录:容器内目录  -p 主机端口:容器内端口
    
    例:
    # 获取mysql镜像
    [root@iz2zeak7sgj6i7hrb2g862z home]# docker pull mysql:5.7
    
    # 运行容器,需要做数据挂载 #安装启动mysql,需要配置密码的,这是要注意点!
    # 参考官网hub 
    docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
    
    #启动我们得
    -d 后台运行
    -p 端口映射
    -v 卷挂载
    -e 环境配置
    -- name 容器名字
    docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql03 mysql:5.7
    
    # 启动成功之后,我们在本地使用sqlyog来测试一下
    # sqlyog-连接到服务器的3306--和容器内的3306映射 
    
    # 在本地测试创建一个数据库,查看一下我们映射的路径是否ok!
    

    Dockerfile

    Dockerfile 就是用来构建docker镜像的构建文件!命令脚本!
    通过这个脚本可以生成镜像,镜像是一层一层的,脚本是一个个的命令,每个命令都是一层!

    • 编写一个dockerfile文件

    规则
    1、每个保留关键字(指令)都是必须是大写字母
    2、执行从上到下顺序
    3、#表示注释
    4、每一个指令都会创建提交一个新的镜像曾,并提交!

    # 创建一个dockerfile文件,名字可以随便 建议Dockerfile
    # 文件中的内容: 指令(大写) + 参数
    $ vim dockerfile1
        FROM centos 					# 当前这个镜像是以centos为基础的
        VOLUME ["volume01","volume02"] 	# 挂载卷的卷目录列表(多个目录)
        CMD echo "-----end-----"		# 输出一下用于测试
        CMD /bin/bash					# 默认走bash控制台
    
    # 这里的每个命令,就是镜像的一层!
    # 构建出这个镜像 
    -f dockerfile1 			# f代表file,指这个当前文件的地址(这里是当前目录下的dockerfile1)
    -t caoshipeng/centos 	# t就代表target,指目标目录(注意caoshipeng镜像名前不能加斜杠‘/’)
    . 						# 表示生成在当前目录下
    
    • docker build 构建称为一个镜像
    $ docker build -f dockerfile1 -t caoshipeng/centos .
    Sending build context to Docker daemon   2.56kB
    Step 1/4 : FROM centos
    latest: Pulling from library/centos
    8a29a15cefae: Already exists 
    Digest: sha256:fe8d824220415eed5477b63addf40fb06c3b049404242b31982106ac204f6700
    Status: Downloaded newer image for centos:latest
     ---> 470671670cac
    Step 2/4 : VOLUME ["volume01","volume02"] 			# 卷名列表
     ---> Running in c18eefc2c233
    Removing intermediate container c18eefc2c233
     ---> 623ae1d40fb8
    Step 3/4 : CMD echo "-----end-----"					# 输出 脚本命令
     ---> Running in 70e403669f3c
    Removing intermediate container 70e403669f3c
     ---> 0eba1989c4e6
    Step 4/4 : CMD /bin/bash
     ---> Running in 4342feb3a05b
    Removing intermediate container 4342feb3a05b
     ---> f4a6b0d4d948
    Successfully built f4a6b0d4d948
    Successfully tagged caoshipeng/centos:latest
    
    # 查看自己构建的镜像
    $ docker images
    REPOSITORY          TAG          IMAGE ID            CREATED              SIZE
    caoshipeng/centos   latest       f4a6b0d4d948        About a minute ago   237MB
    
    • docker run运行镜像
      运行自己的镜像 略…

    • docker push发布镜像(DockerHub 、阿里云仓库)

    1、地址 https://hub.docker.com/
    2、确定这个账号可以登录
    3、登录
    
    $ docker login --help
    Usage:  docker login [OPTIONS] [SERVER]
    
    Options:
      -p, --password string   Password
          --password-stdin    Take the password from stdin
      -u, --username string   Username
    
    $ docker login -u 你的用户名 -p 你的密码
    
    # push不上去,因为如果没有前缀的话默认是push到 官方的library
    # 解决方法:
    # 第一种 build的时候添加你的dockerhub用户名,然后在push就可以放到自己的仓库了
    $ docker build -t kuangshen/mytomcat:0.1 .
    
    # 第二种 使用docker tag #然后再次push
    $ docker tag 容器id kuangshen/mytomcat:1.0 #然后再次push
    $ docker push kuangshen/mytomcat:1.0
    

    发布到 阿里云镜像服务上
    看官网 很详细https://cr.console.aliyun.com/repository/

    docker tag [ImageId] registry.cn-shenzhen.aliyuncs.com/dsadxzc/cheng:[镜像版本号]
    docker login --username=zchengx registry.cn-shenzhen.aliyuncs.com
    
    # 修改id 和 版本
    docker tag a5ef1f32aaae registry.cn-shenzhen.aliyuncs.com/dsadxzc/cheng:1.0
    # 修改版本
    docker push registry.cn-shenzhen.aliyuncs.com/dsadxzc/cheng:[镜像版本号]
    

    ![此处输入图片的描述][3]

    DockerFile的指令

    FROM				# from:基础镜像,一切从这里开始构建
    MAINTAINER			# maintainer:镜像是谁写的, 姓名+邮箱
    RUN					# run:镜像构建的时候需要运行的命令
    ADD					# add:步骤,tomcat镜像,这个tomcat压缩包!添加内容 添加同目录
    WORKDIR				# workdir:镜像的工作目录
    VOLUME				# volume:挂载的目录
    EXPOSE				# expose:保留端口配置
    CMD					# cmd:指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
    ENTRYPOINT			# entrypoint:指定这个容器启动的时候要运行的命令,可以追加命令
    ONBUILD				# onbuild:当构建一个被继承DockerFile这个时候就会运行onbuild的指令,触发指令
    COPY				# copy:类似ADD,将我们文件拷贝到镜像中
    ENV					# env:构建的时候设置环境变量!
    

    ![此处输入图片的描述][4]
    ![此处输入图片的描述][5]

    DockerCompose

    Docker Compose是一个用来定义和运行复杂应用的Docker工具。一个使用Docker容器的应用,通常由多个容器组成。使用Docker Compose不再需要使用shell脚本来启动容器。
    Compose 通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。

    下载地址: curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
    添加操作权限:chmod +x /usr/local/bin/docker-compose
    查看:docker-compose --version
    安装pip: sudo pip install docker-compose
    

    DockerCompose指令

    version   指定本 yml 依从的 compose 哪个版本制定的
    
    build
        	  指定为构建镜像上下文路径
        		context:上下文路径。
        		dockerfile:指定构建镜像的 Dockerfile 文件名。
        		args:添加构建参数,这是只能在构建过程中访问的环境变量。
        		labels:设置构建镜像的标签。
        		target:多层构建,可以指定构建哪一层。
        		
    command         覆盖容器启动的默认命令。
    
    container_name  指定自定义容器名称,而不是生成的默认名称。
    
    environment     添加环境变量。
    
    expose          暴露端口,但不映射到宿主机,只被连接的服务访问。
    
    image           指定容器运行的镜像。
    
    restart
    		no:是默认的重启策略,在任何情况下都不会重启容器。
    		always:容器总是重新启动。
    		on-failure:在容器非正常退出时(退出状态非0),才会重启容器。
            unless-stopped:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器
    

    DockerCompose命令

    	docker-compose up //启动yml文件定义的 container
    	docker-compose up -d //后台运行
    	docker-compose up --help //查看up帮助
    	docker-compose -f docker-compose.yml up //-f 指定yml文件
    	docker-compose stop //停止
    	docker-compose start 
    	docker-compose ls  //查看
    	docker-compose down //停止删除
    	docker-compose ps
    	docker-compose images
    	docker-compose exec {service_name} {bash}
    
    

    待完善…

    cs