You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

configuration.md 5.3 KiB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. # Configuration
  2. By default, you can specify the configuration when you register the CAP service into the IoC container for ASP.NET Core project.
  3. ```c#
  4. services.AddCap(config=>
  5. {
  6. // config.XXX
  7. });
  8. ```
  9. The `services` is `IServiceCollection` interface,which is under the `Microsoft.Extensions.DependencyInjection`.
  10. If you don't want to use Microsoft's IoC container, you can view ASP.NET Core documentation [here](https://docs.microsoft.com/en-us/aspnet/core/fundamentals/dependency-injection?view=aspnetcore-2.2#default-service-container-replacement) to learn how to replace the default container implementation.
  11. ## What is the minimum configuration?
  12. The simplest answer is that at least you have to configure a transport and a storage. If you want to get started quickly you can use the following configuration:
  13. ```C#
  14. services.AddCap(capOptions =>
  15. {
  16. capOptions.UseInMemoryQueue();
  17. capOptions.UseInmemoryStorage();
  18. });
  19. ```
  20. For specific transport and storage configuration, you can view the configuration items provided by the specific components in the [Transports](../transports/general.md) section and the [Persistent](../persistent/general.md) section.
  21. ## Custom configuration
  22. The `CapOptions` is used to store configuration information. By default they have the default values, and sometimes you may need to customize them.
  23. #### DefaultGroup
  24. > Default: cap.queue.{assembly name}
  25. The default consumer group name, corresponding to different names in different Transports, you can customize this value to customize the names in Transports for easy viewing.
  26. !!! info "Mapping"
  27. Map to [Queue Names](https://www.rabbitmq.com/queues.html#names) in RabbitMQ.
  28. Map to Topic Name in Apache Kafka.
  29. Map to Subscription Name in Azure Service Bus.
  30. #### Version
  31. > Default: v1
  32. This is a new configuration item introduced in the CAP v2.4 version. It is used to specify a version of a message to isolate messages of different versions of the service. It is often used in A/B testing or multi-service version scenarios. The following is its application scenario:
  33. !!! info "Business Iterative and compatible"
  34. Due to the rapid iteration of services, the data structure of the message is not fixed during each service integration process. Sometimes we add or modify certain data structures to accommodate the newly introduced requirements. If you're a brand new system, there's no problem, but if your system is deployed to a production environment and serves customers, this will cause new features to be incompatible with the old data structure when they go online, and then these changes can cause serious problems. To work around this issue, you can only clean up message queues and persistent messages before starting the application, which is obviously fatal for production environments.
  35. !!! info "Multiple versions of the server"
  36. Sometimes, the server's server needs to provide multiple sets of interfaces to support different versions of the app. The data structures of the same interface and server interaction of these different versions of the app may be different, so usually the server does not provide the same. Routing addresses to adapt to different versions of App calls.
  37. !!! info "Using the same persistent table/collection in different instance"
  38. If you want multiple different instance services to use the same database, in versions prior to 2.4, we could isolate database tables for different instances by specifying different table names. That is to say, when configuring the CAP, it is implemented by configuring different table name prefixes.
  39. > Check out the blog to learn more about Version feature: https://www.cnblogs.com/savorboard/p/cap-2-4.html
  40. #### FailedRetryInterval
  41. > Default: 60 sec
  42. In the process of message message sent to transport failed, the CAP will be retry to sent. This configuration item is used to configure the interval between each retry.
  43. In the process of message consumption failed, the CAP will retry to execute. This configuration item is used to configure the interval between each retry.
  44. !!! WARNING "Retry & Interval"
  45. By default, retry will start after **4 minutes** of failure to send or consume, in order to avoid possible problems caused by setting message state delays.
  46. Failures in the process of sending and consuming messages will be retried 3 times immediately, and will be retried polling after 3 times, at which point the FailedRetryInterval configuration will take effect.
  47. #### FailedRetryCount
  48. > Default: 50
  49. Maximum number of retries. When this value is reached, retry will stop and the maximum number of retries will be modified by setting this parameter.
  50. #### FailedThresholdCallback
  51. > Default: NULL
  52. Type: `Action<MessageType, string, string>`
  53. >
  54. T1 : Message Type
  55. T2 : Message Name
  56. T3 : Message Content
  57. Failure threshold callback. This action is called when the retry reaches the value set by `FailedRetryCount`, and you can receive the notification by specifying this parameter to make a manual intervention. For example, send an email or notify.
  58. #### SucceedMessageExpiredAfter
  59. > Default: 24*3600 sec (1 days)
  60. The expiration time (in seconds) of the success message. When the message is sent or consumed successfully, it will be removed from persistent when the time reaches `SucceedMessageExpiredAfter` seconds. You can set the expiration time by specifying this value.