一文了解Docker容器技术的操作

一文了解Docker容器技术的操作

前言一、Docker是什么二、Docker的安装及测试Docker的安装Docker的Hello world测试三、Docker的常见操作镜像的基本操作容器的基本操作镜像、容器的导入和导出四、关于DockerFile总结

前言

相信点进这篇文章的Coder,不管是在各大技术论坛上、技术交流群,亦或招聘网上,应该都有见到过Doker容器技术的面孔,随着社会节奏的加快以及迫于生活的压力,在计算机技术日新月异的今天,真正能够沉下心来学习一门技术的时间真的不多。趁着这段空闲的时间,涛耶也该是时候把过去学习时所积累的笔记沉淀一下了。本文主要是从是什么、为什么、怎么做的角度来介绍Docker容器技术的入门,能让初次接触Docker容器技术的朋友更快更便捷的使用Docker。

一、Docker是什么

对于Docker,官方的介绍如下:

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

在实际的开发过程中,我们往往会因为环境的搭建而浪费过多的时间,而现如今有了Docker容器技术的支持,我们不再过于担心各种因为环境问题而造成的过多时间的浪费。Docker容器引擎中已经为我们提供了开发过程中所需要的各种镜像,我们需要有Resid数据库、Elasticsearch搜索技术、Mq消息队列等支持,我们都可以使用Docker中的pull命令来从中央仓库中进行拉取,而不像传统那样从各大官网亦或github中进行下载。读到这里的朋友应该会有所发现,Docker就有点类似Maven管理工具,或者直接将Docker看做一个装载了大量“物资”的集装箱,但Docker的强大之处可并不止步于此,查阅了解后,Docker主要有以下几大特性:

  • Automating the packaging and deployment of applications(使应用的打包与部署自动化)
  • Creation of lightweight, private PAAS environments(创建轻量、私密的PAAS环境)
  • Automated testing and continuous integration/deployment(实现自动化测试和持续的集成/部署)
  • Deploying and scaling web apps, databases and backend services(部署与扩展webapp、数据库和后台服务)

总之,Docker容器是现如今相当火热的一门技术。之前读到网上有着这么一句话:电脑如果有问题,没有是重装系统解决不了的。话虽如此,但是一旦重装系统之后,我们之前系统中所有保存资源都被消除了,我们需要使用QQ增进朋友之间的感情,则要到鹅厂中去下载、安装;需要网易云音乐来放松心情,则要到官网中安装、下载,以及需要下载并安装其他各大软件才能满足自己的实际需求,一个不小心还可能会绑架其他垃圾软件。当然有的朋友会在重装系统之前自己的资源备份以下,重装系统之后再直接使用,但依然免不了N个下一步所带来的时间消耗。假如现在有这么一个容器,里面存放着我们需要的所有资源,在我们需要的时候只需要一行简单的pull命令即可迅速完成所有软件的下载安装步骤,这岂不美哉!

没错,Docker容器就是基于这么一个思想来解决我们各大烦恼。如果对于Docker容器技术的理解还不是特别清楚,可拜读一下大佬的文章:漫画 | 从搬家到容器技术 Docker 应用场景解析,这篇文章使用漫画的形式来给读者介绍Docker容器的优势。

二、Docker的安装及测试

Docker的安装

我们往往是使用Linux系统来安装Docker,在之前的文章也有过Linux系统的安装,这里就不多介绍了。下面我们就在CentOS Linux release 8.0.1905 (Core)系统下来安装一下Docker吧。

首选使用cat /etc/redhat-release查看一下自己的Linux版本:

[root@iZm5eei156c9h3hrdjpe77Z ~]# cat /etc/redhat-release
CentOS Linux release 8.0.1905 (Core)

在安装Docker之前,我们先把yum更新一下

update yum

安装Docker需要的软件包

yum install -y yum-utils device-mapper-persistent-data lvm2

设置一下docker的yum源,后期在使用的Docker的pull操作都是在此仓库中下载

 yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

查看仓库中所有的docker版本,以便安装我们需要的Docker版本

yum list docker-ce --showduplicates | sort -r

安装需要的docker版本,此处以Docker17.12.1版本为例

yum install docker-ce-17.12.1.ce

成功安装之后,便可使用docker version/docker -v即可查看所安装docker的版本

# docker version
[root@iZm5eei156c9h3hrdjpe77Z ~]# docker version
Client:
 Version:    17.12.1-ce
 API version:    1.35
 Go version:    go1.9.4
 Git commit:    7390fc6
 Built:    Tue Feb 27 22:15:20 2018
 OS/Arch:    linux/amd64

