mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-05-14 06:34:30 +08:00
- 新增 request pipeline benchmark 的 handwritten generated request registry,并通过真实程序集注册路径接上 generated invoker provider - 更新 RequestPipelineBenchmarks 宿主接线与 benchmark README,统一默认 request 与 pipeline 场景的 generated-provider 口径 - 更新 CQRS 迁移 tracking 与 trace,记录 RP-106 的基线、验证结果与下一恢复点
39 KiB
39 KiB
CQRS 重写迁移跟踪
目标
围绕 GFramework 当前的双轨 CQRS 现状,继续完成以“去外部依赖、降低反射、收口公开入口”为目标的
CQRS 迁移与收敛。
当前恢复点
- 恢复点编号:
CQRS-REWRITE-RP-106 - 当前阶段:
Phase 8 - 当前 PR 锚点:
PR #340 - 当前结论:
GFramework.Cqrs已完成对外部Mediator的生产级替代,当前主线已从“是否可替代”转向“仓库内部收口与能力深化顺序”dispatch/invoker生成前移已扩展到 request / stream 路径,RP-077已补齐 request invoker provider gate 与 stream gate 对称的 descriptor / descriptor entry runtime 合同回归RP-078已补齐 mixed fallback metadata 在 runtime 不允许多个 fallback attribute 实例时的单字符串 attribute 回退回归RP-079已补齐 runtime 缺少 generated handler registry interface 时的 generator 静默跳过回归RP-080已将基础 generation gate 回归扩展到 notification handler interface、stream handler interface 与 registry attribute 缺失分支RP-081已继续补齐基础 generation gate 的 logging 与 DI runtime contract 缺失分支- 当前
RP-082已补齐基础 generation gate 的 request handler runtime contract 缺失分支 RP-083已补齐 mixed direct / reflected-implementation request 与 stream invoker provider 发射顺序回归RP-084已引入独立GFramework.Cqrs.Benchmarks项目,作为持续吸收Mediatorbenchmark 组织方式的第一落点RP-085已补齐 stream request benchmark,对齐Mediatormessaging benchmark 的第二个核心场景RP-086已补齐 request pipeline0 / 1 / 4数量矩阵,开始把 benchmark 关注点从单纯 messaging steady-state 扩展到行为编排开销RP-087已补齐 request startup benchmark,把 initialization 与 cold-start 维度正式纳入GFramework.Cqrs.Benchmarks- 当前
RP-088已补齐 request invoker reflection / generated-provider 对照,开始直接量化 dispatcher 预热 generated descriptor 的收益 - 当前
RP-089已补齐 stream invoker reflection / generated-provider 对照,使 generated descriptor 预热收益从 request 扩展到 stream 路径 - 当前
RP-090已收敛PR #326benchmark review:统一 benchmark 最小宿主构建、冻结 GFramework 容器、限制 MediatR 扫描范围,并恢复 request startup cold-start 对照 - 当前
RP-091已把 benchmark 项目发布面隔离与包清单校验前移到 PR:GFramework.Cqrs.Benchmarks明确保持不可打包,publish.yml与ci.yml复用同一份 packed-modules 校验脚本 RP-092已补齐 request handlerSingleton / Transient生命周期矩阵 benchmark,并明确把Scoped对照留到具备真实显式作用域边界的宿主模型后再评估RP-093已把GFramework.Core的 legacySendCommand/SendQuery兼容入口收敛到底层统一GFramework.Cqrsruntime,同时补充Mediator未吸收能力差距复核RP-094已按PR #334latest-head review 收口 legacy bridge 的测试注册方式、模块运行时依赖契约、异步取消语义、XML 文档缺口与兼容文档回退边界RP-095已继续收口PR #334剩余 review:把 legacy 同步 bridge 的阻塞等待统一切到线程池隔离 helper、补齐ArchitectureContext/ executor 共享 dispatch helper、修正 bridge fixture 的并行与容器释放约束,并为 runtime bridge 与 async void command cancellation 增补回归测试RP-096已再次使用$gframework-pr-review复核PR #334latest-head review,确认仍显示为 open 的 AI threads 在本地代码中已无新增仍成立的运行时 / 测试 / 文档缺陷,剩余差异主要是 GitHub thread 未 resolve 的状态滞后RP-097已继续收口PR #334latest-head nitpick:为AsyncQueryExecutorTests/CommandExecutorTests补齐可观察的上下文保留断言,并让RecordingCqrsRuntime在测试替身返回错误响应类型时抛出带请求/类型信息的诊断异常- 当前
RP-098已再次使用$gframework-pr-review复核PR #334latest-head review,并收口LegacyCqrsDispatchHelper.TryResolveDispatchContext(...)过宽吞掉InvalidOperationException的真实运行时诊断退化问题;现在仅把“上下文尚未就绪”视为允许 fallback 的信号,并为 fallback / 异常冒泡分别补齐回归测试 RP-099已补齐GFramework.Cqrs的最小 stream pipeline seam:新增IStreamPipelineBehavior<,>/StreamMessageHandlerDelegate<,>、RegisterCqrsStreamPipelineBehavior<TBehavior>()、dispatcher 侧 stream pipeline executor 缓存与 generated stream invoker 兼容回归,以及Architecture公开注册入口与对应文档说明- 当前
RP-100已使用$gframework-pr-review复核PR #339latest-head review:收口RegisterCqrsStreamPipelineBehavior<TBehavior>()的异常契约文档、为StreamPipelineInvocation.GetContinuation(...)补齐并发 continuation 缓存说明、抽取MicrosoftDiContainer的 CQRS 行为注册公共逻辑,并顺手修复当前 branch diff 内ICqrsRequestInvokerProvider.cs的 XML 缩进格式问题 - 当前
RP-101已按用户新增 benchmark 诉求收口 request 热路径:为IIocContainer新增不激活实例的HasRegistration(Type)、让 dispatcher 在0 pipeline场景下跳过空行为解析,并为MicrosoftDiContainer的热路径查询补齐 debug-level 守卫,避免无效日志字符串分配 - 当前
RP-102已把GFramework.Cqrs.Benchmarks的Mediator对照组收口为官方 NuGet 引用(Mediator.Abstractions/Mediator.SourceGenerator3.0.2),不再使用本地ai-libs/Mediatorproject reference;RequestBenchmarks现已新增 source-generated concreteMediator对照方法,并通过RequestLifetimeBenchmarks复核 hot path 收口后的新基线 - 当前
RP-102已将BenchmarkDotNet.Artifacts/收口为默认忽略路径,并把 request steady-state / lifetime benchmark 复跑升级为 CQRS 性能相关改动的默认回归门槛;当前阶段目标明确为“持续逼近 source-generatedMediator,并至少稳定超过反射版MediatR” - 当前
RP-103已使用$gframework-pr-review复核PR #340latest-head review:修复CreateStream_Should_Throw_When_Stream_Pipeline_Behavior_Context_Does_Not_Implement_IArchitectureContext因 strict mock 未配置HasRegistration(Type)产生的 CI 失败,收紧MicrosoftDiContainer.HasRegistration(Type)到与GetAll(Type)一致的服务键可见性语义,补齐IIocContainer.HasRegistration(Type)的异常/XML 契约与docs/zh-CN/core/ioc.md的用户接入说明,并同步 benchmark 注释与 active tracking/trace 到当前 PR 锚点 - 当前
RP-104已继续沿用$gframework-batch-boot 50压 request 热路径:先把CqrsDispatcher.SendAsync(...)改成 direct-returnValueTask,移除 dispatcher 自身的async/await状态机;再让MicrosoftDiContainer.HasRegistration(Type)在冻结后复用预构建的服务键索引,避免每次命中零 pipeline request 都线性扫描全部描述符;本轮 benchmark 表明第一刀显著压低 steady-state / lifetime request,第二刀在当前短跑下主要确认“无回退、收益不明显” - 当前
RP-105已继续沿用$gframework-batch-boot 50压默认 request steady-state:为 benchmark 最小宿主补齐 CQRS runtime / registrar / registration service 基础设施,让RequestBenchmarks不再只测反射路径,而是通过 handwritten generated registry +RegisterCqrsHandlersFromAssembly(...)真实接上 generated request invoker provider;本轮 benchmark 表明默认 request 路径进一步从约70.298 ns / 32 B压到约65.296 ns / 32 B,Singleton / Transientlifetime 也同步收敛到约68.772 ns / 32 B与73.157 ns / 56 B - 当前
RP-106已把同一套 generated-provider 宿主收口扩展到RequestPipelineBenchmarks:新增 handwrittenGeneratedRequestPipelineBenchmarkRegistry,并让RequestPipelineBenchmarks改走RegisterCqrsHandlersFromAssembly(...)+ benchmark CQRS 基础设施预接线;本轮 benchmark 表明0 pipelinesteady-state 进一步收敛到约64.755 ns / 32 B,1 pipeline约353.141 ns / 536 B,4 pipeline在短跑噪音下维持约555.083 ns / 896 B
ai-planactive 入口现以RP-106为最新恢复锚点;PR #340、PR #339、PR #334、PR #331、PR #326、PR #323、PR #307与其他更早阶段细节均以下方归档或说明为准
当前活跃事实
- 当前分支为
feat/cqrs-optimization - 本轮
$gframework-batch-boot 50以origin/main(4d6dbba6, 2026-05-08 11:13:33 +0800) 为基线;本地main仍落后,不作为 branch diff 基线 - 当前已提交分支相对
origin/main的累计 branch diff 为8 files / 358 lines - 本批待提交工作树集中在
GFramework.Cqrs.Benchmarks/Messaging/RequestPipelineBenchmarks.cs、GFramework.Cqrs.Benchmarks/Messaging/GeneratedRequestPipelineBenchmarkRegistry.cs与GFramework.Cqrs.Benchmarks/README.md,新增 generated-provider pipeline 宿主接线后仍明显低于$gframework-batch-boot 50的文件阈值 GFramework.Cqrs.Benchmarks作为 benchmark 基础设施项目,必须持续排除在 NuGet / GitHub Packages 发布集合之外GFramework.Cqrs.Benchmarks现已覆盖 request steady-state、pipeline 数量矩阵、startup、request/stream generated invoker,以及 request handlerSingleton / Transient生命周期矩阵GFramework.Cqrs.Benchmarks当前以 NuGet 方式引用Mediator.Abstractions/Mediator.SourceGenerator3.0.2;ai-libs/Mediator只保留为本地源码/README 对照资料,不再参与 benchmark 项目编译- 当前 request steady-state benchmark 已形成 baseline /
Mediator/MediatR/GFramework.Cqrs四方对照:最新约5.680 ns / 32 B、6.565 ns / 32 B、54.737 ns / 232 B、63.644 ns / 32 B - 当前 request lifetime benchmark 已继续收敛:
Singleton下GFramework.Cqrs最新约69.896 ns / 32 B,Transient下约72.880 ns / 56 B;相较RP-104前的73.005 ns / 32 B与74.757 ns / 56 B已继续下降 - 当前 request pipeline benchmark 已改为与默认 request steady-state 相同的 generated-provider 宿主接线路径:
0 pipeline约64.755 ns / 32 B,1 pipeline约353.141 ns / 536 B,4 pipeline约555.083 ns / 896 B - 本轮已验证旧 benchmark 劣化的两个主热点:
0 pipeline场景下仍解析空行为列表,以及容器查询热路径在 debug 禁用时仍构造日志字符串;两者收口后,GFramework.Cqrsrequest 路径不再出现额外数百字节分配 HasRegistration(Type)现在只把“同一服务键已注册”或“开放泛型服务键可闭合到目标类型”视为命中,不再把“仅以具体实现类型自注册”的行为误判为接口服务已注册;该语义与Get(Type)/GetAll(Type)已重新对齐GFramework.Cqrs.Tests/Cqrs/CqrsDispatcherContextValidationTests.cs已同步适配HasRegistration(Type)fast-path,避免 strict mock 因缺少新调用配置而在上下文失败语义断言前提前抛出Moq.MockExceptiondocs/zh-CN/core/ioc.md已新增HasRegistration(Type)的使用语义、热路径用途与“按服务键而非可赋值关系判断”的示例说明- 当前 request steady-state 仍落后于 source-generated
Mediator与MediatR,但差距已从“额外数百字节分配 + 近 300ns”收敛到“零 pipeline fast-path 仍慢约31ns/3.6x于Mediator”;下一批若继续压 request dispatch,应优先评估默认路径吸收 generated invoker/provider 的空间 - 本轮
SendAsync(...)的 direct-returnValueTask改动已证明确实是有效热点:同样的短跑配置下,GFramework.Cqrssteady-state request 从约83.823 ns下探到69-70 ns区间 - 冻结后
HasRegistration(Type)服务键索引化在当前短跑下没有带来同等量级的可见收益,但也没有引入功能回退或额外分配;后续若继续压零 pipeline request,应优先重新评估“默认 request 路径进一步吸收 generated invoker/provider”而不是继续堆叠同层级微优化 - 默认
RequestBenchmarks与RequestPipelineBenchmarks现在都已通过 handwritten generated registry + 真实RegisterCqrsHandlersFromAssembly(...)宿主接线命中 generated request invoker provider,不再只代表纯反射 request binding 路径 - 当前性能回归门槛已收紧为:只要改动触达
GFramework.Cqrsrequest dispatch、DI 热路径、invoker/provider、pipeline 或 benchmark 宿主,就必须至少复跑RequestBenchmarks.SendRequest_*与RequestLifetimeBenchmarks.SendRequest_* - 当前阶段的性能验收目标已明确为:默认 request steady-state 路径不要求超过 source-generated
Mediator,但必须持续逼近它,并至少稳定快于基于反射 / 扫描的MediatR GFramework.Core当前已通过内部 bridge request / handler 把 legacyICommand、IAsyncCommand、IQuery、IAsyncQuery接到统一ICqrsRuntime- 标准
Architecture初始化路径会自动扫描GFramework.Core程序集中的 legacy bridge handler,因此旧SendCommand(...)/SendQuery(...)无需改变用法即可进入统一 pipeline CommandExecutor、QueryExecutor、AsyncQueryExecutor仍保留“无 runtime 时直接执行”的回退路径,用于不依赖容器的隔离单元测试LegacyCqrsDispatchHelper现统一负责 runtime dispatch context 解析,以及 legacy 同步 bridge 对ICqrsRuntime.SendAsync(...)的线程池隔离等待ArchitectureContext、CommandExecutor、QueryExecutor的同步 CQRS/legacy bridge 入口不再直接在调用线程上阻塞SendAsync(...).GetAwaiter().GetResult()GFramework.Core.Tests现通过InternalsVisibleTo("GFramework.Core.Tests")直接实例化内部 bridge handler,不再依赖字符串反射装配测试桥接注册- 使用
LegacyBridgePipelineTracker的ArchitectureContextTests与ArchitectureModulesBehaviorTests现都显式标记为NonParallelizable ArchitectureContextTests.CreateFrozenBridgeContext(...)现把冻结容器所有权显式交回调用方,并在每个 bridge 用例的finally中释放CommandExecutorModule、QueryExecutorModule、AsyncQueryExecutorModule现改为GetRequired<ICqrsRuntime>()并在 XML 文档里显式声明注册顺序契约,避免 runtime 缺失时静默回退LegacyAsyncQueryDispatchRequestHandler、LegacyAsyncCommandResultDispatchRequestHandler、LegacyAsyncCommandDispatchRequestHandler现都通过ThrowIfCancellationRequested()+WaitAsync(cancellationToken)显式保留调用方取消可见性- 相对
ai-libs/Mediator,当前仍未完全吸收的能力集中在五类:facade 公开入口、telemetry、notification publisher 策略、生成器配置与诊断、生命周期/缓存公开配置面 - 发布工作流已有 packed modules 校验,但 PR 工作流此前没有等价的 solution pack 产物名单校验
- 本地
dotnet pack GFramework.sln -c Release --no-restore -o <temp-dir>当前只产出 14 个预期包,未复现 benchmark.nupkg PR #334在2026-05-07的 latest-head review 当前显示CodeRabbit 10/Greptile 5个 open thread;本轮再次复核后确认其中大部分仍是已实质修复但未 resolve 的 stale thread,仅LegacyCqrsDispatchHelper.TryResolveDispatchContext(...)的异常边界仍需要继续收口- benchmark 场景现统一通过
BenchmarkHostFactory构建最小宿主:GFramework 侧在 runtime 分发前显式Freeze()容器,MediatR 侧只扫描当前场景需要的 handler / behavior 类型 RequestStartupBenchmarks已恢复ColdStart_GFrameworkCqrs结果产出,不再命中No CQRS request handler registeredBenchmarkDotNet在当前 agent 沙箱里会因自动生成的 bootstrap 脚本异常失败;同一dotnet run --no-build命令在沙箱外执行通过,因此本轮以沙箱外结果作为 benchmark 权威验证- 已新增手动触发的 benchmark workflow;默认只验证 benchmark 项目 Release build,只有显式提供过滤器时才执行 BenchmarkDotNet 运行;过滤器输入现通过环境变量传入 shell,避免 workflow_dispatch 输入直接插值到命令行
- 远端
CTRF最新汇总为2311/2311passed(run#1079, 2026-05-07) MegaLinter当前只暴露dotnet-format的Restore operation failed环境噪音,尚未提供本地仍成立的文件级格式诊断LegacyCqrsDispatchHelper.TryResolveDispatchContext(...)现在只会把“Context 尚未设置”或“当前没有活动上下文”识别为可安全 fallback 的缺上下文信号;其他InvalidOperationException将继续向上传播,避免把真实运行时故障误判成 legacy 直执行场景CommandExecutorTests已新增“缺上下文继续 fallback”和“意外InvalidOperationException必须冒泡”的回归,防止后续再次放宽该异常过滤面PR #334当前 latest-head open AI feedback 经过本轮本地复核与修复后,应主要剩余待 GitHub 重新索引的状态差异或已实质关闭但未 resolve 的 threadGFramework.Core.Tests中 legacy bridge 的“保留上下文”回归现在同时断言 bridge request 类型与目标对象执行期观察到的IArchitectureContextRecordingCqrsRuntime对非Unit响应已显式校验返回值类型;若测试工厂返回了null或错误装箱类型,异常会直接指出 request 类型与期望/实际响应类型PR #339当前 latest-head review 仍显示2个 CodeRabbit open thread 与2个 nitpick;本轮本地复核后确认:GFramework.Cqrs.Tests/Cqrs/CqrsDispatcherCacheTests.cs的Per_Behavior_Count拼写已在当前 head 修正,属于 stale threadGFramework.Core.Abstractions/Ioc/IIocContainer.cs的流式行为注册入口此前确实缺少<exception>/<remarks>契约说明,现已补齐并同步到IArchitecture/Architecture/ArchitectureModulesGFramework.Cqrs/Internal/CqrsDispatcher.cs的StreamPipelineInvocation.GetContinuation(...)线程模型说明此前少于 request 对称路径,现已补齐并发next()时 continuation 缓存的语义边界GFramework.Core/Ioc/MicrosoftDiContainer.cs的 request / stream 行为注册逻辑此前存在重复实现,现已抽取共享私有 helper 以避免后续生命周期或校验逻辑漂移
- 本地
dotnet format GFramework.Cqrs/GFramework.Cqrs.csproj --verify-no-changes显示当前 diff 内仍有GFramework.Cqrs/ICqrsRequestInvokerProvider.cs的空白格式问题,本轮已修复;同一次命令报出的多条CHARSET提示集中在未触达的历史文件,不视为PR #339本轮新增 triage 结论
当前风险
- 顶层
GFramework.sln/GFramework.csproj在 WSL 下仍可能受 Windows NuGet fallback 配置影响,完整 solution 级验证成本高于模块级验证 - 若后续新增 benchmark / example / tooling 项目但未同步校验发布面,solution 级
dotnet pack仍可能在 tag 发布前才暴露异常包 RequestStartupBenchmarks为了量化真正的单次 cold-start,引入了InvocationCount=1/UnrollFactor=1的专用 job;该配置会触发 BenchmarkDotNet 的MinIterationTime提示,后续若要做稳定基线比较,还需要决定是否引入批量外层循环或自定义 cold-start harness- 当前 benchmark 宿主仍刻意保持“单根容器最小宿主”模型;若要公平比较
Scopedhandler 生命周期,需要先引入显式 scope 创建与 scope 内首次解析的对照基线 - 当前
Mediator对照组仅先接入 steady-state request;若要把Transient/Scoped生命周期矩阵也纳入同一组对照,需要按Mediator官方 benchmark 的做法拆分 compile-time lifetime build config,而不是在同一编译产物里混用多个 lifetime BenchmarkDotNet.Artifacts/现已加入仓库忽略规则;若后续确实需要提交新的基准报告,应显式挑选结果文件或改走文档归档,而不是直接纳入整个生成目录- 当前
GFramework.Cqrsrequest steady-state 仍慢于MediatR;在“至少超过反射版MediatR”这个阶段目标达成前,任何相关改动都不能只看功能 build/test 结果,必须附带 benchmark 回归数据 - 仓库内部仍保留旧
Command/QueryAPI、LegacyICqrsRuntimealias 与部分历史命名语义,后续若不继续分批收口,容易混淆“对外替代已完成”与“内部收口未完成” - 若继续扩大 generated invoker 覆盖面,需要持续区分“可静态表达的合同”与
PreciseReflectedRegistrationSpec等仍需保守回退的场景 - legacy bridge 当前只为已有
Command/Query兼容入口接到统一 request pipeline;若后续要继续对齐Mediator,仍需要单独设计 stream pipeline、telemetry 与 facade 公开面,而不是把这次 bridge 当成“全部收口完成” LegacyBridgePipelineTracker仍是进程级静态测试辅助;虽然现在已在相关 fixture 清理阶段重置并补充线程安全说明,但若将来扩大并行 bridge fixture 数量,仍要继续控制共享状态扩散- stream pipeline 当前只在“单次建流”层面包裹 handler 调用;若后续需要 per-item 拦截、元素级重试或流内 metrics 聚合,仍需额外设计更细粒度 contract,而不是把本轮 seam 直接等同于元素级 middleware
PR #339在 GitHub 上仍有 1 个已本地失效但未 resolve 的 stale test-thread;若后续 head 再次变化,需要重新抓取 latest-head review 确认未解决线程是否收敛- 若后续继续依赖
HasRegistration(Type)做热路径短路,新增测试替身或 strict mock 时必须同步配置该调用,否则容易在真正业务断言之前被 mock 框架短路成环境性失败
最近权威验证
python3 .agents/skills/gframework-pr-review/scripts/fetch_current_pr_review.py --json-output /tmp/current-pr-review.json- 结果:通过
- 备注:确认当前分支对应
PR #340;latest-head 当前显示CodeRabbit 2/Greptile 2open thread,且CTRF报告中唯一失败测试为CreateStream_Should_Throw_When_Stream_Pipeline_Behavior_Context_Does_Not_Implement_IArchitectureContext
dotnet build GFramework.Core.Abstractions/GFramework.Core.Abstractions.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet build GFramework.Cqrs.Tests/GFramework.Cqrs.Tests.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --no-build --filter "FullyQualifiedName~MicrosoftDiContainerTests"- 结果:通过,
52/52passed
- 结果:通过,
dotnet test GFramework.Cqrs.Tests/GFramework.Cqrs.Tests.csproj -c Release --no-build --filter "FullyQualifiedName~CqrsDispatcherContextValidationTests"- 结果:通过,
4/4passed
- 结果:通过,
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:按新性能回归门槛复跑后,steady-state request 对照约为 baseline
5.300 ns / 32 B、Mediator4.964 ns / 32 B、MediatR57.993 ns / 232 B、GFramework.Cqrs83.823 ns / 32 B
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestLifetimeBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:按新性能回归门槛复跑后,
Singleton下GFramework.Cqrs/MediatR约83.183 ns / 32 Bvs60.915 ns / 232 B;Transient下约86.243 ns / 56 Bvs59.644 ns / 232 B
env GIT_DIR=... GIT_WORK_TREE=... python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
- 备注:当前仅保留
GFramework.sln的历史 CRLF 警告,无本轮新增 diff 格式错误
dotnet build GFramework.Cqrs/GFramework.Cqrs.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --filter "FullyQualifiedName~MicrosoftDiContainerTests"- 结果:通过,
52/52passed
- 结果:通过,
dotnet test GFramework.Cqrs.Tests/GFramework.Cqrs.Tests.csproj -c Release --no-build --filter "FullyQualifiedName~CqrsDispatcherCacheTests|FullyQualifiedName~CqrsDispatcherContextValidationTests"- 结果:通过,
14/14passed
- 结果:通过,
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release --no-build -- --filter "*RequestBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:本轮两批热路径收口后的最新 steady-state request 对照约为 baseline
6.141 ns / 32 B、Mediator6.674 ns / 32 B、MediatR61.803 ns / 232 B、GFramework.Cqrs70.298 ns / 32 B
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release --no-build -- --filter "*RequestLifetimeBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:最新 lifetime request 对照约为
Singleton下 baseline /MediatR/GFramework.Cqrs=4.706 ns / 52.197 ns / 73.005 ns,Transient下 =4.571 ns / 50.175 ns / 74.757 ns
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
python3 scripts/license-header.py --check --paths GFramework.Cqrs.Benchmarks/Messaging/GeneratedDefaultRequestBenchmarkRegistry.cs GFramework.Cqrs.Benchmarks/Messaging/BenchmarkHostFactory.cs GFramework.Cqrs.Benchmarks/Messaging/RequestBenchmarks.cs GFramework.Cqrs.Benchmarks/README.md- 结果:通过
git diff --check- 结果:通过
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:默认 steady-state request 对照现约为 baseline
5.013 ns / 32 B、Mediator5.747 ns / 32 B、MediatR51.588 ns / 232 B、GFramework.Cqrs65.296 ns / 32 B
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestLifetimeBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:最新 lifetime request 对照约为
Singleton下 baseline /MediatR/GFramework.Cqrs=4.817 ns / 48.177 ns / 68.772 ns,Transient下 =4.841 ns / 51.753 ns / 73.157 ns
env GIT_DIR=... GIT_WORK_TREE=... python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
- 备注:仍仅保留
GFramework.sln的历史 CRLF 警告,无本轮新增 diff 格式问题
dotnet pack GFramework.sln -c Release --no-restore -o /tmp/gframework-pack-validation -p:IncludeSymbols=false- 结果:通过
- 备注:当前本地产物仅包含 14 个预期发布包,未生成
GFramework.Cqrs.Benchmarks.*.nupkg
bash scripts/validate-packed-modules.sh /tmp/gframework-pack-validation- 结果:通过
- 备注:共享脚本确认 actual package set 与预期 14 个发布包完全一致
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --filter "FullyQualifiedName~MicrosoftDiContainerTests"- 结果:通过,
51/51passed
- 结果:通过,
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:最新 steady-state request 对照约为 baseline
5.969 ns / 32 B、Mediator6.242 ns / 32 B、MediatR53.818 ns / 232 B、GFramework.Cqrs85.504 ns / 32 B
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestLifetimeBenchmarks.SendRequest_*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:
Singleton下GFramework.Cqrs/MediatR约84.066 ns / 32 Bvs56.096 ns / 232 B;Transient下约90.652 ns / 56 Bvs57.207 ns / 232 B
python3 scripts/license-header.py --check- 结果:通过
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestStartupBenchmarks*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过
- 备注:
ColdStart_GFrameworkCqrs已恢复出数,最新本地输出约220-292 us,MediatR 对照约575-616 us;当前仅剩 BenchmarkDotNet 对单次 cold-start 场景的MinIterationTime提示
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error - 备注:用于验证本轮 request invoker / pipeline / stream invoker 调整与 benchmark workflow 改动后的 Release 编译结果
- 结果:通过,
python3 .agents/skills/gframework-pr-review/scripts/fetch_current_pr_review.py --format json --json-output /tmp/current-pr-review.json- 结果:通过
- 备注:确认当前分支对应
PR #334;CodeRabbitlatest review 已APPROVED,但 latest-head 仍显示10个 open thread、Greptile仍显示3个 open thread;本地逐项复核后未发现新的仍成立缺陷,最新 CI 测试汇总为2311/2311passed,MegaLinter仅剩dotnet-formatrestore 环境噪音
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
python3 .agents/skills/gframework-pr-review/scripts/fetch_current_pr_review.py --json-output /tmp/current-pr-review.json- 结果:通过
- 备注:确认当前分支对应
PR #339;latest-head 显示2个 CodeRabbit open thread 与2个 nitpick;本轮本地接受并修复的问题集中在流式行为注册入口 XML 契约、stream continuation 线程说明与MicrosoftDiContainer的重复注册逻辑,测试方法拼写线程已在当前 head 失效
dotnet format GFramework.Cqrs/GFramework.Cqrs.csproj --verify-no-changes- 结果:发现当前 diff 内
GFramework.Cqrs/ICqrsRequestInvokerProvider.cs的空白格式问题;其余CHARSET提示集中在未触达的历史文件
- 结果:发现当前 diff 内
dotnet build GFramework.Cqrs/GFramework.Cqrs.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet build GFramework.Core.Abstractions/GFramework.Core.Abstractions.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Cqrs.Tests/GFramework.Cqrs.Tests.csproj -c Release --no-build --filter "FullyQualifiedName~CqrsDispatcherCacheTests"- 结果:通过,
10/10passed
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --no-build --filter "FullyQualifiedName~ArchitectureModulesBehaviorTests"- 结果:通过,
4/4passed
- 结果:通过,
env GIT_DIR=... GIT_WORK_TREE=... python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
dotnet build GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --filter "FullyQualifiedName~CommandExecutorTests|FullyQualifiedName~AsyncQueryExecutorTests"- 结果:通过,
19/19passed
- 结果:通过,
python3 .agents/skills/gframework-pr-review/scripts/fetch_current_pr_review.py --json-output /tmp/current-pr-review.json- 结果:通过
- 备注:确认当前分支对应
PR #334;最新 review 仍为CodeRabbit APPROVED (2026-05-07T12:20:24Z),latest-head 显示CodeRabbit 10/Greptile 5open thread;本轮接受并修复的仍成立问题收敛到LegacyCqrsDispatchHelper.TryResolveDispatchContext(...)的过宽异常吞掉逻辑
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet build GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --no-build --filter "FullyQualifiedName~CommandExecutorTests|FullyQualifiedName~QueryExecutorTests"- 结果:通过,
25/25passed
- 结果:通过,
python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
python3 .agents/skills/gframework-pr-review/scripts/fetch_current_pr_review.py --format json --json-output <temporary-json-output>- 结果:通过
- 备注:确认当前分支对应
PR #331,本轮 latest-head open AI feedback 已收敛到dotnet pack --no-build、共享包校验脚本跨平台兼容性与 active 文档 PR 锚点同步
python3 scripts/license-header.py --check- 结果:通过
- 备注:当前 WSL worktree 需要显式绑定
GIT_DIR/GIT_WORK_TREE后运行
git diff --check- 结果:通过
dotnet build GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet run --project GFramework.Cqrs.Benchmarks/GFramework.Cqrs.Benchmarks.csproj -c Release -- --filter "*RequestLifetimeBenchmarks*" --job short --warmupCount 1 --iterationCount 1 --launchCount 1- 结果:通过(以沙箱外
--no-build权威结果为准) - 备注:
Singleton下 baseline / MediatR / GFramework 均值约5.633 ns / 58.687 ns / 301.731 ns;Transient下约5.044 ns / 52.274 ns / 287.863 ns
- 结果:通过(以沙箱外
python3 scripts/license-header.py --check- 结果:通过
- 备注:当前 WSL worktree 需要显式绑定
GIT_DIR/GIT_WORK_TREE
git diff --check- 结果:通过
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --filter "FullyQualifiedName~ArchitectureContextTests|FullyQualifiedName~CommandExecutorTests|FullyQualifiedName~QueryExecutorTests|FullyQualifiedName~AsyncQueryExecutorTests"- 结果:通过,
45/45passed
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release- 结果:通过,
1644/1644passed
- 结果:通过,
env GIT_DIR=... GIT_WORK_TREE=... python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
python3 .agents/skills/gframework-pr-review/scripts/fetch_current_pr_review.py --json-output /tmp/current-pr-review.json- 结果:通过
- 备注:确认当前分支对应
PR #334;仍有效的 latest-head review 已收敛到 legacy bridge 测试装配、运行时依赖契约、异步取消、XML 文档与兼容文档边界
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error - 备注:修复新增 XML 文档 warning 后复跑,当前
GFramework.Core三个 target framework 均已干净通过
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --filter "FullyQualifiedName~ArchitectureContextTests|FullyQualifiedName~ArchitectureModulesBehaviorTests|FullyQualifiedName~CommandExecutorTests|FullyQualifiedName~QueryExecutorTests|FullyQualifiedName~AsyncQueryExecutorTests"- 结果:通过,
48/48passed - 备注:覆盖 legacy bridge 兼容入口、测试装配、执行器 runtime fallback 与相关模块行为
- 结果:通过,
env GIT_DIR=... GIT_WORK_TREE=... python3 scripts/license-header.py --check- 结果:通过
git diff --check- 结果:通过
dotnet build GFramework.Core/GFramework.Core.csproj -c Release- 结果:通过,
0 warning / 0 error
- 结果:通过,
dotnet test GFramework.Core.Tests/GFramework.Core.Tests.csproj -c Release --filter "FullyQualifiedName~ArchitectureContextTests|FullyQualifiedName~ArchitectureModulesBehaviorTests|FullyQualifiedName~CommandExecutorTests|FullyQualifiedName~QueryExecutorTests|FullyQualifiedName~AsyncQueryExecutorTests|FullyQualifiedName~LegacyAsyncCommandDispatchRequestHandlerTests"- 结果:通过,
54/54passed - 备注:覆盖 legacy 同步 bridge 的同步上下文隔离、bridge fixture 容器释放,以及 async void command cancellation 可见性
- 结果:通过,
env GIT_DIR=... GIT_WORK_TREE=... python3 scripts/license-header.py --check- 结果:通过
下一推荐步骤
- 若继续沿用
$gframework-batch-boot 50且优先处理性能,下一批先查看RequestLifetimeBenchmarks与 stream/notification 对照里是否还有未吸收 generated-provider 宿主收益的低风险切片 - 若要把“至少超过反射版
MediatR”变成可执行目标,下一批应继续围绕 request dispatch / pipeline 路径的剩余常量开销下钻,并在每次改动后立即复跑RequestBenchmarks、RequestLifetimeBenchmarks与RequestPipelineBenchmarks - 若 benchmark 对照需要继续贴近
Mediator官方设计,再扩Mediator的 compile-time lifetime 或 stream 对照矩阵,而不是回头重试已被 benchmark 否决的GetAll(Type)零行为探测方案
活跃文档
- 历史跟踪归档:cqrs-rewrite-history-through-rp043.md
- 验证历史归档:cqrs-rewrite-validation-history-through-rp062.md
RP-063至RP-074验证归档:cqrs-rewrite-validation-history-rp063-through-rp074.mdRP-062至RP-076trace 归档:cqrs-rewrite-history-rp062-through-rp076.md- CQRS 与 Mediator 评估归档:cqrs-vs-mediator-assessment-rp063.md
- 历史 trace 归档:cqrs-rewrite-history-through-rp043.md
RP-046至RP-061trace 归档:cqrs-rewrite-history-rp046-through-rp061.md
说明
PR #261、PR #302、PR #305、PR #307及更早阶段的详细过程已不再作为 active 恢复入口;如需追溯,以对应归档文件或历史 trace 段落为准- active tracking 仅保留当前恢复点、当前风险、最近权威验证与下一推荐步骤,避免
boot落到历史阶段细节