百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

(十四) Docker 面试通关秘籍:从基础到进阶

off999 2025-04-07 17:40 25 浏览 0 评论



一、Docker概述

Docker为一种开源的“容器化平台”,其能够让开发者把应用程序及其依赖打包进一个轻量级、可移植的容器内,达成“跨环境一致运行”。

  • 核心概念镜像(Image):这是一种只读模板,涵盖应用运行所需的代码、库以及环境配置。容器(Container):是镜像的运行实例,提供隔离的沙箱环境,共享宿主机内核。仓库(Registry):作为存储和分发镜像的平台(例如Docker Hub)。
  • 与传统虚拟机的差异: Docker容器直接共享宿主机内核,无需模拟完整操作系统,所以“启动更为迅速”(秒级)、“资源占用更少”(无Hypervisor开销)。

二、Docker的发展趋向

  1. 云原生技术的基石:与Kubernetes、Service Mesh相结合,成为微服务架构的核心部件。
  2. 边缘计算的崛起:其轻量级特性使其在IoT和边缘设备部署方面具备优势。
  3. 安全性能提升:容器运行时安全工具(如Falco)和镜像扫描工具的普及。
  4. CI/CD标准化:与Jenkins、GitLab等工具深度融合,推动自动化流水线。

三、Docker常用指令

以下为高频操作指令(完整列表可参考):

1. 镜像管理

docker pull nginx:latest  # 拉取镜像 
docker images # 查看本地镜像 
docker rmi  # 删除镜像 
docker image rm [镜像ID] # 删除镜像 
docker build -t myapp. # 通过Dockerfile构建镜像

2. 容器操作

docker run -d -p 80:80 nginx # 启动容器(后台运行) 
docker ps #查看运行中的容器
docker ps -a # 查看所有容器(含已停止) 
docker exec -it  /bin/sh # 进入运行中的容器 
---exit 或 Ctrl+D 退出容器
docker stop  # 停止容器 
docker restart  # 重启容器 
docker rm  # 删除容器 
docker logs  # 查看容器日志
docker inspect [容器ID/名称]  #显示容器的配置、网络、挂载卷等详细信息,可查看日志挂载地址等
docker system prune   # 清理未使用的镜像、容器和缓存
docker commit [容器ID] [新镜像名]   #容器生成镜像

3. 数据与网络

docker volume create my_volume # 创建数据卷
 docker network create my_network # 创建自定义网络
 docker run -v [宿主机目录]:[容器目录]    #实现宿主机与容器间的数据共享
  1. 日志与进程
docker logs -f <容器ID或名称>      # -f 参数实现日志实时刷新
docker logs --tail=100 <容器ID或名称>   # 显示最后100行日志(数值可自定义)
docker logs -t <容器ID或名称>          # 显示每条日志的生成时间
docker logs -f --tail=200 <容器ID或名称>    #实时查看并仅显示最后200行

查看历史日志文件
日志文件路径:
/var/lib/docker/containers/<容器ID>/<容器ID>-json.log
可直接用 cat 或 tail 命令操作

docker top <容器ID>   #查看容器内进程 

5.服务与配置

systemctl start/stop/restart docker  #启停服务
systemctl enable docker  #设置开机自启

四、Docker使用方式

1. 快速入门

  1. 安装Docker
  • Linux:apt-get install docker-ce
  • Windows/macOS:下载Docker Desktop。

2.运行首个容器

docker run hello-world

2. 核心实践技巧

  • 多阶段构建:借助Dockerfile分阶段编译和打包,缩减最终镜像体积。
  • 容器数据持久化:运用-v挂载宿主机目录或数据卷。
  • Compose编排:通过docker-compose.yml管理多容器应用。

五、常见面试问题

  1. Docker与虚拟机的本质区别?

Docker共享宿主机内核,虚拟机需独立OS;Docker启动更快、资源占用更低。

  • 虚拟机:通过 Hypervisor 虚拟化硬件,每个 VM 包含完整的 OS,资源占用高,启动慢。
  • Docker:基于宿主机的内核,通过容器隔离进程,共享 OS 内核,轻量、启动快、资源占用低。
  1. 如何优化Docker镜像大小?

