初识 Docker
1.1 Docker概念
-
Docker是一个开源的应用容器引擎
-
诞生于2013年初,基于Go语言实现,dotCloud公司出品(后改名Docker Inc)
-
Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上
-
容器是完全使用沙箱机制,相互隔离
-
容器性能开销极低
Docker可以运行在在MAC、Windows、CentOS、UBUNTU等操作系统上
官网:`https://www.docker.com`
1.2 安装Docker
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
1.3 Docker架构
-
镜像(Image):Docker镜像(Image),就相当于是一个root文件系统。比如官方镜像 ubuntu:16.04就包含了完整的一套Ubuntu16.04最小系统的root文件系统
-
容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等
-
仓库(Repository):仓库可以看成一个代码控制中心,用来保存镜像
1.4 配置Docker镜像加速器
默认情况下,将从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 命令
2.1 Docker 服务相关命令
-
启动docker 服务:
systemctl start docker
-
停止docker 服务:
systemctl stop docker
-
重启docker 服务:
systemctl restart docker
-
查看docker 服务状态:
systemctl status docker
-
设置开机启动docker:
systemctl enable docker
2.2 Docker 镜像相关命令
-
查看镜像:查看本地所有的镜像
docker images docker images -q #查看所有镜像的id
-
搜索镜像:从网络中查找需要的镜像
docker search 镜像名称
-
拉取镜像:从Docker 仓库下载镜像到本地,镜像名称格式为
名称:版本号
,如果版本号不指定则是最新的版本。如果不知道镜像版本,可以去docker hub 搜索对应镜像查看docker pull 镜像名称
-
删除镜像:删除本地镜像
docker rmi 镜像id/名称号:版本号 #删除指定本地镜像 docker rmi 'docker images -q' #删除所有本地镜像
2.3 Docker 容器相关命令
-
查看容器
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 容器的数据卷
3.1 数据卷概念及作用
思考:
-
Docker 容器删除后,在容器中产生的数据还在吗?
-
Docker 容器和外部继器可以交换文件吗?
-
容器之间想要进行数据交互?
数据卷
-
数据卷是宿主机中的一个目录或文件
-
当容器目录和数据卷目录绑定后,对方的修改会立即同步
-
一个数据卷可以被多个容器同时挂载
-
一个容器也可以被挂载多个数据卷
数据卷的作用
-
容器数据持久化
-
外部计价器和容器间接通信
-
容器之间数据交换
3.2 配置数据卷
-
创建启动容器时,使用
-v
参数 设置数据卷docker run ... -v 宿主机目录(文件):容器内目录(文件) ...
-
注意事项:
-
目录必须是绝对路径
-
如果目录不存在,会自动创建
-
可以挂载多个数据卷
-
3.3 配置数据卷容器
多容器进行数据交换:
-
多个容器挂载同一个数据卷
-
数据卷容器
配置数据卷容器:
-
创建启动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