docker(初识一)

初识docker

问题分析:我们写的代码会接触到好几个环境:开发环境、测试环境以及生产环境:
在这里插入图片描述

docker概念

在这里插入图片描述

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

安装docker

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
  • 镜像加速器

阿里云镜像获取地址:https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors,登陆后,左侧菜单选中镜像加速器就可以看到你的专属地址了:

  • 在/etc/docker/daemon.json,文件末尾增加如下内容
{
"registry-mirrors": ["https://你的ID.mirror.aliyuncs.com"]
}

docker架构

在这里插入图片描述

  • 镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04
    就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
  • 容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
  • 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。

docker命令

进程相关命令

启动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 search redis #查找redis镜像

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

  • 如果不知道镜像版本,可以去docker hub 搜索对应镜像查看。
docker pull 镜像名称
docker pull redis #下载最新版本redis
docker pull redis:5.0 #下载5.0版本redis
  • 删除镜像: 删除本地镜像
docker rmi 镜像id # 删除指定本地镜像
docker images -q #查看所有的镜像列表
docker rmi `docker images -q` # 删除所有本地镜像

容器相关命令

查看容器、创建容器、进入容器、启动容器、停止容器、删除容器、查看容器信息

  • 查看容器
docker ps # 查看正在运行的容器
docker ps –a # 查看所有容器
  • 创建并启动容器
docker run 参数

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

er run -it --name=c1 centos:7 /bin/bash #创建交互式容器
docker run -id --name=c2 centos:7 #创建守护式容器

注意:交互式容器,exit后容器自动关闭,守护式容器会在后台执行

  • 进入容器
docker exec -it c2 /bin/bash #进入容器
  • 停止容器
docker stop 容器名称
  • 启动容器
docker start 容器名称
  • 删除容器:如果容器是运行状态则删除失败,需要停止容器才能删除
docker rm 容器名称
  • 查看容器信息
docker inspect 容器名称
  • docker设置开机启动:
systemctl enable docker.service
  • docker关闭开机启动
systemctl disable docker.service

Docker 容器设置自启动 容器自启动要看两种情况

  1. 新建容器时配置自启参数
docker run --restart=always 容器id 或 容器名称
  1. 已存在的容器配置自启
docker update --restart=always 容器id 或 容器名称

  • 取消容器自启
docker update --restart=no 容器id 或 容器名称
  • 批量设置容器自启
docker update --restart=always $(docker ps -aq)

docker容器数的据卷

数据卷概念及作用

思考:

  • Docker 容器删除后,在容器中产生的数据还在吗?

在这里插入图片描述

  • Docker 容器和外部机器可以直接交换文件吗?

在这里插入图片描述

  • 容器之间想要进行数据交互?
    在这里插入图片描述数据卷概念:
  • 数据卷是宿主机中的一个目录或文件
  • 当容器目录和数据卷目录绑定后,对方的修改会立即同步
  • 一个数据卷可以被多个容器同时挂载
  • 一个容器也可以被挂载多个数据卷
    数据卷的作用:
  • 容器数据持久化
  • 外部机器和容器间接通信
  • 容器之间数据交换

配置数据卷

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

注意事项:

  • 容器目录必须是绝对路径
  • 如果目录不存在,会自动创建
  • 可以挂载多个数据卷
    在这里插入图片描述
    演示数据卷持久化:
  • 创建c1挂载/root/data到/root/data_container
docker run -it --name=c1 -v /root/data:/root/data_container centos:7 /bin/bash

关闭容器,可以看到数据卷数据文件还在

docker stop c1

宿主机目录还在

  • 删除容器c1
docker rm c1
  • 宿主机目录还在
    重新恢复c1
docker run -it --name=c1 -v ~/data:/root/data_container centos:7 /bin/bash

注意在容器中不能写~

  • 演示一个容器挂载多个数据卷
docker run -it --name=c2 \
-v ~/data2:/root/data2 \
-v ~/data3:/root/data3 \
centos:7
  • 两个容器挂载同一个数据卷
docker run -it --name=c3 -v /root/data:/root/data_container centos:7 /bin/bash
docker run -it --name=c4 -v /root/data:/root/data_container centos:7 /bin/bash

在一个容器中修改文件,看到另一个容器也跟着

配置数据卷容器

多容器进行数据交换,多个容器挂载同一个数据卷容器,完成数据交互
在这里插入图片描述

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

这里没有指定宿主机目录,默认生成一个宿主机目录

docker inspect c3 #查看c3
  1. 创建启动 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

使用 c3数据卷容器创建c1,c2,这时即使c3关闭不影响c3,c4交互

数据卷小结

  1. 数据卷概念
    宿主机的一个目录或文件
  2. 数据卷作用
    容器数据持久化
    客户端和容器数据交换
    容器间数据交换
    3.数据卷容器
    创建一个容器,挂载一个目录,让其他容器继承自该容器( --volume-from )。
    通过简单方式实现数据卷配置
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值