电子围栏推送服务
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

60 lines
2.5KB

  1. using Confluent.Kafka;
  2. using TelpoPush.Fence.Worker.Common;
  3. using TelpoPush.Fence.Worker.Service.Mq;
  4. namespace TelpoPush.Fence.Worker.Handlers
  5. {
  6. public class KafkaSubscribe
  7. {
  8. private readonly ILogger<KafkaSubscribe> _logger;
  9. private readonly IHostEnvironment _env;
  10. private readonly IKafkaService _kafkaService;
  11. private readonly FenceProcess _feneProcess;
  12. public KafkaSubscribe(
  13. ILogger<KafkaSubscribe> logger, IHostEnvironment env,
  14. IKafkaService kafkaService,
  15. FenceProcess feneProcess)
  16. {
  17. _logger = logger;
  18. _env = env;
  19. _kafkaService = kafkaService;
  20. _feneProcess = feneProcess;
  21. }
  22. public async Task SubscribeAsync()
  23. {
  24. #if DEBUG
  25. _logger.LogInformation("11312");
  26. //string message = "{\"messageId\":\"1798637996003269632\",\"topic\":\"topic.push.position\",\"time\":\"2024-06-06 16:43:21\",\"data\":{\"deviceId\":\"f9f395b1-a6c3-4919-bf24-5ed963d79fad\",\"imei\":\"861281060086083\",\"wifiInfo\":\"88:86:03:df:a3:6c,-59,|88:86:03:e0:09:64,-63,|e8:84:c6:ef:cc:14,-68,|34:da:b7:69:d5:00,-68,|88:86:03:e0:09:4c,-68,|88:86:03:e0:0a:5c,-74,|88:86:03:df:b7:54,-83,|88:86:03:df:dc:18,-87,\",\"address\":\"通钦街道合作市第三小学\",\"baiduLatitude\":34.9966307394798,\"baiduLongitude\":102.918411172862,\"gaodeLatitude\":34.9908855355319,\"gaodeLongitude\":102.911835939226,\"originalLatitude\":34.9920144084504,\"originalLongitude\":102.910114012956,\"locationType\":3,\"lastUpdate\":\"2024-06-06 16:43:21\",\"utcDate\":\"2024-06-06 08:43:21\",\"radius\":50}}";
  27. //await _feneProcess.SendFence(message);
  28. //// await _kafkaService.SubscribeAsync(DoReceive, CancellationToken.None);
  29. #else
  30. LimitedConcurrencyLevelTaskScheduler lcts = new LimitedConcurrencyLevelTaskScheduler(5);
  31. TaskFactory factory = new TaskFactory(lcts);
  32. try
  33. {
  34. await factory.StartNew(async () =>
  35. {
  36. await _kafkaService.SubscribeAsync(DoReceive, CancellationToken.None);
  37. });
  38. }
  39. catch (Exception ex)
  40. {
  41. _logger.LogError($"Subscribe 处理Kafka数据发生异常 {ex.Message}|{ex.Source}|{ex.StackTrace}");
  42. }
  43. #endif
  44. }
  45. async void DoReceive(string message)
  46. {
  47. await _feneProcess.SendFence(message);
  48. }
  49. }
  50. }