Docker入门

Docker是一个开源的应用容器引擎,让开发者打包他们的应用以及依赖包到一个轻量级的/可移植的容器中,然后发布到任何流行的Linux机器上.

基于CentOS7安装Docker

  • yum包更新的最新
    • yum update
  • 安装需要的软件包,yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的
    • yum install -y yum-utils device-mapper-persistent-data lvm2
  • 设置yum源
    • yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  • 安装docker,输入y
    • yum install -y docker-ce
  • 检验是否安装成功
    • docker -v

Docker架构
镜像(Image)
容器(Container)
仓库(Repository)

仓库里存储各个镜像,根据镜像生成容器

配置阿里云镜像加速器:控制台–>容器镜像服务
阿里云镜像加速器入口
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Docker命令

服务相关

  • systemctl start docker 启动docker服务
  • systemctl stop docker 停止
  • systemctl restart docker 重启
  • systemctl status docker 查看状态
  • systemctl enable docker 开机启动

镜像相关

  • docker images 查看本地的镜像
  • docker search name 搜索指定的镜像
  • docker pull name 下载默认版本的镜像
    docker pull name:版本号 下载指定版本的镜像
  • docker rmi name:版本号 删除指定版本的镜像

容器相关

  • docker ps 查看正在运行的容器
    docker ps -a 查看所有容器

  • docker run -it --name=c1 redis:5.0 创建容器 (参数i:让容器一 直运行,t创建终端)

  • docker exec -it name bash 进入容器

  • docker stop name 停止容器

  • docker start name 启动容器

  • docker rm name 删除容器

  • docker inspect name 查看容器信息

Docker容器的数据卷
数据卷是宿主机之中的一个目录或者文件

  • Docker容器删除后,容器中的数据也会删除吗?
    不会,数据保存在数据卷,挂载在容器
  • Docker和外部机器可以直接交换数据吗?
    不可以直接交换,间接通过数据卷
  • 容器之间想要进行数据交互?
    通过挂载数据卷进行交互

容器和数据卷绑定之后,修改会立即同步.一个数据卷可以被多个容器挂载,一个容器也可以挂载多个数据卷.

配置数据卷

  • 创建启动容器时使用 -v参数设置数据卷
    docker run … -v 宿主机目录(文件):容器目录(文件)…
    注意: 目录必须是绝对路径,可以挂载多个数据卷,目录不存在会自动创建

    数据卷容器
    docker run -it --name c3 --volumes-from c2 centos:7

    容器转镜像
    docker commit 容器id 镜像名称:版本号
    镜像转为压缩文件
    docker save -o 压缩文件名称 镜像名称:版本号
    压缩文件转为镜像
    docker load -i 压缩文件名称

DockerFile概念

  • Dockerfile是一个文本文件
  • 包含了一条条指令
  • 每一条指令构建一层,基于基础镜像,最终构建出一个新的镜像
  • 为开发团队提供一个完全一致的开发环境
关键字作用备注
FROM指定父镜像指定dockerfile基于那个image构建
MAINTAINER作者信息用来标明这个dockerfile谁写的
LABEL标签用来标明dockerfile的标签 可以使用Label代替Maintainer 最终都是在docker image基本信息中可以查看
RUN执行命令执行一段命令 默认是/bin/sh 格式: RUN command 或者 RUN [“command” , “param1”,“param2”]
CMD容器启动命令提供启动容器时候的默认命令 和ENTRYPOINT配合使用.格式 CMD command param1 param2 或者 CMD [“command” , “param1”,“param2”]
ENTRYPOINT入口一般在制作一些执行就关闭的容器中会使用
COPY复制文件build的时候复制文件到image中
ADD添加文件build的时候添加文件到image中 不仅仅局限于当前build上下文 可以来源于远程服务
ENV环境变量指定build时候的环境变量 可以在启动的容器的时候 通过-e覆盖 格式ENV name=value
ARG构建参数构建参数 只在构建的时候使用的参数 如果有ENV 那么ENV的相同名字的值始终覆盖arg的参数
VOLUME定义外部可以挂载的数据卷指定build的image那些目录可以启动的时候挂载到文件系统中 启动容器的时候使用 -v 绑定 格式 VOLUME [“目录”]
EXPOSE暴露端口定义容器运行的时候监听的端口 启动容器的使用-p来绑定暴露端口 格式: EXPOSE 8080 或者 EXPOSE 8080/udp
WORKDIR工作目录指定容器内部的工作目录 如果没有创建则自动创建 如果指定/ 使用的是绝对地址 如果不是/开头那么是在上一条workdir的路径的相对路径
USER指定执行用户指定build或者启动的时候 用户 在RUN CMD ENTRYPONT执行的时候的用户
HEALTHCHECK健康检查指定监测当前容器的健康监测的命令 基本上没用 因为很多时候 应用本身有健康监测机制
ONBUILD触发器当存在ONBUILD关键字的镜像作为基础镜像的时候 当执行FROM完成之后 会执行 ONBUILD的命令 但是不影响当前镜像 用处也不怎么大
STOPSIGNAL发送信号量到宿主机该STOPSIGNAL指令设置将发送到容器的系统调用信号以退出。
SHELL指定执行脚本的shell指定RUN CMD ENTRYPOINT 执行命令的时候 使用的shell

