rwadurian/backend
hailin 7b95711406 feat(android): 实现可靠的 gRPC 连接和流管理机制
基于 gRPC 官方最佳实践完整重构流管理系统

核心改进:
1. Keep-Alive 配置优化 (20s PING, 5s 超时, 永不超时空闲连接)
2. 创建 StreamManager 统一管理双向流生命周期
3. 实现自动重连机制 (Flow.retryWhen + 指数退避)
4. 添加 Android 网络状态监听 (立即 resetConnectBackoff)

技术细节:
- gRPC 流无法"恢复",必须重新发起 RPC 调用
- StreamManager 保存流配置,失败后自动重新发起
- 监听 GrpcConnectionEvent.Reconnected 触发流重启
- 删除旧的 callback 机制,使用 Flow 事件驱动

修复的关键问题:
- 网络断开后 eventStreamSubscribed flag 被清除导致 callback 不触发
- reSubscribeStreams 尝试"恢复"已关闭的 Flow (设计错误)
- 缺少 Keep-Alive 导致连接被中间设备清理
- 缺少网络监听导致 60 秒 DNS 解析延迟

参考资料:
- https://github.com/grpc/grpc-java/issues/8177
- https://grpc.io/docs/guides/keepalive/
- https://github.com/grpc/grpc-java/issues/4011

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-01-27 00:56:55 -08:00
..
.claude refactor: simplify mpc-service to gateway mode 2025-12-06 17:16:14 -08:00
api-gateway fix(kong): remove ws/wss protocols from WebSocket route 2026-01-18 21:36:30 -08:00
infrastructure chore(docker): 为 mpc-system、api-gateway、infrastructure 添加时区配置 2025-12-23 18:35:09 -08:00
mpc-system feat(android): 实现可靠的 gRPC 连接和流管理机制 2026-01-27 00:56:55 -08:00
scripts fix(scripts): 修正容器名为 rwa-blockchain-service 2025-12-15 10:34:25 -08:00
services fix(contribution-service): CDC planting_orders 阶段按 order_id 排序处理 2026-01-23 03:41:14 -08:00
.env.windows fix(referral): 修复 getMyReferralInfo 使用 userId 而不是 accountSequence 的问题 2025-12-14 05:05:03 -08:00
docker-compose.windows.yml feat(service-party-app): implement co-sign multi-party signing 2025-12-30 18:36:11 -08:00