60 lines
1.4 KiB
C#
Raw Normal View History

2025-04-21 10:17:40 +08:00
namespace JiShe.CollectBus.Kafka.Attributes;
2025-04-15 11:15:22 +08:00
2025-04-21 10:17:40 +08:00
[AttributeUsage(AttributeTargets.Method)]
public class KafkaSubscribeAttribute : Attribute
2025-04-15 11:15:22 +08:00
{
2025-04-21 10:17:40 +08:00
/// <summary>
/// 订阅主题
/// </summary>
/// <param name="batchTimeout"></param>
public KafkaSubscribeAttribute(string topic)
2025-04-15 11:15:22 +08:00
{
2025-04-21 10:17:40 +08:00
Topic = topic;
}
2025-04-15 15:49:22 +08:00
2025-04-21 10:17:40 +08:00
/// <summary>
/// 订阅主题
/// </summary>
public KafkaSubscribeAttribute(string topic, int partition)
{
Topic = topic;
Partition = partition;
2025-04-15 11:15:22 +08:00
}
2025-04-21 10:17:40 +08:00
/// <summary>
/// 订阅的主题
/// </summary>
public string Topic { get; set; } = null!;
/// <summary>
/// 分区
/// </summary>
public int Partition { get; set; } = -1;
/// <summary>
/// 消费者组
/// </summary>
public string? GroupId { get; set; } = null; //"default"
/// <summary>
/// 任务数(默认是多少个分区多少个任务)
/// 如设置订阅指定Partition则任务数始终为1
/// </summary>
public int TaskCount { get; set; } = -1;
/// <summary>
/// 批量处理数量
/// </summary>
public int BatchSize { get; set; } = 100;
/// <summary>
/// 是否启用批量处理
/// </summary>
public bool EnableBatch { get; set; } = false;
/// <summary>
/// 批次超时时间
/// 格式:("00:05:00")
/// </summary>
public TimeSpan? BatchTimeout { get; set; } = null;
}