25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

README.zh-cn.md 9.0 KiB

add docs to master (#284) * update version to 2.4.0 * Add version options to config file. * update resource * add message version support for dashboard * add message version support for dashboard * Support using version to isolate messages. #220 * update mongo unit tests * update unit tests * update unit tests * Set default versions for consumer groups * solve the problem of issue#181 (#237) * Issue#235 (#238) * solve the problem of issue#181 * solve the problem of issue#235 * refactor * Fix the message persistence bug. #240 * using new CamelCaseNamingStrategy * update packages to .net core 2.2 * update test framework to netcoreapp2.2 * Update .travis.yml * update TargetFramework * Exclude build samples project * update version to 2.4.1 * add samples project to sln for build * update version to 2.4.2 * Fixed PostgreSql version isolation feature bug. (#256) * Fixed spelling errors * modify cap publish Message to rabbitmq slow (#261) * Startup the CAP with the BackgroundService. #265 * update samples * Fixed SQL query bug. #266 * update travis ci config * update travis ci config * adjust dashboard table column width * adjust the consumer execution time to milliseconds * update ignore * add mkdocs.yml * update version to 2.4.3 * add about.md docs * add index.md docs * add docs * add docs * add docs * add docs * add docs * add docs * add docs * add docs * add docs * add docs * add docs * Fix resource files * add docs * add docs * add docs * Create readme.md * add markdown extensions supports * update about.md * add CNAME fiel * add img * update docs * Update README.zh-cn.md
6 년 전
7 년 전
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. # CAP                       [English](https://github.com/dotnetcore/CAP/blob/develop/README.md)
  2. [![Travis branch](https://img.shields.io/travis/dotnetcore/CAP/develop.svg?label=travis-ci)](https://travis-ci.org/dotnetcore/CAP)
  3. [![AppVeyor](https://ci.appveyor.com/api/projects/status/v8gfh6pe2u2laqoa?svg=true)](https://ci.appveyor.com/project/yuleyule66/cap)
  4. [![NuGet](https://img.shields.io/nuget/v/DotNetCore.CAP.svg)](https://www.nuget.org/packages/DotNetCore.CAP/)
  5. [![NuGet Preview](https://img.shields.io/nuget/vpre/DotNetCore.CAP.svg?label=nuget-pre)](https://www.nuget.org/packages/DotNetCore.CAP/)
  6. [![Member project of .NET Core Community](https://img.shields.io/badge/member%20project%20of-NCC-9e20c9.svg)](https://github.com/dotnetcore)
  7. [![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg)](https://raw.githubusercontent.com/dotnetcore/CAP/master/LICENSE.txt)
  8. CAP 是一个基于 .NET Standard 的 C# 库,它是一种处理分布式事务的解决方案,同样具有 EventBus 的功能,它具有轻量级、易使用、高性能等特点。
  9. 你可以在这里[CAP docs](http://docs.dotnet-china.org/CAP/)看到更多详细资料。
  10. 你可以在这里看到[CAP 视频教程](https://www.cnblogs.com/savorboard/p/cap-video-1.html),学习如何在项目中集成CAP。
  11. ## 预览(OverView)
  12. 在我们构建 SOA 或者 微服务系统的过程中,我们通常需要使用事件来对各个服务进行集成,在这过程中简单的使用消息队列并不能保证数据的最终一致性,
  13. CAP 采用的是和当前数据库集成的本地消息表的方案来解决在分布式系统互相调用的各个环节可能出现的异常,它能够保证任何情况下事件消息都是不会丢失的。
  14. 你同样可以把 CAP 当做 EventBus 来使用,CAP提供了一种更加简单的方式来实现事件消息的发布和订阅,在订阅以及发布的过程中,你不需要继承或实现任何接口。
  15. 这是CAP集在ASP.NET Core 微服务架构中的一个示意图:
  16. ![cap.png](http://oowr92l0m.bkt.clouddn.com/cap.png)
  17. > CAP 实现了 [eShop 电子书](https://docs.microsoft.com/en-us/dotnet/standard/microservices-architecture/multi-container-microservice-net-applications/subscribe-events#designing-atomicity-and-resiliency-when-publishing-to-the-event-bus) 中描述的发件箱模式
  18. ## Getting Started
  19. ### NuGet
  20. 你可以运行以下下命令在你的项目中安装 CAP。
  21. ```
  22. PM> Install-Package DotNetCore.CAP
  23. ```
  24. CAP 支持 Kafka 或者 RabbitMQ 消息队列,你可以选择下面的包进行安装:
  25. ```
  26. PM> Install-Package DotNetCore.CAP.Kafka
  27. PM> Install-Package DotNetCore.CAP.RabbitMQ
  28. ```
  29. CAP 提供了 Sql Server, MySql, PostgreSQL,MongoDB 的扩展作为数据库存储:
  30. ```
  31. // 按需选择安装你正在使用的数据库
  32. PM> Install-Package DotNetCore.CAP.SqlServer
  33. PM> Install-Package DotNetCore.CAP.MySql
  34. PM> Install-Package DotNetCore.CAP.PostgreSql
  35. PM> Install-Package DotNetCore.CAP.MongoDB
  36. ```
  37. ### Configuration
  38. 首先配置CAP到 Startup.cs 文件中,如下:
  39. ```c#
  40. public void ConfigureServices(IServiceCollection services)
  41. {
  42. ......
  43. services.AddDbContext<AppDbContext>();
  44. services.AddCap(x =>
  45. {
  46. //如果你使用的 EF 进行数据操作,你需要添加如下配置:
  47. x.UseEntityFramework<AppDbContext>(); //可选项,你不需要再次配置 x.UseSqlServer 了
  48. //如果你使用的Ado.Net,根据数据库选择进行配置:
  49. x.UseSqlServer("数据库连接字符串");
  50. x.UseMySql("Your ConnectionStrings");
  51. x.UsePostgreSql("Your ConnectionStrings");
  52. //如果你使用的 MongoDB,你可以添加如下配置:
  53. x.UseMongoDB("Your ConnectionStrings"); //注意,仅支持MongoDB 4.0+集群
  54. //如果你使用的 RabbitMQ 或者 Kafka 作为MQ,根据使用选择配置:
  55. x.UseRabbitMQ("localhost");
  56. x.UseKafka("localhost");
  57. });
  58. }
  59. ```
  60. ### 发布
  61. 在 Controller 中注入 `ICapPublisher` 然后使用 `ICapPublisher` 进行消息发送
  62. ```c#
  63. public class PublishController : Controller
  64. {
  65. private readonly ICapPublisher _capBus;
  66. public PublishController(ICapPublisher capPublisher)
  67. {
  68. _capBus = capPublisher;
  69. }
  70. //不使用事务
  71. [Route("~/without/transaction")]
  72. public IActionResult WithoutTransaction()
  73. {
  74. _capBus.Publish("xxx.services.show.time", DateTime.Now);
  75. return Ok();
  76. }
  77. //Ado.Net 中使用事务,自动提交
  78. [Route("~/adonet/transaction")]
  79. public IActionResult AdonetWithTransaction()
  80. {
  81. using (var connection = new MySqlConnection(ConnectionString))
  82. {
  83. using (var transaction = connection.BeginTransaction(_capBus, autoCommit: true))
  84. {
  85. //业务代码
  86. _capBus.Publish("xxx.services.show.time", DateTime.Now);
  87. }
  88. }
  89. return Ok();
  90. }
  91. //EntityFramework 中使用事务,自动提交
  92. [Route("~/ef/transaction")]
  93. public IActionResult EntityFrameworkWithTransaction([FromServices]AppDbContext dbContext)
  94. {
  95. using (var trans = dbContext.Database.BeginTransaction(_capBus, autoCommit: true))
  96. {
  97. //业务代码
  98. _capBus.Publish("xxx.services.show.time", DateTime.Now);
  99. }
  100. return Ok();
  101. }
  102. }
  103. ```
  104. ### 订阅
  105. **Action Method**
  106. 在 Action 上添加 CapSubscribeAttribute 来订阅相关消息。
  107. ```c#
  108. public class PublishController : Controller
  109. {
  110. [CapSubscribe("xxx.services.show.time")]
  111. public void CheckReceivedMessage(DateTime datetime)
  112. {
  113. Console.WriteLine(datetime);
  114. }
  115. }
  116. ```
  117. **Service Method**
  118. 如果你的订阅方法没有位于 Controller 中,则你订阅的类需要继承 `ICapSubscribe`:
  119. ```c#
  120. namespace xxx.Service
  121. {
  122. public interface ISubscriberService
  123. {
  124. public void CheckReceivedMessage(DateTime datetime);
  125. }
  126. public class SubscriberService: ISubscriberService, ICapSubscribe
  127. {
  128. [CapSubscribe("xxx.services.show.time")]
  129. public void CheckReceivedMessage(DateTime datetime)
  130. {
  131. }
  132. }
  133. }
  134. ```
  135. 然后在 Startup.cs 中的 `ConfigureServices()` 中注入你的 `ISubscriberService` 类
  136. ```c#
  137. public void ConfigureServices(IServiceCollection services)
  138. {
  139. //注意: 注入的服务需要在 `services.AddCap()` 之前
  140. services.AddTransient<ISubscriberService,SubscriberService>();
  141. services.AddCap(x=>{});
  142. }
  143. ```
  144. #### 订阅者组
  145. 订阅者组的概念类似于 Kafka 中的消费者组,它和消息队列中的广播模式相同,用来处理不同微服务实例之间同时消费相同的消息。
  146. 当CAP启动的时候,她将创建一个默认的消费者组,如果多个相同消费者组的消费者消费同一个Topic消息的时候,只会有一个消费者被执行。
  147. 相反,如果消费者都位于不同的消费者组,则所有的消费者都会被执行。
  148. 相同的实例中,你可以通过下面的方式来指定他们位于不同的消费者组。
  149. ```C#
  150. [CapSubscribe("xxx.services.show.time", Group = "group1" )]
  151. public void ShowTime1(DateTime datetime)
  152. {
  153. }
  154. [CapSubscribe("xxx.services.show.time", Group = "group2")]
  155. public void ShowTime2(DateTime datetime)
  156. {
  157. }
  158. ```
  159. `ShowTime1` 和 `ShowTime2` 处于不同的组,他们将会被同时调用。
  160. PS,你可以通过下面的方式来指定默认的消费者组名称:
  161. ```C#
  162. services.AddCap(x =>
  163. {
  164. x.DefaultGroup = "default-group-name";
  165. });
  166. ```
  167. ### Dashboard
  168. CAP 2.1+ 以上版本中提供了仪表盘(Dashboard)功能,你可以很方便的查看发出和接收到的消息。除此之外,你还可以在仪表盘中实时查看发送或者接收到的消息。
  169. 在分布式环境中,仪表盘内置集成了 [Consul](http://consul.io) 作为节点的注册发现,同时实现了网关代理功能,你同样可以方便的查看本节点或者其他节点的数据,它就像你访问本地资源一样。
  170. ```c#
  171. services.AddCap(x =>
  172. {
  173. //...
  174. // 注册 Dashboard
  175. x.UseDashboard();
  176. // 注册节点到 Consul
  177. x.UseDiscovery(d =>
  178. {
  179. d.DiscoveryServerHostName = "localhost";
  180. d.DiscoveryServerPort = 8500;
  181. d.CurrentNodeHostName = "localhost";
  182. d.CurrentNodePort = 5800;
  183. d.NodeId = 1;
  184. d.NodeName = "CAP No.1 Node";
  185. });
  186. });
  187. ```
  188. 仪表盘默认的访问地址是:[http://localhost:xxx/cap](http://localhost:xxx/cap),你可以在`d.MatchPath`配置项中修改`cap`路径后缀为其他的名字。
  189. ![dashboard](http://images2017.cnblogs.com/blog/250417/201710/250417-20171004220827302-189215107.png)
  190. ![received](http://images2017.cnblogs.com/blog/250417/201710/250417-20171004220934115-1107747665.png)
  191. ![subscibers](http://images2017.cnblogs.com/blog/250417/201710/250417-20171004220949193-884674167.png)
  192. ![nodes](http://images2017.cnblogs.com/blog/250417/201710/250417-20171004221001880-1162918362.png)
  193. ## 贡献
  194. 贡献的最简单的方法之一就是是参与讨论和讨论问题(issue)。你也可以通过提交的 Pull Request 代码变更作出贡献。
  195. ### License
  196. MIT