Docker入门学习(笔记1)

初识 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 宿主机目录(文件):容器内目录(文件) ...
  • 注意事项:

    1. 目录必须是绝对路径

    2. 如果目录不存在,会自动创建

    3. 可以挂载多个数据卷

3.3 配置数据卷容器

​ 多容器进行数据交换:

  1. 多个容器挂载同一个数据卷

  2. 数据卷容器

    配置数据卷容器:

  3. 创建启动c3数据卷容器,使用-v参数 设置数据卷

    docker run -it --name=c3 -v /volume centos:7 /bin/bash
  4. 创建启动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

你可能感兴趣的:(其它,docker,容器,linux)