Docker是一个开源的应用容器引擎
诞生于2013年初,基于Go语言实现,dotCloud公司出品(后改名Docker Inc)
Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上
容器是完全使用沙箱机制,相互隔离
容器性能开销极低
Docker可以运行在在MAC、Windows、CentOS、UBUNTU等操作系统上
官网:`https://www.docker.com`
1. yum包更新到最新
yum update
2. 安装需要的软件包,yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的
yum install -y yum-utils device-mapper-persistent-data lvm2
3. 设置yum源
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
4. 安装docker,出现输入的界面都按 y
yum install -y docker-ce
5. 查看docker版本,验证是否成功
docker -v
镜像(Image):Docker镜像(Image),就相当于是一个root文件系统。比如官方镜像 ubuntu:16.04就包含了完整的一套Ubuntu16.04最小系统的root文件系统
容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等
仓库(Repository):仓库可以看成一个代码控制中心,用来保存镜像
默认情况下,将从docker hub(Docker Hub)上下载docker镜像,太慢。一般都会配置镜像加速器
USTC:中科大镜像加速器(https://docker.mirrors.ustc.edu.cn)
阿里云
网易云
腾讯云
在这里我们用阿里云镜像加速器,登陆阿里云查看个人加速地址
注意:用阿里云时,每家加速器地址不同,然后在终端输入下面指令
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://eob5atc6.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
###上面操作完成后输入下面代码测试是否成功
cat /etc/docker/daemon.json
启动docker 服务:
systemctl start docker 停止docker 服务:
systemctl stop docker 重启docker 服务:
systemctl restart docker 查看docker 服务状态:
systemctl status docker 设置开机启动docker:
systemctl enable docker
查看镜像:查看本地所有的镜像
- docker images
- docker images -q #查看所有镜像的id
搜索镜像:从网络中查找需要的镜像
docker search 镜像名称 拉取镜像:从Docker 仓库下载镜像到本地,镜像名称格式为名称:版本号,如果版本号不指定则是最新的版本。如果不知道镜像版本,可以去docker hub 搜索对应镜像查看
docker pull 镜像名称 删除镜像:删除本地镜像
- docker rmi 镜像id/名称号:版本号 #删除指定本地镜像
- docker rmi 'docker images -q' #删除所有本地镜像
查看容器
- docker ps #查看正在运行的容器
- docker ps -a #查看所有容器
创建并启动容器
- docker run 参数 --name=容器自定义别名 镜像:版本号
- 例:docker run --it --name=c2 redis:5.0
参数说明:
-i:保持容器运行。通常与-t同时使用。加入it这两个参数后,容器创建后自动进入容器中,退出容器后,容器自动关闭
-t:为容器重新分配一个伪输入终端,通常与-i同时使用
-d:以守护(后台)模式运行容器。创建一个容器在后台运行,docker exec -id --name=c2 redis:5.0。退出后,容器不会关闭
-it创建的容器一般称为交互式容器;-id创建的容器一般称为守护式容器
--name:为创建的容器命名
进入容器
docker exec -it c2 /bin/bash #进入正在运行的后台容器 停止容器
docker stop 容器名称 启动容器
docker start 容器名称 删除容器:如果容器是运行状态则删除失败,需要停止容器参能删除
docker rm 容器名称 查看容器信息
docker inspect 容器名称
思考:
Docker 容器删除后,在容器中产生的数据还在吗?
Docker 容器和外部继器可以交换文件吗?
容器之间想要进行数据交互?
数据卷
数据卷是宿主机中的一个目录或文件
当容器目录和数据卷目录绑定后,对方的修改会立即同步
一个数据卷可以被多个容器同时挂载
一个容器也可以被挂载多个数据卷
数据卷的作用
容器数据持久化
外部计价器和容器间接通信
容器之间数据交换
创建启动容器时,使用-v参数 设置数据卷
docker run ... -v 宿主机目录(文件):容器内目录(文件) ... 注意事项:
目录必须是绝对路径
如果目录不存在,会自动创建
可以挂载多个数据卷
多容器进行数据交换:
多个容器挂载同一个数据卷
数据卷容器
配置数据卷容器:
创建启动c3数据卷容器,使用-v参数 设置数据卷
docker run -it --name=c3 -v /volume centos:7 /bin/bash 创建启动c1 c2容器,使用--volumes-from参数 设置数据卷(将容器挂载到数据卷c3)
- docker run -it --name=c1 --volumes-from c3 centos:7 /bin/bash
- docker run -it --name=c2 --volumes-from c3 centos:7 /bin/bash