Server:
 Engine:
  Version:    17.12.1-ce
  API version:    1.35 (minimum version 1.12)
  Go version:    go1.9.4
  Git commit:    7390fc6
  Built:    Tue Feb 27 22:17:54 2018
  OS/Arch:    linux/amd64
  Experimental:    false

# docker -v
[root@iZm5eei156c9h3hrdjpe77Z ~]# docker -v
Docker version 17.12.1-ce, build 7390fc6

之后,我们需要更换docker拉取软件的服务,这里使用的是Aliyun镜像加速器,使用加速器可以提升获取Docker官方镜像的速度(一下操作可直接复制执行):

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://1ewanek5.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

这样一来,我们便完整的安装好了Docker。(PS:由于系统环境的问题,在安装过程中可能需要到其他依赖,只需要根据提示操作即可)

Docker的Hello world测试

任何技术的学习,我们都离不开Hello world,Docker也不例外,下面我们来使用Docker来运行一下Hello world吧,在测试之前我们首先使用如下命令来启动Docker,启动、重新启动以及设置开机自启动:

# Docker的启动
systemctl start docker
# Docker的重启
systemctl restart docker
# Docker的开机自启动
systemctl enable docker     # 一般我们使用开机自启动的形式

启动好Docker之后,我们来在Docker中运行一下hello world:

# docker 运行hello world
docker run hello-world

在我们执行docker run hello-world之后,Docker首先会根据我们的命令查看一下本地是否存在hello-world镜像,如果存在则会直接运行,如果不存在就会去中央仓库中拉取(下载)hello-world镜像(拉取过程极为迅速)之后再来运行。由于我们首次使用Docker,所以执行之后会出现以下结果:

由于Docker已经帮我们拉取了hello-world镜像,所以当我们再次运行docker run hello-world之后,则会出现如下结果:

顺便一提,我们在使用Docker拉取所拉取的所有镜像都来源于Docker的中央仓库,里面存放了大量的镜像可供我们自由使用:https://hub.docker.com/

三、Docker的常见操作

启动docker systemctl start docker,重启systemctl restart docker,开机docker自启动systemctl enable docker

# Docker的启动
systemctl start docker
# Docker的重启
systemctl restart docker
# Docker的开机自启动
systemctl enable docker     # 一般我们使用开机自启动的形式

镜像的基本操作

  • 使用search命令来检索中央仓库中收录的镜像,这里以tomcat为例
# 检索镜像:docker search [镜像名称]
docker search tomcat

  • 拉取(下载)镜像:docker pull tomcat(默认最新版本),如果需要其他版本可在中央仓库中查阅
# 拉取镜像:docker pull [镜像名称]
docker pull tomcat
# 默认拉取的是最新版本,如果需要特定版本,在后面指定即可,以tomcat7.0.1为例
docker pull tomcat:7.0.1
  • 查看已经下载的本地镜像:
# 查看已经下载的本地镜像
docker images

  • 删除本地镜像
# 删除本地镜像: docker rmi 镜像名称/IMAGE ID
docker rmi tomcat

容器的基本操作

  • 根据镜像启动对应的容器
# 根据镜像启动对应的容器
docker run -d --name mytomcat tomcat
# --name 对容器起一个别名
# -d 对指定的容器进行后台运行
  • 停止运行的容器
# 停止运行的容器:docker stop 容器名称/CONTAINER ID
docker stop mytomcat
  • 查看正在运行的容器
docker ps       # 查看正在运行的容器
docker ps -a    # 查看本地所有的容器
  • 删除容器
# 注:删除容器是使用rm,删除镜像是rmi,且删除镜像之前需要停止运行容器并删除
docker rm mytomcat
  • 启动一个做了端口映射的容器,在之前创建容器之后,我们无法通过ip:端口的形式来访问Docker中所开启的服务,因为每一个容器他都是独立,所以要想访问,我们则需要通过端口的映射来访问容器。
docker run -d --name mytomcat -p 8888:8080 tomcat
# --name:对容器起一个别名
# -p:将主机的端口映射到容器的一个端口  主机端口:容器内部的端口 
# -d:后台运行
  • 查看容器的日志docker logs mytomcat

  • 容器开机自起动:

docker update mytomcat --restart=always
  • 进入对应的容器
docker exec -it mytomcat /bin/bash
  • 本地文件(是centos不是windows)与docker容器中文件之间的互传,以将ik分词器插件上传至elasticsearch容器为例:
# 先将windows上的文件使用xftp上传到vmware linux中,然后将文件使用docker命令上传到docker容器中
# docker cp 本地路径 容器名:容器路径
docker cp ./elasticsearch-analysis-ik-6.5.4.zip elasticsearch:/usr/share/elasticsearch/plugins
  • 文件的挂载

