Snapd 2.69 版本发布:全面增强系统安全与功能扩展
项目概述
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 版本修复了多个重要问题:
- 修复了 snap-bootstrap 从 /sysroot/writable/system-data 挂载内核 Snap 的问题
- 解决了 snap-bootstrap 忙循环问题
- 修正了时间编码问题,在 Go 1.24+ 上使用 omitzero 替代 omitempty
- 修复了 openSUSE 上通过 permctl 设置 snapd 权限的问题
- 修正了 Snap 结构体 JSON 标签拼写错误
- 解决了 Snap 打包时配置钩子权限检查的文件模式不正确问题
- 确保 gadget Snap 重新安装时保留现有分区大小
- 修复了重新执行 snapd 工具时的命令行更新问题
- 改进了 'snap validate' 命令的输出格式和错误处理
- 解决了 snapd-confine 在不同架构间 time_t 大小差异的问题
接口改进
多个接口获得了功能增强和问题修复:
- polkit 接口:支持自定义 polkit 规则
- opengl 接口:修复了当 xorg 被 AppArmor 限制时的 NVIDIA GLX 问题
- log-observe 接口:添加了缺失的 udev 规则
- hostname-control 接口:修复了在 core24 中对 hostnamectl 的调用
- network-control 接口:允许移除创建的网络命名空间
- scsi-generic 接口:重新启用 scsi-generic 插头的基础声明
- 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 版本将获得更完善的功能体验和更可靠的安全保障。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
pc-uishopTNT开源商城系统使用java语言开发,基于SpringBoot架构体系构建的一套b2b2c商城,商城是满足集平台自营和多商户入驻于一体的多商户运营服务系统。包含PC 端、手机端(H5\APP\小程序),系统架构以及实现案例中应满足和未来可能出现的业务系统进行对接。Vue00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01