|
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- using Confluent.Kafka;
- using Microsoft.Extensions.Options;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Net;
- using System.Reflection.PortableExecutable;
- using System.Text;
- using System.Threading.Tasks;
- using TelpoPush.Common;
- using TelpoPush.Models.Config;
- using TelpoPush.Service.Mq.Kafka;
-
- namespace TelpoPush.Worker.ThirdSsl.Handlers
- {
- public class KafkaSubscribe
- {
- private readonly ILogger<KafkaSubscribe> _logger;
- private readonly IHostEnvironment _env;
- private readonly IKafkaService _kafkaService;
- private readonly ThirdSslProcess _thirdSslProcess;
- private readonly ServiceConfig _configService;
-
-
- public KafkaSubscribe(
- ILogger<KafkaSubscribe> logger, IHostEnvironment env,
- IKafkaService kafkaService,
- ThirdSslProcess thirdSslProcess)
- {
- _logger = logger;
- _env = env;
- _kafkaService = kafkaService;
- _thirdSslProcess = thirdSslProcess;
- }
- public async Task SubscribeAsync()
- {
-
-
-
-
-
-
-
-
-
-
-
- LimitedConcurrencyLevelTaskScheduler lcts = new LimitedConcurrencyLevelTaskScheduler(5);
- TaskFactory factory = new TaskFactory(lcts);
- try
- {
- await factory.StartNew(() =>
- {
- _kafkaService.SubscribeAsync(DoReceive, CancellationToken.None);
- });
- }
- catch (Exception ex)
- {
- _logger.LogError($"Subscribe 处理Kafka数据发生异常 {ex.Message}|{ex.Source}|{ex.StackTrace}");
- }
- }
- async void DoReceive(string topic, string message, Headers headers)
- {
- await _thirdSslProcess.SendSslThird(message, topic, headers);
- }
- }
- }
|