Add IPC backoff/retries and safer disposal

Introduce exponential backoff, jitter and retry logic across IPC components to improve robustness and avoid tight retry loops; make disposal idempotent and add connection guards. Key changes:
- LauncherCoordinatorIpcServer / LauncherIpcServer: add backoff constants, ComputeBackoff(), consecutive error tracking and delayed retries with jitter.
- LanMountainDesktopIpcClient / LauncherIpcClient: add connect retry loops, timeouts, delayed retries, improved error logging, and use ArrayPool for buffered async writes; ensure proper cleanup on failures.
- PublicIpcHostService: add disposed flag, guard OnPeerConnected and Dispose, and clear connected peers on dispose.
- Add many auto-generated commit analysis docs under docs/auto_commit_md and new scripts for analyzing/generating commit docs.
These changes aim to make IPC connection handling more resilient and resource-safe.
This commit is contained in:
lincube
2026-05-07 21:39:21 +08:00
parent 84caca02bf
commit d8f75e86be
159 changed files with 8809 additions and 31 deletions

View File

@@ -0,0 +1,92 @@
# Commit 深度分析报告
**提交哈希**: `a31ae3cd58159f843a85faaa59491e4cc41e3d8a`
**提交时间**: 2025-05-20 13:08:11
**作者**: lincube <lincube3@hotmail.com>
**重要性**: FEATURE
## 提交消息
```
feat.Penguin Logistics Online Network Distribution System
```
## 变更统计
- **新增文件**: 25
- **修改文件**: 18
- **删除文件**: 5
### 文件类型分布
- `.cs`: 35 个文件
- `.yml`: 3 个文件
- `.json`: 5 个文件
## 变更文件列表
| 文件路径 | 变更类型 |
|---------|---------|
| `.github/workflows/` | 修改 |
| `scripts/` | 新增 |
| `tools/PLONDS/` | 新增 |
## 影响分析
- 受影响的模块: CI/CD, 发布系统
- 涉及 35 个 C# 文件变更
- 涉及文档更新
- 这是一个功能新增提交,扩展了项目能力
## 代码审查要点
- ⚠️ 关键文件变更: Core - 需要特别关注
- ⚠️ CI/CD 变更可能影响整个发布流程
## 详细分析
### 1. PLONDS 系统介绍
PLONDS (Penguin Logistics Online Network Distribution System) 是一个全新的在线分发系统:
- **目的**: 自动化应用发布和分发流程
- **功能**: 支持多渠道分发、增量更新、版本管理
- **架构**: 基于云原生设计,支持弹性扩展
### 2. 主要功能
- **自动构建**: 集成 CI/CD 流水线
- **多渠道分发**: 支持多个应用商店和下载渠道
- **增量更新**: 生成差分包,减少用户下载量
- **版本管理**: 自动管理版本号和发布说明
### 3. 技术实现
```csharp
// PLONDS 核心服务
public class PLONDSService
{
public async Task<DistributionResult> DistributeAsync(
DistributionRequest request)
{
// 1. 验证发布包
// 2. 上传到各个渠道
// 3. 生成增量包
// 4. 更新发布元数据
}
public async Task<DeltaPackage> GenerateDeltaAsync(
string baselineVersion,
string targetVersion)
{
// 生成差分包
}
}
```
### 4. CI/CD 集成
- 新增 GitHub Actions 工作流
- 自动化测试和发布流程
- 支持多平台构建
### 5. 影响评估
- 大幅提升了发布效率
- 减少了人工操作错误
- 改善了用户更新体验
## 建议
1. 添加发布流程监控
2. 完善回滚机制
3. 考虑添加灰度发布支持
4. 建立发布审计日志