使用Alpine基础镜像、多阶段构建、合并RUN指令减少层数。

  1. 容器如何与宿主机共享文件?

通过-v /宿主机路径:/容器路径挂载卷。

4.解释Docker的网络模式?

默认提供bridge(桥接)、host(共享宿主机网络)、none(无网络)等模式。

5.如何构建一个 Docker 镜像?

docker build -t image-name:tag  #基于当前目录的 Dockerfile 构建镜像,-t 指定名称和标签。

6.如何运行一个容器并映射端口?

docker run -d -p 宿主机端口:容器端口 --name 容器名 镜像名

7.Dockerfile 中的COPY和ADD有什么区别?

  • COPY:仅复制本地文件到容器。
  • ADD:支持复制并自动解压压缩包,或从 URL 下载文件(推荐优先使用 COPY)。

8.如何减少 Docker 镜像的体积?

  • 使用多阶段构建(Multi-stage build)。
  • 选择轻量级基础镜像(如 Alpine Linux)。
  • 合并命令减少层数(用 && 连接命令,清理缓存文件)。

9.Docker 有哪些网络模式?

  • bridge(默认):容器通过虚拟网桥连接到宿主机。
  • host:容器直接使用宿主机的网络命名空间。
  • none:无网络。
  • overlay:用于跨主机的容器通信(如 Swarm 集群)。

10.如何实现容器间数据持久化?

  • 数据卷(Volume):独立于容器的存储,通过 docker volume create 创建。
  • 绑定挂载(Bind Mount):将宿主机目录挂载到容器(-v /宿主机路径:/容器路径)。

11.什么是 Docker Compose?

  • 用于定义和运行多容器应用,通过 docker-compose.yml 配置服务。
  • 示例:启动一个包含 Web 服务、数据库和缓存的微服务应用。

12.如何防止容器以 root 权限运行?

在 Dockerfile 中指定非 root 用户:

RUN useradd -m appuser && chown -R appuser /app
USER appuser

13.容器启动后立即退出,如何排查?

  • 检查日志:docker logs 容器ID。
  • 检查容器进程是否在前台运行(如未指定 CMD 或 ENTRYPOINT 可能直接退出)。
  • 使用 docker run -it 镜像名 /bin/sh 进入交互模式调试。

14.如何在生产环境中部署 Docker?

  • 使用编排工具(如 Kubernetes、Docker Swarm)。
  • 配置健康检查、日志收集、监控(Prometheus + Grafana)。
  • 镜像仓库管理(如 Harbor、AWS ECR)。

六、 实际应用举例

本次阳仔通过举例说明在实际应用中如何使用docker启动mysql的详细步骤和注意事项

第一步:

1. 拉取 MySQL 镜像

docker pull mysql:5.7 # 推荐指定版本(如 5.7),避免使用 latest

2. 运行 MySQL 容器

docker run -d \
  --name mysql-container \
  -p 3306:3306 \
  -e MYSQL_ROOT_PASSWORD=your_password \
  -v /宿主机路径:/var/lib/mysql \
  mysql:5.7 

参数说明:

  • -d:容器后台运行。
  • --name:容器命名(例如 mysql-container)。
  • -p 3306:3306:将宿主机的 3306 端口映射到容器的 3306 端口,允许外部访问13。
  • -e MYSQL_ROOT_PASSWORD=your_password:设置 root 用户密码(必填项)12。
  • -v /宿主机路径:/var/lib/mysql:挂载数据目录,防止容器删除后数据丢失358。

3. 验证容器状态

  1. 通过容器内命令行
docker ps -a | grep 'mysql'

查看mysql服务是否启动正常,并查看3306端口是否放开,服务状态是否正常

  1. 使用第三方数据库链接软件查看是否链接正常 (DBeaver)

测试链接正常则代表服务正常,如果链接失败看看是不是mysql链接的驱动异常和检查步骤1是否正常

  • 主机:localhost 或宿主机 IP
  • 端口:3306
  • 用户/密码:root 和 your_password

我是阳仔,喜欢的朋友,欢迎点赞,收藏,转发和评论,感谢各位朋友的支持!!!

相关推荐

