关键词:
一、通用问题
1、Docker 和虚拟机有啥不同?
答:
Docker 是轻量级的沙盒,在其中运行的只是应用,虚拟机里面还有额外的系统。
2、Docker 安全么?
答:
Docker 利用了 Linux 内核中很多安全特性来保证不同容器之间的隔离,并且通过签名机制来对镜像进行验证。大量生产环境的部署证明,Docker 虽然隔离性无法与虚拟机相比,但仍然具有极高的安全性。
3、如何清理后台停止的容器?
答:
可以使用 sudo docker rm $sudo( docker ps -a -q) 命令。
4、如何查看镜像支持的环境变量?
答:
可以使用 docker run IMAGE env 命令。
5、当启动容器的时候提示:exec format error?如何解决问题
答:
检查启动命令是否有可执行权限,进入容器手工运行脚本进行排查。
6、本地的镜像文件都存放在哪里?
答:
与 Docker 相关的本地资源都存放在/var/lib/docker/目录下,其中container目录存放容器信息,graph目录存放镜像信息,aufs目录下存放具体的内容文件。
7、如何退出一个镜像的bash,而不终止它?
答:按 Ctrl-p Ctrl-q。
8、退出容器时候自动删除?
答:使用 –rm 选项,例如 sudo docker run –rm -it ubuntu
9、怎么快速查看本地的镜像和容器?
答:
可以通过docker images来快速查看本地镜像;通过docker ps -a快速查看本地容器。
二、镜像相关问题
1、如何批量清理临时镜像文件?
答:
可以使用sudo docker rmi $(sudo docker images -q -f danging=true)命令
2、如何查看镜像支持的环境变量?
答:
使用sudo docker run IMAGE env
3、本地的镜像文件都存放在哪里
答:
于Docker相关的本地资源存放在/var/lib/docker/目录下,其中container目录存放容器信息,graph目录存放镜像信息,aufs目录下存放具体的镜像底层文件。
4、构建Docker镜像应该遵循哪些原则?
答:
- 整体远侧上,尽量保持镜像功能的明确和内容的精简,要点包括: 尽量选取满足需求但较小的基础系统镜像
- 清理编译生成文件、安装包的缓存等临时文件
- 安装各个软件时候要指定准确的版本号,并避免引入不需要的依赖
- 从安全的角度考虑,应用尽量使用系统的库和依赖
- 使用Dockerfile创建镜像时候要添加.dockerignore文件或使用干净的工作目录
三、容器相关问题
1、容器退出后,通过docker ps 命令查看不到,数据会丢失么?
答:
容器退出后会处于终止(exited)状态,此时可以通过 docker ps -a 查看,其中数据不会丢失,还可以通过docker start 来启动,只有删除容器才会清除数据。
2、如何停止所有正在运行的容器?
答:
使用docker kill $(sudo docker ps -q)
3、如何清理批量后台停止的容器?
答:
使用docker rm $(sudo docker ps -a -q)
4、如何临时退出一个正在交互的容器的终端,而不终止它?
答:
按Ctrl+p,后按Ctrl+q,如果按Ctrl+c会使容器内的应用进程终止,进而会使容器终止。
5、很多应用容器都是默认后台运行的,怎么查看它们的输出和日志信息?
答:
使用docker logs,后面跟容器的名称或者ID信息
6、使用docker port 命令映射容器的端口时,系统报错Error: No public port ‘80’ published for …,是什么意思?
答:
创建镜像时Dockerfile要指定正确的EXPOSE的端口,容器启动时指定PublishAllport=true
7、可以在一个容器中同时运行多个应用进程吗?
答:
一般不推荐在同一个容器内运行多个应用进程,如果有类似需求,可以通过额外的进程管理机制,比如supervisord来管理所运行的进程
8、如何控制容器占用系统资源(CPU,内存)的份额?
答:
在使用docker create 命令创建容器或使用docker run 创建并运行容器的时候,可以使用-c|–cpu-shares[=0]参数来调整同期使用CPU的权重,使用-m|–memory参数来调整容器使用内存的大小。
四、仓库相关
1、仓库(Repository)、注册服务器(Registry)、注册索引(Index)有何关系?
答:
首先,仓库是存放一组关联镜像的集合,比如同一个应用的不同版本的镜像,注册服务器是存放实际的镜像的地方,注册索引则负责维护用户的账号,权限,搜索,标签等管理。注册服务器利用注册索引来实现认证等管理。
五、配置相关
1、Docker的配置文件放在那里。如何修改配置?
答:
Ubuntu系统下Docker的配置文件是/etc/default/docker,CentOS系统配置文件存放在/etc/sysconfig/docker
2、如何更改Docker的默认存储设置?
答:
Docker的默认存放位置是/var/lib/docker,如果希望将Docker的本地文件存储到其他分区,可以使用Linux软连接的方式来做。
六、Docker 与虚拟化
1、Docker与LXC(Linux Container)有何不同?
答:
LXC 利用Linux 上相关技术实现容器,Docker 则在如下的几个方面进行了改进:
- 移植性:通过抽象容器配置,容器可以实现一个平台移植到另一个平台;
- 镜像系统:基于AUFS的镜像系统为容器的分发带来了很多的便利,同时共同的镜像层只需要存储一份,实现高效率的存储;
- 版本管理:类似于GIT 的版本管理理念,用户可以更方面的创建、管理镜像文件;
- 仓库系统:仓库系统大大降低了镜像的分发和管理的成本;
- 周边工具:各种现有的工具(配置管理、云平台)对Docker的支持,以及基于Docker的Pass、CI等系统,让Docker的应用更加方便和多样化。
七、Other FAQ
1、Docker能在非Linux平台(Windows+MacOS)上运行吗?
答:
可以
2、如何将一台宿主机的docker环境迁移到另外一台宿主机?
答:
停止Docker服务,将整个docker存储文件复制到另外一台宿主机上,然后调整另外一台宿主机的配置即可。
数据库常见面试题总结
参考如下:数据库常见面试题(开发者篇)数据库优化SQL数据库面试题及答案常见面试题整理--数据库篇 查看详情
大数据——flink常见面试题整理(代码片段)
目录1.Flink的特点2.Flink和SparkStreaming的对比3.Flink和Blink、Alink之间的关系4.JobManager和TaskManager的职责5.Flink集群部署有哪些模式6.FlinkDataflow介绍7.Parallelism和Slot的理解8.Flink执行图9.DatastreamAPI常见的Transform算子10.Flink中窗口类型11.Fli 查看详情
java后端常见面试题总结
...子在准备面试相关的事情,现在把之前搜集整理的后端常见面试题整理成博客,分享给大家,有什么建议欢迎评论或私信。本博客仅供参考!这个整理只做查漏补缺之用,因为面试中常见的问题也是实际工作中可能会遇到的问题... 查看详情
大数据——hadoop常见面试题整理
目录1.大数据的特点(4V特征)2.谈谈Hadoop的优缺点3.为什么HDFS不适合存小文件4.Hadoop的核心组件有哪些,并说明下功能5.Hadoop与关系型数据库对比6.如果集群中DataNode出现错误(比如DataNode进程死亡或者网络故障造成... 查看详情
大数据——hbase常见面试题整理
目录1.什么是HBase2.大数据中为何要使用HBase(HBase在大数据中的优势)3.HBase与传统的关系数据库的区别4.RowKey的设计原则5.RowKey如何设计可以避免热点问题6.HRegionServer架构7.HBase性能优化方法总结表的设计写表操作 读表操... 查看详情
分布式常见面试题整理
一、分布式理论:1.什么是CAP理论?2.什么是BASE理论?3.什么是2PC?4.什么是3PC?5.什么是ZAB协议?6.什么是Raft协议?7.什么是Paxos算法?二、Zookeeper:8.ZooKeeper是什么?9.Zookeeper怎么保证主从节点的数据同步... 查看详情
vue常见面试题整理值得收藏
看看面试题,只是为了查漏补缺,看看自己那些方面还不懂。切记不要以为背了面试题,就万事大吉了,最好是理解背后的原理,这样面试的时候才能侃侃而谈。不然,稍微有水平的面试官一看就能看出,是否有真才实学还是刚... 查看详情
java常见面试题非常实用个人经验(代码片段)
1、左下角windows图标 2、点击设置 3、点击应用 4、点击左边菜单栏的启动按钮 5、然后你就可以在下面出现的开机自动启动的软件中,自由选择开或者关闭了。 查看详情
最近python常见面试题精华整理
1、list和tuple的一些区别区别一:语法差异1、使用方括号[]创建列表,而使用括号()创建元组区别二:是否可变2、列表是可变的,而元组是不可变的,这标志着两者之间的关键差异。我们可以修改列表的值,但是不修改元组的值... 查看详情
常见面试题整理---前端(不论出处)(代码片段)
1.浏览器渲染页面的过程用户输入URL地址浏览器解析URL解析出主机名浏览器将主机名转换成服务器ip地址(浏览器先查找本地DNS缓存列表没有的话再向浏览器默认的DNS服务器发送查询请求同时缓存)浏览器将端口号从URL中解析出... 查看详情
常见面试题整理:计算机网络篇,值得背诵收藏!(代码片段)
号外号外!《死磕Java并发编程》系列连载中,大家可以关注一波:「死磕Java并发编程05」阿里面试失败后,一气之下我图解了Java中18把锁「死磕Java并发编程04」说说JavaAtomic原子类的实现原理「死磕Java并发编程03... 查看详情
常见面试题整理:计算机网络篇,值得背诵收藏!(代码片段)
号外号外!《死磕Java并发编程》系列连载中,大家可以关注一波:「死磕Java并发编程05」阿里面试失败后,一气之下我图解了Java中18把锁「死磕Java并发编程04」说说JavaAtomic原子类的实现原理「死磕Java并发编程03... 查看详情
20个数据库常见面试题讲解()
20个数据库常见面试题讲解()进了互联网公司,整天也就是搬砖,等到了面试的时候,发现数据库方面,忘得一塌糊涂,抽时间整理了一些数据库方面的题。欢迎大家向我推荐你在面试过程中遇到的问题,我会把大家推荐的问题添... 查看详情
redis常见面试题总结
Redis面试题总结(1)2018年02月28日17:42:21LSX丨笔头先生阅读数:3568更多个人分类:面试题总结 (1)什么是redis? Redis 是一个基于内存的高性能key-value数据库。(有空再补充,有理解错误或不足欢迎指正) (2)Reids的... 查看详情
spring常见面试题(代码片段)
本文是通过收集网上各种面试指南题目及答案然后经过整理归纳而来,仅仅是为了方便以后回顾,无意冒犯各位原创作者。1.什么是Spring?Spring是个java企业级应用的开源开发框架。Spring主要用来开发Java应用,但是有些扩展是针... 查看详情
关于springboot常见面试题整理笔记
关于springboot常见面试题整理笔记1、什么是springboot,它主要有哪些优点Springboot是spring的子项目,称为一站式解决方案,集成了外部很多的优秀的框架,如常用的mysql、jdbc。主要优点:通过maven导入各种jar包ÿ... 查看详情
关于springboot常见面试题整理笔记
参考技术A[if!supportLists]1、[endif]什么是springboot,它主要有哪些优点Springboot是spring的子项目,称为一站式解决方案,集成了外部很多的优秀的框架,如常用的mysql、jdbc。主要优点:通过maven导入各种jar包,可以减少jar包的冲突;屏... 查看详情
java集合常见面试题进大厂必掌握---自行整理笔试题
java集合常见面试题进大厂必掌握—自行整理笔试题1、什么是集合,集合有哪些特点,它与数组的区别集合就是存储数据的容器;特点将数据封装成不同的多个对象;它们两者之间存储的容量不同,数组是固定... 查看详情