您的位置:首页 > 运维架构 > Docker

Docker 从入门到跑路【1】-docker_简介_安装_命令_基本操作_数据卷

2020-05-07 04:24 106 查看

1 Docker是什么

Docker 是一个开源的应用容器引擎
诞生于 2013 年初,基于 Go 语言实现, dotCloud 公司出品(后改名为Docker Inc)
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上。
容器是完全使用沙箱机制,相互隔离
容器性能开销极低。
Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版)

2 安装Docker

2.1 安装

Docker可以运行在MAC、Windows、CentOS、UBUNTU等操作系统上,本课程基于CentOS 7 安装Docker。官网: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

2.2 配置镜像服务器

默认情况下,将来从docker hub(https://hub.docker.com/)上下载docker镜像,太慢。一般都会配置镜像加速器:
USTC:中科大镜像加速器(https://docker.mirrors.ustc.edu.cn)
阿里云
网易云
腾讯云

登录阿里云帐号,搜索镜像,配置阿里云镜像加速器

3 Docker 架构介绍

  • 镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04
    就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。

  • 容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。

  • 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。

4 Docker 命令

4.1 服务相关命令

  • 启动docker服务

systemctl start docker

  • 停止docker服务

systemctl stop docker

  • 重启docker服务

systemctl restart docker

  • 查看docker服务状态

systemctl status docker

  • 开机启动docker服务

systemctl enable docker

4.2 镜像相关命令

  • 查看镜像: 查看本地所有的镜像

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

  • 搜索镜像:从网络中查找需要的镜像

docker search 镜像名称

  • 拉取镜像:从Docker仓库下载镜像到本地,镜像名称格式为 名称:版本号,如果版本号不指定则是最新的版本。
    如果不知道镜像版本,可以去docker hub 搜索对应镜像查看。

docker pull 镜像名称

  • 删除镜像: 删除本地镜像

【docker rmi 镜像id】 或 【 docker rmi 镜像名字:版本号 】 # 删除指定本地镜像
docker rmi

docker images -q
# 删除所有本地镜像

4.3 容器相关命令

  • 查看容器

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

  • 创建并启动容器

docker run 参数

参数说明:
-i:保持容器运行。通常与 -t 同时使用。加入it这两个参数后,容器创建后自动进入容器中,退出容器后,容器自动关闭。
-t:为容器重新分配一个伪输入终端,通常与 -i 同时使用。
-d:以守护(后台)模式运行容器。创建一个容器在后台运行,需要使用docker exec 进入容器。退出后,容器不会关闭。
-it 创建的容器一般称为交互式容器,-id 创建的容器一般称为守护式容器
–name:为创建的容器命名。
示例如下,创建并运行一个容器, 最后的centos:7 是镜像名称和版本号 /bin/bash 类似于执行的脚步命令

  • 进入容器

docker exec 参数 (docker exec -it mytomcat /bin/bash) # 通过-id创建退出容器,容器不会关闭

  • 停止容器

docker stop 容器名称

  • 启动容器

docker start 容器名称

  • 删除容器:如果容器是运行状态则删除失败,需要停止容器才能删除

docker rm 容器名称

  • 查看容器信息

docker inspect 容器名称

5 Docker数据卷

5.1 数据卷简介及作用

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

数据卷作用

  • 容器数据持久化 (将宿主目录与容器中目录进行绑定并互相同步)
  • 外部机器和容器间接通信
  • 容器之间数据交换

5.2 配置数据卷

创建启动容器时,使用 –v 参数 设置数据卷

docker run … –v 宿主机目录(文件):容器内目录(文件) …

注意事项:
1. 目录必须是绝对路径
2. 如果目录不存在,会自动创建
3. 可以挂载多个数据卷

/root/data 是宿主机目录
/root/data_container 是容器内目录

5.3 配置数据卷容器

多容器进行数据交换

  1. 多个容器挂载同一个数据卷
  2. 数据卷容器
  • 配置数据卷容器

docker run –it --name=c3 –v /volume centos:7 /bin/bash

  • 创建启动 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

5.4 小结

  • 数据卷概念
    宿主机的一个目录或文件
  • 数据卷作用
    容器数据持久化
    客户端和容器数据交换
    容器间数据交换
  • 数据卷容器
    创建一个容器,挂载一个目录,让其他容器继承自该容器( --volume-from )。
    通过简单方式实现数据卷配置
youarenowhere 原创文章 15获赞 3访问量 783 关注 私信
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: