1、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 https://download.docker.com/linux/centos/docker-ce.repo
安装 docker ,出现输入的界面都按 y
yum install -y docker-ce
查看 docker 版本,验证是否安装成功
docker -v
2、docker 架构
镜像(Image)
:Docker镜像,就相当于一个 root 文件系统,比如官方镜像 ubuntu:16.04 就包含了完整的一套 ubuntu 16.04 最小系统的 root 文件系统。容器(Container)
:镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、暂停等。仓库(Repository)
:仓库可看成一个代码控制中心,用来保存镜像。
3、配置 Docker 镜像加速器
默认情况下,将来从docker.hub(https://hub.docker.com/)上下载 docker 镜像,太慢。一般都会配置镜像加速器。
// ustc:https://docker.mirrors.ustc.edu.cn
// 网易:https://hub-mirror.c.163.com/
// 阿里云:https://<你的ID>.mirror.aliyuncs.com (建议使用,登录阿里云获取)
// 七牛云加速器:https://reg-mirror.qiniu.com
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://<你的ID>.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
4、docker 服务相关命令
启动 docker 服务
systemctl start docker
停止 docker 服务
systemctl stop docker
重启 docker 服务
systemctl restart docker
查看 docker 服务状态
systemctl status docker
开机启动 docker 服务
systemctl enable docker
5、docker 镜像相关命令
查看镜像
docker images
docker images -q (获取全部镜像id)
搜索镜像
docker search [镜像名称,如:redis]
拉取镜像
docker pull [镜像名称,如:redis](部件版本号,默认拉取最新版本。指定版本:Redis:3.0。可在:hub.docker.com/ 查询)
删除镜像
// 删除指定镜像
docker rmi [镜像ID | 镜像名称:tag]
// 删除全部镜像
docker rmi `docker image -q`
6、docker 容器相关命令
查看容器
docker ps // 查看正在运行的容器
docker ps -a // 查看所有容器
创建容器
// 创建并启动容器
docker run [参数]
参数说明:
-i
:保持容器运行,通常与 -t 同时使用。加入 it 这两个参数以后,容器创建后自动进入容器中,退出容器后,容器自动关闭。
-t
:为容器重新分配一个伪输入终端,通常与 -i 同时使用。
-d
:以守护(后台)模式运行容器。创建一个容器在后台运行,需要使用 docker exec 进入容器,退出后,容器不会关闭。
-it
:创建的容器一般称为交互式容器,-id:创建的容器一般称为守护时容器。
--name
:为创建的容器命名
例子,如:
docker run -it --name=c1 centos:7 /bin/bash
i
:一直运行;
t
:分配终端,输入命令;
d
:后台运行创建容器
name
:给容器起名字;
7
:指定的版本;
/bin/bash
:进入容器后的初始化指令
exit
: 退出容器,会关闭容器
进入容器
// 进入已运行的容器 c1
docker exec -it c1 /bin/bash
启动容器
docker start c2
// c2:容器名称
停止容器
docker stop c2
// c2:容器名称
删除容器
docker rm [容器id 或 容器名称]
查看容器信息
docker inspect c2
7、Docker 容器的数据卷
数据卷的概念及作用
思考:
1、Docker 容器删除后,在容器中的数据还在吗?
答:可保存在数据卷中
2、Docker 容器和外部的机器可以直接交换文件吗?
答:不能
3、容器之间想要进行数据交互?
答:可通过数据卷
7.1、数据卷:
- 数据卷是宿主机的一个目录或文件
- 当容器目录和数据卷目录绑定后,对方的修改会立即同步
- 一个数据卷可以被多个容器同时挂载
- 一个容器也可以挂载多个数据卷
7.2、数据卷的作用:
- 容器数据持久化
- 外部机器和容器间接通信
- 容器之间数据交换
7.3、配置数据卷
创建启动容器时,使用 -v
参数设置数据卷
// docker run ... -v 宿主机目录(文件):容器内目录(文件) ...(多个数据卷:多个 -v)
docker run -it --name=c2 -v /root/data:/root/data_container redis:5.0.9 /bin/bash
注意事项:
- 目录必须是绝对路径
- 如果目录不存在,会自动创建
- 可以挂在多个数据卷
7.4、配置数据卷容器
多容器进行数据交互
1、多个容器挂载同一个数据卷
2、数据卷容器
1、创建启动 c3 数据卷容器,使用 -v
参数设置数据卷
docker run -it --name=c3 -v /volume centos:7 /bin/bash
// /volume:容器目录
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