首页
/ Docker v28.1.0 版本深度解析:新特性与优化详解

Docker v28.1.0 版本深度解析:新特性与优化详解

2025-05-31 01:32:18作者:仰钰奇

Docker 是一个开源的容器化平台,它允许开发者将应用程序及其依赖打包成轻量级、可移植的容器,从而实现快速部署和跨环境一致性运行。Docker 通过容器技术解决了"在我机器上能运行"的问题,极大地简化了开发、测试和部署流程。

核心新特性

Docker Bake 子命令

v28.1.0 版本引入了一个重要的新命令 docker bake,作为 docker buildx bake 的别名。这个命令简化了多阶段构建流程,让开发者能够更高效地管理复杂的构建配置。Bake 功能特别适合需要同时构建多个镜像或针对不同平台构建的场景,它通过声明式的方式定义构建流程,显著提升了构建效率。

实验性 API 套接字共享

本次更新带来了一个实验性功能:通过 --use-api-socket 标志,容器可以直接访问宿主机的 Docker 套接字。这项功能不仅允许容器内执行 Docker 命令,还能共享宿主机的凭证信息。虽然目前处于实验阶段,但它为开发更复杂的容器编排工具和 CI/CD 流水线提供了新的可能性。需要注意的是,出于安全考虑,生产环境中应谨慎使用此功能。

多平台镜像支持增强

docker image inspect 命令新增了 --platform 标志,允许用户检查多平台镜像中特定平台的配置信息。这一改进对于处理多架构镜像(如同时支持 amd64 和 arm64 的镜像)的开发者特别有价值,能够更精确地获取目标平台的镜像详情。

重要优化与修复

容器网络改进

网络子系统在本版本中获得了多项重要修复:

  • 修复了 Swarm 容器主机端口映射在 docker psdocker inspect 中重复显示的问题
  • 解决了容器网络连接失败时出现的"Bridge port not forwarding"错误
  • 改进了默认桥接网络中 --link 参数的移除机制
  • 优化了网络端点关系跟踪机制,减少了误报"has active endpoints"错误的情况

镜像管理增强

镜像处理方面有几个值得注意的改进:

  • docker load 现在能正确保留被替换的镜像
  • 修复了与私有仓库交互时 docker pull/push 失败的问题
  • 针对 containerd 镜像存储后端,优化了远程仓库错误处理机制
  • 现在可以显示非层类型镜像blob的拉取进度

性能优化

  • 修复了 docker stats 在高CPU核心数机器上运行异常的问题
  • 改进了 rootless Docker 在缺少 ip_tables 内核模块的主机上的安装体验
  • 优化了 iptables 规则管理,防止在 firewalld 重载后出现不必要的规则残留

开发者工具更新

CLI 改进

命令行界面有多项用户体验提升:

  • 新增了上下文名称的 shell 补全功能
  • 改进了 docker service scale 命令的补全体验
  • docker images --tree 现在默认隐藏未标记和悬空镜像
  • docker system info 现在会在无法连接 Docker 守护进程时提供明确的退出码

API 变更

API 版本升级至 v1.49,主要变化包括:

  • /image/{name}/json 端点新增 platform 参数,支持查询多平台镜像的特定变体
  • /info 端点现在返回防火墙后端配置信息
  • 移除了多个已弃用字段,包括 AllowNondistributableArtifactsCIDRsAllowNondistributableArtifactsHostnames

生态系统更新

组件版本升级

  • BuildKit 更新至 v0.21.0,带来构建性能改进和新特性
  • Compose 升级到 v2.35.0,增强了编排能力
  • Go 运行时更新至 1.23.8,包含安全修复和性能优化

平台支持扩展

新增了对多个新操作系统版本的支持:

  • Debian "Trixie"
  • Fedora 42
  • Ubuntu 25.04 "Plucky Puffin"

总结

Docker v28.1.0 是一个功能丰富的中期版本,在多平台镜像支持、网络稳定性和开发者体验方面都有显著提升。实验性的 API 套接字共享功能为高级用例开辟了新途径,而大量的错误修复和性能优化则进一步巩固了 Docker 作为容器化平台领导者的地位。对于开发者而言,新引入的 docker bake 命令将简化复杂构建流程,而增强的多平台支持则让跨架构开发更加顺畅。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
136
187
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
884
523
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
362
381
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
182
264
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
84
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
613
60
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
118
78