Docker知识点面试题总结

1、什么是Docker?

Docker是一个容器化平台,它以容器的形式将你的应用程序及所有的依赖项打包在一起,以确保你的应

用程序在任何环境中无缝运行。

2、什么是Docker镜像?

Docker镜像是Docker容器的源代码,Docker镜像用于创建容器,使用Build命令创建镜像。

3、什么是Docker容器?

Docker容器包括应用程序及所有的依赖项,作为操作系统的独立进程运行。

4、Docker容器有几种状态?

四种状态:运行、已停止、重新启动、已退出。

5、DockerFile中最常见的指定是什么?

指令 备注

FROM 指定基础镜像

LABEL 功能为镜像指定标签

RUN 运行指定命令

CMD 容器启动时要运行的命令

6、DockerFile中的命令COPY和ADD命令有什么区别?

COPY和ADD的区别是:COPY的SRC只能是本地文件,其他用法一致。

7、Docker的常用命令?docker pull 拉去或更新指定的镜像

docker push 将镜像推送到远程仓库

docker rm 删除容器

docker rmi删除镜像

docker images 列出所有镜像

docker ps 列出所有容器

8、容器与主机之间的数据拷贝命令?

Docker cp命令用于容器与主机之间的数据拷贝

主机到容器:docker cp /www 96f7f14e99ab:/www/

容器到主机:docker cp 96f7f14e99ab:/www /tmp

9、启动nginx容器(随机端口映射),并挂载本地文件目

录到容器html的命令?

Docker run -d -p --name nginx2 -v /home/nginx:/usr/share/nginx/html nginx

10、解释一下dockerfile的ONBUILD指令?

当镜像用作另一个镜像构建的基础时,ONBUILD指令像镜像添加将在稍后执行的触发指令。如果要构建

将用作构建其他镜像的基础的镜像(例如,可以使用特定于用户的配置自定义的应用程序构建环境或守

护程序),这将非常有用。

11、什么是docker Swarm?

Docker Swarm是docker的本地群集。它将docker主机池转变为单个虚拟docker主机。Docjer Swarm

提供标准的docker API,任何已经与docker守护进程通信的工具都可以使用Swarm透明地扩展到多个主

机。

12、如何在生产中监控docker?

Docker提供docker:stats和docker事件等工具来监控生产中的docker。我们可以使用这些命令获取重要

统计数据的报告。

Docker统计数据:当我们使用容器ID调用docker stats时,我们获得容器的CPU,内存使用情况等。它

类似于Linux中的top命令。

Docker事件:docker事件是一个命令,用于查看docker守护程序中正在进行的活动流。一些常见的

docker事件是:attach,commit,die,detach,rename,destroy等。我们还可以使用各种选项来限

制或过滤我们感性其的事件。

13、Docker如何在非Linux系统中运行容器?

通过添加到Linux内核版本2.6.24的名称空间功能,可以实现容器的概念。容器将其ID添加到每个进程,

并向每个系统调用添加新的访问控制检查。它由clone()系统调用访问,该调用允许创建先前全局命名

空间的单独实例。

如果由于Linux内核中可用的功能而可以使用容器,那么显而易见的问题是非Linux系统如何运行容器。

Docker for Mac和Windows都使用Linux VM来运行容器。Docker Toolbox用于在Virtual Box VM中运

行容器。但是,罪行的docker早Windows中使用Hyper-V,在MAC中使用Hypervisor.framework。

14、如何批量清理临时镜像文件?

可以使用sudo docker rmi $(sudo docker images -q -f danging=true)命令

15、如何查看镜像支持的环境变量?

使用sudo docker run IMAGE env

16、本地的镜像文件都存放在哪里?

于docker相关的本地资源存在/var/lib/docker/目录下,其中container目录存放容器信息,graph目录存

放镜像信息,aufs目录下存放具体的镜像底层文件。

17、构建docker镜像应该遵循哪些原则?

整体原则上,尽量保持镜像功能的明确和内容的精简,要点包括:

尽量选取满足需求但较小的基础系统镜像,建议选择debian:wheezy镜像,仅有86MB大小。

清理编译生成文件、安装包的缓存等临时文件。

安装哥哥软件时候要指定准确的版本号,并避免引入不需要的依赖。

从安全的角度考虑,应用尽量使用系统的库和依赖。

使用dockerfile创建镜像时候要添加.dockerignore文件或使用干净的工作目录。

18、容器退出后,通过docker ps命令查看不到,数据会丢

失么?

容器退出后会处于终止(exited)状态,此时可以通过docker ps -a查看,其中数据不会丢失,还可以通

过docker start来启动,只要删除容器才会清除数据。

19、如何停止所有正在运行的容器?

docker kill $(sudo docker ps -q)

20、如何清理批量后台停止容器?

docker rm$(sudo docker ps -a -q)

21、如何临时退出一个正在交互的容器的终端,而不终止

它?

按Ctrl+p,后按Ctrl+q,如果按Ctrl+c会使容器内的应用进程终止,进而会使容器终止。

22、很多应用容器都是默认后台运行的,怎么查看他们的

输出和日志信息?

使用docker logs,后面跟容器的名称或者ID信息

23、使用docker port命令映射容器的端口时,系统报错

Error:NO public port ‘80’ published for …,是什么意

思?

创建镜像时dockerfile要指定正确的EXPOSE的端口,容器启动时指定PublishAllport=true

24、可以在一个容器中同时运行多个应用进程吗?

一般不推荐在用以容器内运行多个应用进程,如果有类似需求,可以用过额外的进程管理机制,比如

supervisord来管理所运行的进程。25、如何控制容器占用系统资源(CPU,内存)的份额?

在使用docker create命令创建容器或使用docker run 创建并运行容器的时候,可以使用-c|-spu

shares[=0]参数来调整同期使用SPU的权重,使用-m|-memory参数来调整容器使用内存的大小。

26、仓库(Repository)、注册服务器(Registry)、注册 索引(Index)有何关系?

首先,仓库事存放一组关联镜像的集合,比如同一个应用的不同版本的镜像,注册服务器时存放实际的

镜像的地方,注册索引则负责维护用户的账号、权限、搜索、标签等管理。注册服务器利用注册索引来

实现认证等管理。

27、从非官方仓库(如:dl.dockerpool.com)下载镜像

的时候,有时候会提示”Error:Invaild registry endpoint

https://dl.docker.com:5000/v1/…”?

Docker自1.3.0版本往后以来,加强了对镜像安全性的验证,需要手动添加对非官方仓库的信任。

DOCKER_ORTS=”-insecure-registry dl.dockerpool.com:5000”重启docker服务。

28、Docker的配置文件放在那里。如何修改配置?

Ubuntu系统下Docker的配置文件是/etc/default/docker,CentOS系统配置文件存放

在/etc/sysconfig/docker。

29、如何更改docker的默认存储设置?

Docker的默认存放位置是/var/lib/docker,如果希望将docker的本地文件存储到其他分区,可以使用

Linux软连接的方式来做。

30、docker与LXC(Linux Container)有何不同?

LXC利用Linux上相关技术实现容器,docker则在如下的几个方面进行了改进:

容器特性备注

移植性 通过抽象容器配置,容器可以实现一个平台移植到另一个平台

镜像系统基于AUFS的镜像系统为容器的分发带来了很多的便利,通是共同的镜像层只需要存储一份,实

现高效率的存储

版本管理类似于GIT的版本管理理念,用户可以更方便的创建、管理镜像文件

仓库系统仓库系统大大降低了镜像的分发和管理的成本

周边工具各种现有的工具(配置管理、云平台)对docker的支持,以及基于docker的pass、Cl等系统,

让docker的应用更加方便和多样。

31、Docker于Vagrant有何不同?

两者的定位完全不同

Vagrant类似于Boot2Docker(一款运行Docker的最小内核),是一套虚拟机的管理环境,Vagrant可

以在多种系统上和虚拟机软件中运行,可以在Windows、Mac等非Linux平台上为Docker支持,自身具

有较好的包装性和移植性。原生Docker自身只能运行在Linux平台上,但启动和运行的性能比虚拟机要

快,往往更适合快速开发和部署应用的场景。

32、开发环境中Docker与Vagrant该如何选择?

Docker不是虚拟机,而是进程隔离,对于资源的消耗很少,单一开发环境下Vagrant是虚拟机上的封

装,虚拟机本身会消耗资源。

33、如何将一台宿主机的docker环境迁移到另外一台宿主机?

停止docker服务,将整个docker存储文件复制到另外一台宿主机上,然后调整另外一台宿主机的配置即

可。

34、Docker容器创建后,删除了/var/run/netns目录下

的网络名字空间文件,可以手动恢复它:

查看容器进程ID,比如1234

到proc目录下,把对应的网络名字空间文字链接到/var/run/netns,然后通过正常的系统命令查看操作

容器的名字空间

35、什么是Docker镜像?

答:Docker镜像是Docker容器的源代码。换句话说,Docker镜像用于创建容器。使用build命令创建镜

像,并且在使用run启动时它们将生成容器。镜像存储在Docker注册表中,registry.hub.docker.com

为它们可能变得非常大,镜像被设计为由其他镜像层组成,允许在通过网络传输镜像时发送最少量的数

据。

36、解释基本的Docker使用工作流程是怎样的?

答:(

1)从Dockerfile开始,Dockerfile是镜像的源代码;(

2)创建Dockerfile后,可以构建它以创建

容器的镜像。图像只是“源代码”的“编译版本”,即Dockerfile;(

3)获得容器的镜像后,应使用注册表

重新分发容器。注册表就像一个git存储库,可以推送和拉取镜像;接下来,可以使用该图像来运行容

器。在许多方面,正在运行的容器与虚拟机(但没有虚拟机管理程序)非常相似。

37、什么是docker-compose?

简单点说就是,docker-compose就是一个编排同时管理多个容器的工具,与它配对使用的是一个

docker-compose.yaml文件,docker-compose命令必须在一个包含docker-compose.yaml文件目录下

才能使用。且当下docker-compose命令只能管理当前目录docker-compose文件中所涉及的容器,安装

在机器上的其他容器无法干扰。docker-compose的大部分命令基本和docker的命令重合,他们唯一的

区别是docker命令能管理机器上所有的容器和镜像文件,而docker-compose只能管理当前docker

compose文件所涉及的容器。

38、Docker镜像联合文件系统

UnionFS(联合文件系统):Union文件系统(UnionFS)是一种分成,轻量级并且高性能的文件系统,

他支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系

统下。Union文件系统的Docker镜像可以通过分层来进行继承,基于基础镜像,可以制作各种具体的应

用镜像。特性:一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把

各层文件系统进行叠加起来,这样最终的文件系统会包含所有底层的文件和目录。

Sudo docker inspect --format=’{{. State.pid}}’ $container_id 123439、什么类型的应用程序无状态或有状态更适合Docker容

器?

答:最好为Docker Container创建无状态应用程序。我们可以从应用程序中创建一个容器,并从应用程

序中取出可配置的状态参数。现在我们可以在生产环境和具有不同参数的QA环境中运行相同的容器。这

有助于在不同场景中重用相同的镜像。另外,无状态应用程序比有状态应用程序更容易使用Docker容器

进行扩展。

40、Docker 和虚拟机有啥不同?

Docker 是轻量级的沙盒,在其中运行的只是应用,虚拟机里面还有额外的系统。

41、Docker 安全么?

Docker 利用了 Linux 内核中很多安全特性来保证不同容器之间的隔离,并且通过签名机制来对镜像进行

验证。大量生产环境的部署证明,Docker 虽然隔离性无法与虚拟机相比,但仍然具有极高的安全性。

42、如何清理后台停止的容器?

可以使用 sudo docker rm $sudo( docker ps -a -q) 命令。

43、如何查看镜像支持的环境变量?

可以使用 docker run IMAGE env 命令。

44、当启动容器的时候提示:exec format error?如何解决问题

检查启动命令是否有可执行权限,进入容器手工运行脚本进行排查。

45、本地的镜像文件都存放在哪里?

Docker 相关的本地资源都存放在/var/lib/docker/目录下,其中container目录存放容器信息,graph

目录存放镜像信息,aufs目录下存放具体的内容文件。

46、如何退出一个镜像的bash,而不终止它?

按 Ctrl-p Ctrl-q。

47、退出容器时候自动删除?

使用 –rm 选项,例如 sudo docker run –rm -it ubuntu

48、怎么快速查看本地的镜像和容器?

可以通过docker images来快速查看本地镜像;通过docker ps -a快速查看本地容器。

49、什么是Docker Hub?

Docker Hub是一个由Docker公司运行和管理的基于云的存储库。它是一个在线存储库,DOcker进行

可以由其他用户发布和使用。

50、Docker容器可扩展到多远?

诸如Foogle和Twitter之类的大型Web部署以及诸如Heroku和dotCloud之类的平台提供商都基于容器技

术运行,并行运行的容器数以十万甚至至数八百计。

51、Docker容器退出时是否丢失数据?

当Docker容器退出时,不会丢失数据。应用程序写入磁盘的所有数据都会保留在其容器中直到您

明确删除该容器为止。即使在容器停止后,该容器的文件系统仍然存在。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值