首页
/ Snapd 2.69 版本发布:全面增强系统安全与功能扩展

Snapd 2.69 版本发布:全面增强系统安全与功能扩展

2025-06-25 11:55:50作者:田桥桑Industrious

项目概述

Snapd 是 Canonical 公司开发的 Snap 包管理系统核心组件,它为 Linux 系统提供了安全、可靠且易于管理的软件打包和分发解决方案。通过容器化技术,Snap 包可以在不同的 Linux 发行版上运行,同时保持隔离性和安全性。Snapd 负责管理这些 Snap 包的安装、运行、更新和卸载等全生命周期操作。

版本亮点

1. 全盘加密(FDE)功能优化

2.69 版本对全盘加密功能进行了多项改进。首先重构了磁盘列表功能,使其能够基于运行模式模型和模型正确解析路径。其次修复了 snapd 在 snap-failure 模式下运行时密钥环模式不正确的问题,提升了加密存储的可靠性。

2. Snap 组件管理增强

新版本改进了 Snap 组件的管理能力,特别是支持回退到包含组件的旧版 Snap 修订版本。同时修复了当系统已安装但非当前使用的内核 Snap 进行重塑时的问题,确保内核升级和回退更加稳定可靠。

3. 实验性配置数据库(Confdb)改进

Confdb 作为实验性功能在本版本获得了多项重要更新:

  • 通过 snapctl get 和 snap get 命令读取数据时现在会加载临时数据
  • 重命名了相关钩子,从 {plug}-view-changed 改为 observe-view-{plug}
  • 将 confdb 断言重命名为 confdb-schema
  • 调整了 confdb-control 断言中的操作符分组
  • 新增了 confdb-control API

这些改进使得配置管理更加灵活和强大。

4. 安全功能强化

AppArmor 增强

  • 扩展了探测功能,现在可以检测文件和目录的存在
  • 简化了实验性的提示功能监听器
  • 为元数据标签功能添加了解析器支持探测(当前禁用)
  • 实现了通知协议 v5(当前禁用)

非SUID snap-confine

开始实施第一阶段计划,用能力(capabilities)替代 setuid 来获得所需权限,这是提升系统安全性的重要一步。

动态安全配置文件

引入了初步支持动态更新安全配置的功能,为未来更灵活的安全策略管理奠定基础。

5. 机密虚拟机支持

针对机密虚拟机环境做了专门优化:

  • sysroot.mount 现在由 snap-bootstrap 动态创建,而非在 initramfs 中使用静态文件
  • 新增了 Snap 完整性 API 的新实现

6. 其他重要改进

  • 为 /v2/icons 添加了 Snap 图标回退机制,无需运行时网络访问
  • 新增 eMMC 设备更新支持
  • 改进对使用 /usr/libexec/snapd 的主机系统(如 Arch Linux、openSUSE)的支持
  • 自动检测未知发行版上的 Snap 挂载目录位置
  • 修改 snap-confine AppArmor 模板以允许所有 glibc HWCAPS 子目录,防止启动错误

问题修复

2.69 版本修复了多个重要问题:

  1. 修复了 snap-bootstrap 从 /sysroot/writable/system-data 挂载内核 Snap 的问题
  2. 解决了 snap-bootstrap 忙循环问题
  3. 修正了时间编码问题,在 Go 1.24+ 上使用 omitzero 替代 omitempty
  4. 修复了 openSUSE 上通过 permctl 设置 snapd 权限的问题
  5. 修正了 Snap 结构体 JSON 标签拼写错误
  6. 解决了 Snap 打包时配置钩子权限检查的文件模式不正确问题
  7. 确保 gadget Snap 重新安装时保留现有分区大小
  8. 修复了重新执行 snapd 工具时的命令行更新问题
  9. 改进了 'snap validate' 命令的输出格式和错误处理
  10. 解决了 snapd-confine 在不同架构间 time_t 大小差异的问题

接口改进

多个接口获得了功能增强和问题修复:

  1. polkit 接口:支持自定义 polkit 规则
  2. opengl 接口:修复了当 xorg 被 AppArmor 限制时的 NVIDIA GLX 问题
  3. log-observe 接口:添加了缺失的 udev 规则
  4. hostname-control 接口:修复了在 core24 中对 hostnamectl 的调用
  5. network-control 接口:允许移除创建的网络命名空间
  6. scsi-generic 接口:重新启用 scsi-generic 插头的基础声明
  7. u2f 接口:新增对 Arculus AuthentiKey 的支持

构建优化

  • 移除了不再需要的 udev 构建依赖
  • 添加了缺失的 systemd-dev 依赖
  • 使用 nomanagers 标签构建 snap-bootstrap,减少 1MB 大小
  • 更新 secboot 并修改 snap-bootstrap 移除 go 模板使用,减少 4MB 大小

使用限制

新版本禁止打包和安装具有特定配置钩子的 snapd、base 和 os Snap,这是出于安全考虑的重要限制。

总结

Snapd 2.69 版本带来了全面的安全增强和功能扩展,特别是在全盘加密、Snap 组件管理、配置数据库和接口支持等方面。这些改进不仅提升了系统的安全性和稳定性,也为开发者提供了更强大的工具和更灵活的管理选项。对于使用 Snap 包管理系统的 Linux 用户和开发者来说,升级到 2.69 版本将获得更完善的功能体验和更可靠的安全保障。

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

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
869
514
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
130
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
295
331
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
333
1.09 K
harmony-utilsharmony-utils
harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
ArkTS
18
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
kernelkernel
deepin linux kernel
C
22
5
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
829
22
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
601
58