# dapper.sharding.cap **Repository Path**: znyet/dapper.sharding.cap ## Basic Information - **Project Name**: dapper.sharding.cap - **Description**: dapper.sharding CAP实现 - **Primary Language**: C# - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2022-02-23 - **Last Updated**: 2022-05-29 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # dapper.sharding.cap #### 介绍 https://gitee.com/znyet/dapper.sharding.cap ```csharp using Akka.Actor; using Akka.Configuration; using Dapper.Sharding.CAP; using RestSharp; var configIni = File.ReadAllText(AppDomain.CurrentDomain.BaseDirectory + "Config.ini"); var config = ConfigurationFactory.ParseString(configIni); var system = ActorSystem.Create("serverSys", config); var serverCap = new ServerCap(system, "server"); var res = await serverCap.ExecuteAsync((token, actorPath) => { Console.WriteLine(token); Console.WriteLine(actorPath); //微服务1 var client = new RestClient("http://localhost:9000"); var req = new RestRequest("/home/index"); req.AddQueryParameter("token", token); req.AddQueryParameter("actorPath", actorPath); var task1 = client.ExecuteAsync(req); //微服务2 var client2 = new RestClient("http://localhost:9001"); var req2 = new RestRequest("/home/index"); req2.AddQueryParameter("token", token); req2.AddQueryParameter("actorPath", actorPath); var task2 = client2.ExecuteAsync(req2); return new Task[] { task1, task2 }; }); Console.WriteLine(res.Success); Console.WriteLine("Hello, World!"); ``` ```csharp //web1 [Route("[controller]/[action]")] public class HomeController : ControllerBase { public IActionResult Index() { var token = Request.Query["token"]; var actorPath = Request.Query["actorPath"]; var tran = new DistributedTransactionCap(MyCap.Cap, token, actorPath, "t1"); try { var data = JsonSerializer.Serialize(tran.TranMsg); DbContext.People.Insert(new PeopleTable { Name = data }, tran); tran.Commit(); } catch (Exception ex) { tran.Rollback(); Console.WriteLine(ex.Message); } return Content("ok"); } } ``` ```csharp //web2 [Route("[controller]/[action]")] public class HomeController : ControllerBase { public IActionResult Index() { var token = Request.Query["token"]; var actorPath = Request.Query["actorPath"]; var tran = new DistributedTransactionCap(MyCap.Cap, token, actorPath, "t2"); try { var data = JsonSerializer.Serialize(tran.TranMsg); DbContext.People.Insert(new PeopleTable { Name = data }, tran); tran.Commit(); } catch (Exception ex) { tran.Rollback(); Console.WriteLine(ex.Message); } return Content("ok"); } } ``` ```csharp public class MyCap { public static ClientCap Cap { get; } static MyCap() { var configIni = File.ReadAllText(AppDomain.CurrentDomain.BaseDirectory + "Config.ini"); var config = ConfigurationFactory.ParseString(configIni); var system = ActorSystem.Create("clientSys", config); //root Cap = new ClientCap(system, "c"); } } ``` #### 软件架构 软件架构说明 #### 安装教程 1. xxxx 2. xxxx 3. xxxx #### 使用说明 1. xxxx 2. xxxx 3. xxxx #### 参与贡献 1. Fork 本仓库 2. 新建 Feat_xxx 分支 3. 提交代码 4. 新建 Pull Request #### 特技 1. 使用 Readme\_XXX.md 来支持不同的语言,例如 Readme\_en.md, Readme\_zh.md 2. Gitee 官方博客 [blog.gitee.com](https://blog.gitee.com) 3. 你可以 [https://gitee.com/explore](https://gitee.com/explore) 这个地址来了解 Gitee 上的优秀开源项目 4. [GVP](https://gitee.com/gvp) 全称是 Gitee 最有价值开源项目,是综合评定出的优秀开源项目 5. Gitee 官方提供的使用手册 [https://gitee.com/help](https://gitee.com/help) 6. Gitee 封面人物是一档用来展示 Gitee 会员风采的栏目 [https://gitee.com/gitee-stars/](https://gitee.com/gitee-stars/)