如何快速入门Docker

这篇文章主要介绍“如何快速入门Docker”,在日常操作中,相信很多人在如何快速入门Docker问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何快速入门Docker”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联建站-专业网站定制、快速模板网站建设、高性价比东辽网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式东辽网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖东辽地区。费用合理售后完善,10余年实体公司更值得信赖。

docker的特别之处:

docker是轻量级的虚拟化技术,启动速度快(大多数docker容器只需不到1s即可完成启动),单台硬件上可以同时跑成百上千个容器,使得快速扩展,弹性伸缩变得简单。据说,在2016年,京东使用15万docker集群来保证618高并发场景下的系统稳定。

docker是跨平台的,支持windows、macos、linux,可以做到“构建一次,到处运行”,解决开发环境和生产环境不一致带来的一系列问题,让开发人员和运维人员可以更加和谐相处。

docker是开源的,托管于github。

docker思想

从docker的logo联想docker核心思想

如何快速入门Docker

docker的logo是一个载着集装箱的大鲸鱼,这绝对是对docker最形象的描述和解释。

对比运输业,在集装箱出现之前,货物无法用统一的标准方式进行搬运,比如有些货物易碎,需要轻拿轻放,有些则不需要。于是铁路、公路、海洋等各种运输之间,需要大量的人力作为货物中转,效率极低,而且成本很高。集装箱出现之后,解决了这个难题,任何货物货物都可以放到这个神奇的箱子里,然后在公路、铁路、海洋等所有运输场景下,这个箱子在运输过程中都是密封的,而且中间的中转工作,都可以通过大型机械搞定,效率大大提升。

docker正式借鉴了标准集装箱的思想,将集装箱思想运用到了软件领域。docker为代码提供了一个基于容器的标准化运输系统,可以将任何应用及其依赖的环境(如代码、配置文件、jdk、tomcat等)打包成一个容器,这个容器可以在几乎所有的操作系统运行。

docker核心概念

镜像

镜像是docker的基石,用户可以基于镜像来运行自己的容器。

镜像的基础是docker的联合文件系统,该文件系统是分层的,每个镜像是一个层。由于每个层上面还以有其他层,也就是说,镜像可以在其他镜像(基础镜像)上面进行创建。借用一幅图来帮助理解。图片来源于网络,侵删。

如何快速入门Docker

仓库

仓库是保存用户镜像的地方。在docker hub上面有许多镜像,包括最简单的hello-world,MySQL等等。当然我们也可以有自己私有的仓库。

容器

容器为应用程序提供了隔离的运行空间。每个容器内都包含一个独享的完整的用户环境,并且一个容器内的运行环境变动不会影响其他容器的运行环境,可以使应用程序在几乎任何地方以相同的方式运行。

容器是基于镜像启动的,容器中可以运行一个或多个进程。在创建容器进程时,指定了这个进程所需要的namespace参数,使得容器就只能「看」到当前 namespace 所限定的资源、文件、设备、状态,或者配置。所以说,容器是一种特殊的进程而已,容器的本质就是进程。

docker安装

以centos 7为例,进行安装docker。

检查系统内核版本

docker运行在 centos 7上,要求操作系统为 64 位,内核版本为 3.10 及以上。

确认本机已经安装了满足要求的linux内核。使用命令uname -r来检查内核版本信息。

[root@localhost ~]# uname -r
3.10.0-957.el7.x86_64

在centos 7中安装docker

使用命令yum install -y docker安装docker,“-y”表示不询问,使用默认配置进行安装。

启动docker服务,并设置为开机自启动

使用下列命令:

systemctl start docker.service
systemctl enable docker.service

输入docker version,返回版本信息表明docker安装成功。

[root@localhost ~]# docker version
client:
 version:     1.13.1
 api version:   1.26
 package version: docker-1.13.1-96.gitb2f74b2.el7.centos.x86_64
 go version:   go1.10.3
 git commit:   b2f74b2/1.13.1
 built:      wed may 1 14:55:20 2019
 os/arch:     linux/amd64

server:
 version:     1.13.1
 api version:   1.26 (minimum version 1.12)
 package version: docker-1.13.1-96.gitb2f74b2.el7.centos.x86_64
 go version:   go1.10.3
 git commit:   b2f74b2/1.13.1
 built:      wed may 1 14:55:20 2019
 os/arch:     linux/amd64
 experimental:  false

docker实战——hello world

入门实战怎么能少得了经典的“hello world”?

拉取镜像

其实dockerhub上已经有了这个镜像,名字叫“hello-world”。直接从dockerhub拉取镜像,命令和git有些相似:docker pull hello-world

[root@localhost docker]# docker pull hello-world
using default tag: latest
trying to pull repository docker.io/library/hello-world ... 
latest: pulling from docker.io/library/hello-world
1b930d010525: pull complete 
digest: sha256:41a65640635299bab090f783209c1e3a3f11934cf7756b09cb2f1e02147c6ed8
status: downloaded newer image for docker.io/hello-world:latest

查看镜像

查看拉取到的docker镜像:docker images

[root@localhost ~]# docker images
repository       tag         image id      created       size
docker.io/hello-world  latest       fce289e99eb9    5 months ago    1.84 kb

运行镜像

运行镜像:docker run hello-world。看到打印出如下的内容,代表运行成功。

[root@localhost docker]# docker run hello-world

hello from docker!
this message shows that your installation appears to be working correctly.

to generate this message, docker took the following steps:
 1. the docker client contacted the docker daemon.
 2. the docker daemon pulled the "hello-world" image from the docker hub.
  (amd64)
 3. the docker daemon created a new container from that image which runs the
  executable that produces the output you are currently reading.
 4. the docker daemon streamed that output to the docker client, which sent it
  to your terminal.

to try something more ambitious, you can run an ubuntu container with:
 $ docker run -it ubuntu bash

share images, automate workflows, and more with a free docker id:
 https://hub.docker.com/

for more examples and ideas, visit:
 https://docs.docker.com/get-started/

docker常用命令

docker images : 列出本地的镜像

docker pull image_name:拉取镜像。如果没有指定具体的镜像标签,会自动拉取latest标签的镜像。

docker search image_name:在docker hub上查找镜像

docker start container:启动和运行容器

docker run [options] image_name:基于镜像创建并启动一个容器

常用选项:
-d: 后台运行容器,并返回容器id;
-i: 以交互模式运行容器,通常与 -t 同时使用;
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
-p: 随机端口映射,容器内部端口随机映射到主机的高端口
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口

docker logs container:获取容器的日志信息

docker attach container:进入容器

exit:退出容器

docker exec container command:在运行的容器中执行命令

docker stop container:停止容器

docker rm container:删除容器

docker save -o image_name.tar image_name:导出镜像

docker ps:查看正在运行的容器

docker ps -a:查看系统中容器列表

docker top container:查看容器内的进程

docker stop daemon_dave:停止守护容器

docker构建镜像

如何构建镜像?

构建一个自己的镜像需要两步:

编写dockerfile。dockerfile 告诉docker如何制作镜像以及每一步是怎样的。

  • docker执行dockerfile中的指令的流程是这样的:

    • docker从基础镜像运行一个容器

    • 执行一条指令,对容器进行修改

    • 提交到一个新的镜像层

    • docker再基于刚才提交的镜像运行一个新容器

    • 执行dockerfile中的下一条指令,知道所有指令执行完毕。

  • 使用docker build命令构建。

编写dockerfile

每个dockerfile的第一条命令必须是from。from指令指定一个已经存在的镜像,告诉docker后续的指令都是在这个基础上进行的。例如:from java:8

maintainer 指令用来标志该镜像所有者和联系方式。例如:maintainer james "×××@example.com"

volume 指令用来向基于镜像创建的容器添加卷。一个卷可以是存在一个或者多个容器内的特定的目录,这个目录可以绕过联合文件系统,并提供共享数据和数据持久化的功能。

cmd 指令用来指定一个容器启动时要运行的命令。

entrypoint指令与cmd指令很相似。

workdir 指令用来从镜像创建一个新容器的时候,在容器内部设置一个工作命令,entrypoint或cmd指令指定的程序会在这个目录下执行。

env 指令用来在在镜像构建过程中设置环境变量。例如:env test_path /home/test

run 指令用来在当前镜像中运行指定的命令。例如:run apt-get install -y nginx

expose 指令用来告诉docker该容器内的应用程序将使用容器的指定端口。例如:expose 80

add 指令用来将构建环境下的文件和目录复制到镜像中。 例如:add docker-0.0.1-snapshot.jar app.jar

copy 指令与add 类似,不同点在与copy只关心在构建上下文中复制本地文件,而不会提取和解压。

label 指令用于为docker镜像添加元数据。例如:label name=test description="a container is used to test"

dockerfile实例:

from java:8
maintainer james "×××@example.com"
volume /tmp
add docker-0.0.1-snapshot.jar app.jar
entrypoint ["java","-djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

执行docker build

执行docker build命令后看到“build success”表明构建成功,可以使用docker run命令来运行了。

到此,关于“如何快速入门Docker”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


网站栏目:如何快速入门Docker
URL标题:http://ybzwz.com/article/jehpej.html