案例
自定义Centos7

  • 默认登陆路径为/usr

  • 可以 使用vim

  • 创建DockerFile文件,编写指令
    在这里插入图片描述

  • 根据文件创建镜像
    docker build -f ./dockerfile -t capgemini_centos:1.0 .

    • -f 代表file文件
    • -t 设置新的镜像名称,版本
    • . 代表一个路径

在这里插入图片描述
Docker部署一个SpringBoot项目
在这里插入图片描述
生成镜像
docker build -f ./springbootfile -t app:1.0 .
在这里插入图片描述
外部访问,部署成功
在这里插入图片描述
Docker服务编排
按照一定的业务规则批量管理容器
Docker Compose
是一个编排多容器分布式部署的工具
步骤:

  • 使用DockerFile定义运行环境镜像

  • 使用docker-compose.yml定义组成应用的各服务
    在这里插入图片描述

  • 运行docker-compose up 启动应用
    安装

  • 以编译好的二进制包方式安装在Linux系统中

    • curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-uname -s-uname -m -o /usr/local/bin/docker-compose
  • 设置文件可执行权限

    • chmod +x /usr/local/bin/docker-compose
  • 查看版本信息

    • docker-compose -version
      卸载DockerCompose
      二进制包方式安装的,删除二进制文件即可
      rm /usr/local/bin/docker-compose

使用SpringBoot+MySQL

  1. 创建docker-compose目录 mkdir docker-compose
    进入 cd docker-compose
  2. 编写docker-compose.yml文件
    vi dokcer-compose
version: '3'         #版本
services:
  app:
    image: app:1.0       #镜像名称及版本
    expose:              #暴露端口
      - "9020"
  mysql:
   image: mysql:8.0
   container_name: cmysql          #创建的容器名称
   restart: always
   ports :
     - "3306:3306"
   environment:                   #环境参数
     - MYSQL_ROOT_PASSWORD=123456
     - MYSQL_DATABASE=saas
     - MYSQL_ROOT_HOST=% 
  1. 运行docker-compose up 启动应用
  • 测试成功连接数据库,成功启动springboot项目
    在这里插入图片描述
    在这里插入图片描述

Docker私有仓库

  • 搭建私有仓库
    1. 拉取私有仓库镜像 docker pull registry
    2. 启动私有仓库容器 docker run -id --name=registry -p 5000:5000 registry
    3. 打开浏览器 输入地址http://私有仓库服务器ip:5000/v2/_catalog,看到{“repositories”:[]} 表示私有仓库 搭建成功
    4. 修改daemon.json
      vi /etc/docker/daemon.json 在上述文件中添加一个key,保存退出。此步用于让 docker 信任私有仓库地址;注意将私有仓库服务器ip修改为自己私有仓库服务器真实ip
      {“insecure-registries”:[“私有仓库服务器ip:5000”]}
    5. 重启docker服务
      systemctl restart docker
      docker start regist
  • 上传镜像到私有仓库
    1. 标记镜像为私有仓库的镜像
    docker tag centos:7 192.168.206.101:5000/centos:7
    2. 上传标记的镜像
    docker push 192.168.206.101:5000/centos:7
    在这里插入图片描述
    查看,上传至私有仓库成功
    在这里插入图片描述
  • 从私有仓库拉取镜像
    docker pull 192.168.206.101:5000/centos:7
    在这里插入图片描述
    关于搭建私有仓库修改daemon.json后,docker启动失败
    检查内核版本无误
    在这里插入图片描述
    原因是daemon.json文件里内容格式错误,或者有中文标点字符
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值