Docker容器是独立,且其相当于是一个及其精简版的Linux,在我们通过exec命令之后,我们是无法使用vim、vi等命令来对其内部文件进行编辑,在一般情况下我们在创建好容器之后一般会对其配置文件进行编辑,此时我们可以使用Docker中的挂载来将容器内文件挂载到宿主机中。当我们在宿主机中对挂载的文件进行编辑的时候,容器中所被挂载的文件也会做出相应的修改,下面就是docker挂载文件的-v操作(以挂载Es的配置文件和数据文件为例):

mkdir -p ./resources/elasticsearch/config
mkdir -p ./resources/elasticsearch/data

docker run --name elasticsearch -p 9200:9200 \
-e "discovery.type=single-node" \
-e ES_JAVA_OPTS="-Xms256m -Xmx256m" \
-v /resources/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
-v /resources/elasticsearch/data:/usr/share/elasticsearch/data -d elasticsearch:5.6.8

镜像、容器的导入和导出

export:可将docker容器通过export导出为tar文件

docker export mytomcat > mytomcat.tar

import:基于tar文件来创建一个新的镜像

docker import - mytomcat < mytomcat.tar

注:以上指示Docker容器中常用的一些命令,对于不同的镜像的使用,其启动命令也是会有所区别,后面的一些命令会在使用的时候进行介绍,其他更多Docker操作可参考Docker官方文档:
https://docs.docker.com/engine/reference/commandline/docker/

四、关于DockerFile

上面我们已经介绍了Docker以及在使用Docker过程中常用的一些命令。而本小结将会介绍Dockerfile,Dockerfile是常用的一种创建镜像的方式,由file我们也不难知道Dockerfile就是一个Docker文件,可以简单把它理解成在其内部定义了构建Docker容器的一条条指令,而每一条指令的内容都代表了构建容器的每个流程,Docker通过读取Dockerfile内的每条指令来构建镜像。下面我们将会简单介绍编写Dockerfile的常用指令及其搭建流程,并最终使用Dockerfile来搭建一个centos镜像。(PS:本文中的Dockerfile仅仅是简单介绍,之后Dockerfile的详细编写会单独成文整理)

Dockerfile官方文档https://docs.docker.com/develop/develop-images/dockerfile_best-practices/

在介绍Dockerfile之前,我们首先通过下面这张图来直观的了解下Dockerfile(来源网络,侵删。)

从上图我们可以大致了解Dockerfile的编写流程,一个标准的Dockerfile以FROM指令开头(除注释之外,注释通过#进行),一般来说,Dockerfile中的指令主要包括四种类型,该四种类型也就是编写Dockerfile的一般流程:

  • 指定构建新镜像的基础镜像(父镜像):FROM
  • 说明所构建镜像的维护者信息:MAINTAINER(官方已经不赞成使用)、LABEL(建议使用)
  • 对镜像的操作指令:RUN、ENV、ADD、COPY以及WORKDIR
  • 对容器的启动指令:CMD、ENTRYPOINT、USER

下面我们通过Dockerfile的形式来搭建一个nginx容器,并访问其index.html页面。

创建一个工作目录,用于指定创建新镜像的所需要的文件(不做要求,但却是一种创建镜像的规范)

mkdir demo_dockerfile
cd demo_dockerfile
vim Dockerfile

编写Dockerfile文件

FROM nginx
LABEL author=taoye email=26647879@qq.com desc="Hello Dockerfile, I am a coder."

Dockerfile文件写完之后,我们通过该文件来创建一个新的镜像,-t参数用于指定创建新镜像的仓库和名称,并设置版本,注意在结尾有.,表示的是指定构建新镜像过程中的上下文环境的目录。

docker build -t demo_nginx/demo_dockerfile:v1.0 .

执行之后docker build之后便会在本地创建了一个新的镜像,我们可以通过该镜像来创建容器并使用curl来进行测试

docker run --name demo_nginx -d -p 7777:80 demo_nginx/demo_dockerfile:v1.0

curl localhost:7777

总结

本文首先介绍的是对Docker基本认识,其次详细说明了Docker环境的搭建,之后常见的Docker操作,最后简单介绍了Dockerfile及通过Dockerfile创建一个简单nginx容器。在之后文章中会详细介绍Dockerfile,最好的学习方式莫过于从官方文档中尽情的无偿汲取知识,本文说到底仅仅是在学习Docker官方文档之后的一个简单总结,所涉及到的也只是冰山一角。Docker官方文档中包含了详细且全面的介绍,涉及到Docker的方方面面,有条件的朋友强烈建议阅读耐心地阅读官方文档:http://docs.docker.com/engine/reference/builder/

posted @ 2020-06-06 14:18  玩世不恭的Coder  阅读(867)  评论(0编辑  收藏  举报