软件误删怎么找回来(软件删掉怎么找回)
  • 软件误删怎么找回来(软件删掉怎么找回)
  • 软件误删怎么找回来(软件删掉怎么找回)
  • 软件误删怎么找回来(软件删掉怎么找回)
  • 软件误删怎么找回来(软件删掉怎么找回)
桌面语言栏不见了怎么办(桌面语言栏不见了怎么办呢)

如果您的语言栏在某个应用程序或操作系统中消失了,您可以尝试以下方法来恢复它。首先,您可以检查操作系统的设置,查看语言和区域选项是否正确设置。如果设置正确,但语言栏仍然不可见,您可以尝试重新启动计算机,...

怎么装win98(怎么装win7系统教程)

如何安装windows98  一、具体安装步骤  备份好重要文件之后,就可以安装windows98了。  第一步:启动安装程序。  用户如果原来已安装了windows95/97/98,现在拟对其进行升...

u盘写保护无法格式化怎么解除
  • u盘写保护无法格式化怎么解除
  • u盘写保护无法格式化怎么解除
  • u盘写保护无法格式化怎么解除
  • u盘写保护无法格式化怎么解除
app下载官网(欧歌影视app下载官网)

需要先进入佳能官网的下载页面,选择手机APP下载选项,根据手机操作系统的不同选择相应的下载链接即可成功下载佳能手机APP。下载链接通常会在网站的首页或者是产品页面上提供。总的来说,下载佳能手机APP非...

qq空间相册密码怎么破
  • qq空间相册密码怎么破
  • qq空间相册密码怎么破
  • qq空间相册密码怎么破
  • qq空间相册密码怎么破
互盾手机数据恢复软件下载(互盾数据恢复软件可以免费使用一次吗)

要的。手机如果可以连电脑当做u盘识别就可以用恢复软件。比如用安易。至于能不能出现盘符,可以网上查一下你这个手机型号可不可以,或者问问手机售后。1、安装互盾安卓恢复大师,运行软件后,将手机连接到电脑上...

电脑wifi突然变成红叉搜不到

1、WiFi功能未开启:很多时候出现WiFi红色叉叉图标,可能就是无线WiFi的开关或者按键没有开启导致的。一般的笔记本键盘上面都有一个F5开启WiFi的功能,有的需要结合Fn功能键一起按。每个品牌的...

正版win10系统一键重装官网(一键装机win10正版系统)

1、下载小白一键重装软件,打开软件后选择我们要安装的系统。?2、接着小白给出我们一些常用的电脑软件,大家可根据自己需要进行下载。?3、然后就是我们就耐心的等待系统镜像的下载吧。?4、部署环境完成后我们...

windows8系统自己怎么装(如何安装windows 8)

要在线安装Windows8系统,您可以按照以下步骤操作:1.准备安装媒体:在您的计算机上打开一个现代的网络浏览器(如Chrome、Firefox或Edge),然后前往Microsoft...

win10登录选项没有密码设置(win10没有登陆密码框)

是该电脑没设置密码,所以登录时看不到密码选项。电脑开机后,要设置密码,设置完成后,重新启动电脑,就会出现密码登录框,输入密码并正确后,电脑才能正常进入系统。1、首先进入安全模式;进入安全模式教程:2、...

小白刷机官网(小白刷机助手)

平板的话,和处理器有关,如果处理器只支持win8是不能刷win10的。

windows关闭端口命令(windows 关端口)

1、点击控制面板。2、进入控制面板,然后点击系统和安全。3、进入系统和安全,点击Windows防火墙。4、进入Windows防火墙,点击左侧的高级设置。5、进入防火墙高级设置,点击入站规则。6、点击入...

360免费wifi老版本(360免费wifi2019下载安装)
  • 360免费wifi老版本(360免费wifi2019下载安装)
  • 360免费wifi老版本(360免费wifi2019下载安装)
  • 360免费wifi老版本(360免费wifi2019下载安装)
  • 360免费wifi老版本(360免费wifi2019下载安装)
无线wifi路由器怎么安装(请问无线路由器怎么安装)

安装的方法/步骤:1、怎么安装无线路由器呢?首先把网线的其中一头插入进光猫里面。2、接着用网线的另一头插入进无线路由器的蓝色接口处,这样就安装好无线路由器啦。3、点击打开电脑浏览器,输入路由器设置地址...

取消回复欢迎 发表评论: