Avalonia需借助第三方库实现自动更新:Windows推荐Squirrel.Windows(支持增量更新、回滚与静默安装,禁用单文件发布);跨平台可选GitHub Releases+自定义更新器(需自行处理下载、校验、解压与重启),关键在于异步执行、版本比对、哈希校验及备份恢复。
Avalonia 本身不内置自动更新机制,需结合第三方库或自研逻辑实现。主流且稳定的方式是使用 Squirrel.Windows(仅限 Windows)或跨平台方案如 GitHub Releases + 自定义更新器。关键在于资源打包、版本比对、静默下载与原子化替换。
Squirrel 是为 .NET 桌面应用设计的成熟更新框架,与 Avalonia 兼容良好,支持增量更新、回滚、静默安装和后台服务。
SquirrelAwareApp.HandleEvents() 在程序启动时注册更新逻辑(如检查更新、应用更新)squirrel --releasify 生成 nupkg 和 RELEASES 文件RELEASES 和各版本 .nupkg,客户端调用 UpdateManager.UpdateApp() 即可SingleFile = false),否则 Squirrel 无法正确提取和替换文件适用于 macOS/Linux/Windows,适合中小项目,控制力强但需自行处理下载、校验、解压和重启逻辑。
MyApp-1.2.0-linux-x64.tar.gz),附带 SHA256 校验值HttpClient 请求 https://api.
github.com/repos/{user}/{repo}/releases/latest 获取最新 tag 和 assetsAssemblyInformationVersion 或读取内置 version.json,决定是否下载无论选哪种方案,以下几点直接影响更新成功率和用户体验:
Task.Run 或 IProgress 报告进度基本上就这些。Squirrel 适合专注 Windows 的快速落地,GitHub 方案更适合多平台或需要定制策略的场景。核心逻辑其实不复杂,但容易忽略权限、路径、进程占用等细节,测试时务必覆盖首次安装、小版本热更、大版本覆盖、断网重试等典型用例。