Docker学习1

313 阅读8分钟

Docker是什么

为什么会有docker出现

  • 将跑通过的源码+配置+环境+版本打包形成一个镜像文件,达到应用程序跨平台间的无缝接轨运作。
  • 比喻的话就是从搬家到搬楼。

docker理念

  • 一次镜像,处处运行。

一句话

  • 解决了运行环境和配置问题的软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术。

容器与虚拟机比较

  • 传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程;
  • 容器内的应用进程直接运行于宿主的内核,容器没有自己的内核且也没有进行硬件虚拟。因此容器要比传统虚拟机更为轻便。
  • 每个容器之间互相隔离,每个容器有自己的文件系统,容器之间进程不会相互影响,能区分计算资源。

能干嘛

  • 更快速的应用交付和部署
  • 更便捷的升级和扩缩容
  • 更简单的系统运维
  • 更高效的计算资源利用
  • 集装箱运输货物,Docker运输软件。

Docker的基本组成

镜像(image)

  • 只读模板

容器(container)

  • 实例 容器是用镜像创建的运行实例 可以把容器看作是一个简易版的Linux环境和运行在其中的应用程序

仓库(repository)

  • 集中存放镜像文件的场所
  • 类似Maven仓库 存放各种jar包的地方
  • github仓库 存放各种git项目的地方
  • Docker公司提供的官方registry被称为Docker Hub,存放各种镜像模板的地方。

安装Docker

1. 用vagrant软件创建centos7并用VirtualBox软件运行centos7

image.png

image.png

image.png

image.png

2. linux安装docker

Install Docker Engine on CentOS | Docker Documentation

  • 启动docker并查看版本

    image.png

  • 使docker开机自动启动并查看镜像 image.png

3. 配置docker阿里云镜像加速

image.png

Docker命令

Docker服务相关命令

启动docker服务

systemctl start docker

停止docker服务

systemctl stop docker

重启docker服务

systemctl restart docker

查看docker服务状态

systemctl status docker

image.png

设置开机启动docker服务

systemctl enable docker

image.png

Docker镜像相关命令

查看本地所有的镜像

docker images
docker images –q # 查看所用镜像的id

image.png

从网络中查找需要的镜像

docker search 镜像名称

image.png

从Docker仓库下载镜像到本地,镜像名称格式为 名称:版本号,如果版本号不指定则是最新的版本。

docker pull 镜像名称

image.png

删除本地镜像

docker rmi 镜像id # 删除指定本地镜像
docker rmi `docker images -q` # 删除所有本地镜像

image.png

Docker容器相关命令

查看容器

docker ps # 查看正在运行的容器 
docker ps –a # 查看所有容器

image.png

创建并启动容器

docker run 参数

参数说明:

  • -i:保持容器运行。通常与 -t 同时使用。加入it 这两个参数后,容器创建后自动进入容器中,退出容器后,容器自动关闭。
  • -t:为容器重新分配一个伪输入终端,通常与 -i 同时使用。
  • -d:以守护(后台)模式运行容器。创建一个容器在后台运行,需要使用docker exec 进入容器。退出后,容器不会关闭。
  • -it 创建的容器一般称为交互式容器,-id 创建的容器一般称为守护式容器
  • --name:为创建的容器命名。

image.png

image.png

进入容器

docker exec 参数 

image.png

停止容器

docker stop 容器名称

image.png

启动容器

docker start 容器名称

image.png

删除容器

docker rm 容器名称

image.png

  • 不能删除正在运行的容器

查看容器信息

docker inspect 容器名称

image.png

Docker容器的数据卷

概念

  • 数据卷是宿主机中的一个目录或文件
  • 当容器目录和数据卷目录绑定后,对方的修改会立即同步,类似于绑定了快捷方式。
  • 一个数据卷可以被多个容器同时挂载
  • 一个容器也可以被挂载多个数据卷

作用

  • 容器数据持久化
  • 外部机器和容器间接通信
  • 容器之间数据交换

配置数据卷

  • 创建启动容器时,使用-v参数 设置数据卷
docker run ... –v 宿主机目录(文件):容器内目录(文件) ...
  • 观察到容器创建的目录

image.png

  • 观察到宿主机创建的数据卷

image.png

  • 在宿主机data目录下创建文件

image.png

  • 观察容器内的同步情况

image.png

  • 在容器内修改文件

image.png

  • 观察宿主机内同步情况

image.png

  • 删除容器

image.png

  • 宿主机数据卷仍存在

image.png

  • 重新创建容器并挂载实现了数据的持久化

image.png

image.png

  • 一个容器内同步多个数据卷
docker run -it --name=c2 -v ~/data2:/root/data2 -v ~/data3:/root/data3 centos
  • 观察到容器创建的目录

image.png

  • 观察到宿主机创建的数据卷

image.png

容器与容器之间的同步

  • 创建两个容器并挂载到宿主机的同一个文件

image.png

  • 进入其中一个容器的挂载位置并创建文件 image.png
  • 在另一个容器实现了同步

image.png

数据卷容器

image.png

  • 配置数据卷容器
    1. 创建启动c3数据卷容器,使用 –v 参数 设置数据卷
docker run –it --name=c3 –v /volume centos:7 /bin/bash

image.png

  • 2. 创建启动 c1 c2 容器,使用 –-volumes-from 参数 设置数据卷
docker run –it --name=c1 --volumes-from c3 centos:7 /bin/bash 
docker run –it --name=c2 --volumes-from c3 centos:7 /bin/bash

image.png

image.png

  • 在数据卷容器新建文件

image.png

  • 观察到两容器数据同步

image.png image.png

Docker应用部署

MySQL部署

  • 容器内的网络服务和外部机器不能直接通信
  • 外部机器和宿主机可以直接通信
  • 宿主机和容器可以直接通信
  • 当容器中的网络服务需要被外部机器访问时,可以将容器中提供服务的端口映射到宿主机的端口上,外部机器访问宿主机的该端口,从而简介访问容器的服务。
  • 这种操作成为:端口映射

image.png

拉取mysql镜像

docker pull mysql:5.6

image.png

创建容器,设置端口映射、挂载目录

image.png

image.png

  • 参数说明:

    • -p 3307:3306:将容器的 3306 端口映射到宿主机的 3307 端口。
    • -v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
    • -v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
    • -v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
    • -e MYSQL_ROOT_PASSWORD=123456: 初始化 root 用户的密码。
  • 进入MySQL容器

image.png

  • 在外部机器测试连接docker上的mysql容器 image.png

image.png

Tomcat部署

拉取tomcat镜像

image.png

创建容器,设置端口映射、挂载目录

image.png

  • 参数说明:

    • -p 8080:8080: 将容器的8080端口映射到主机的8080端口

      -v $PWD:/usr/local/tomcat/webapps: 将主机中当前目录挂载到容器的webapps

Dockerfile

Docker镜像原理

image.png

image.png

image.png

镜像制作

image.png

由容器创建镜像

  • 在tomcat文件根目录创建shin,并在挂载文件夹创建test image.png
  • 由刚刚修改的容器创建镜像

image.png

压缩镜像

image.png

先删除自己制作的镜像,再还原压缩的镜像

image.png

创建自己制作镜像的容器,观察到挂载文件上的修改没有生效,其他文件上的修改生效

image.png

Dockerfile概念

image.png

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