Giter Site home page Giter Site logo

dtm-labs / client-csharp Goto Github PK

View Code? Open in Web Editor NEW
119.0 8.0 25.0 261 KB

The new client for dtm in csharp, including workflow, dtmcli, and dtmgrpc

License: MIT License

C# 99.69% TSQL 0.31%
transaction csharp distributed database microservice distributed-transactions tcc saga

client-csharp's People

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

client-csharp's Issues

这样遍历添加20个,在dtm库里只有18个子事务

await globalTransaction.Excecute(async (tcc) =>
{
for (int i = 0; i < 20; i++)
{
var res1 = await tcc.CallBranch(request, svc + "/TransOut/Try"+i, svc + "/TransOut/Confirm" + i, svc + "/TransOut/Cancel" + i, cts.Token);
}
}, cts.Token);

tcc.Callbranch 检查分支调用结果,如果出错,则走异常

之前dtmcli-csharp的使用者很容易出现的一个误会是,CallBranch调用分支时,如果分支返回了错误的结果,调用方很容易忽略,而继续执行下一步。
因此更好的做法是,检查返回的结果,如果是错误,则走异常,避免被调用者忽略。

调用分支返回错误:旧版本(dtm版本小于1.10.0)为StatusCode==200 && content.Contains("FAILRUE"),新版本可以采用StatusCode >= 400
为了兼容,SDK可以检查两种情况,然后转成异常

没有找到c# SDK的XA模式

我在demo/src中都没有发现关于 XA模式的事务支持, 请问是我看漏了,还是c#的SDK里暂未支持XA模式?

[Dtmcli/Dtmgrpc] Split DtmClient/DtmgRPCClient and barrier relate dependency injection in ServiceCollectionExtensions

Keep the principle of minimum injection. Not all scenarios will involve the server-side request and sub transaction barrier. Consider leaving these two parts during dependency injection and injecting them on demand.


保持最小化注入原则,并不是所有的场景都会涉及到服务端请求和子事务屏障,考虑将这两部分在依赖注入时分离开,按需注入。

希望sdk能基于.netstandard2.0

当前sdk基于netstandard2.1导致.net FX项目无法使用。
image
个人建议将sdk包的.netstandard版本由2.1调整至2.0(版本调整会增加sdk包代码量和实现难度)。好处如下:
1、更好的在.net生态圈推广,让传统行业的.net FX开发人员便捷使用分布式事务
2、帮助.net版本升级的公司。减少从.net FX向.net core3.1+版本升级的过程中分布式事务相关的弯路
3、更便捷的在.net 和java技术栈共存的公司中推广

增加请求超时时间的自定义配置

目前 cli 向 dtm服务端分支事务 发起的请求都是 HttpClient 的默认超时时间。

对这两类请求,可以设置对应的自定义的超时时间。

customer action

image
如果这里只是指定的url。可能会很局限。
比如说:
1、我们系统url调用即使错误业务返回统一格式的数据。即使失败也不会http异常
2、我可能不是一个http调用。只是本地d代码处理了一些业务逻辑。
3、正向调用返回的数据可能会在逆向调用中使用。
4、第一个saga.Add返回的数据可能会给第二个saga.Add使用

[Core] Support RollbackReason and Protocol

The new dtm client support RollbackReason and Protocol in trans_base. We should add support in client-csharp as well.


最新版本的 dtm 客户端 在 trans_base 中 支持了 RollbackReason and Protocol, 同样也需要在 client-csharp 中支持。

http response status: NotFound, Message 报错信息如下

DtmCommon.DtmException: http response status: NotFound, Message :
at DtmAPI1.Controllers.TestController.PostTest() in D:\案例代码\elk\Solution1\DtmAPI1\Controllers\TestController.cs:line 46
at lambda_method5(Closure , Object )
at Microsoft.AspNetCore.Mvc.Infrastructure.ActionMethodExecutor.AwaitableResultExecutor.Execute(IActionResultTypeMapper mapper, ObjectMethodExecutor executor, Object controller, Object[] arguments)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.g__Awaited|12_0(ControllerActionInvoker invoker, ValueTask`1 actionResultValueTask)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.g__Awaited|10_0(ControllerActionInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Rethrow(ActionExecutedContextSealed context)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.g__Awaited|13_0(ControllerActionInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|20_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|17_0(ResourceInvoker invoker, Task task, IDisposable scope)
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|17_0(ResourceInvoker invoker, Task task, IDisposable scope)
at Microsoft.AspNetCore.Routing.EndpointMiddleware.g__AwaitRequestTask|6_0(Endpoint endpoint, Task requestTask, ILogger logger)
at Microsoft.AspNetCore.Authorization.AuthorizationMiddleware.Invoke(HttpContext context)
at Swashbuckle.AspNetCore.SwaggerUI.SwaggerUIMiddleware.Invoke(HttpContext httpContext)
at Swashbuckle.AspNetCore.Swagger.SwaggerMiddleware.Invoke(HttpContext httpContext, ISwaggerProvider swaggerProvider)
at Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.