123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225 |
- using log4net;
- using Microsoft.Extensions.Hosting;
- using RabbitMQ.Client;
- using System;
- using System.Text;
- using System.Threading;
- using System.Threading.Tasks;
- using Ropin.Environmentally.AlarmService.Model;
- using RabbitMQ.Client.Events;
- using System.Net.Http;
- using System.Net;
- using Ropin.Inspection.Model;
- using Newtonsoft.Json;
- using Ropin.Inspection.Service;
- namespace Ropin.Environmentally.AlarmService.Service
- {
- public class RabbitMQReceiveService : IHostedService, IDisposable
- {
- private readonly IServiceProvider _provider;
- private static readonly ILog log = LogManager.GetLogger(typeof(RabbitMQReceiveService));
- private readonly IHttpClientFactory httpClientFactory;
- private readonly CofingSetModel _cofingSetModel;
- private readonly RabbitMQModel _rabbitMQModel;
- private readonly IPushMsgService _pushMsgService;
- public RabbitMQReceiveService(IServiceProvider provider, CofingSetModel cofingSetModel, IHttpClientFactory httpClientFactory, IPushMsgService pushMsgService)
- {
- this._provider = provider;
- _cofingSetModel = cofingSetModel;
- if (cofingSetModel != null)
- {
- _rabbitMQModel = cofingSetModel.RabbitMQ;
- }
- this.httpClientFactory = httpClientFactory;
- _pushMsgService = pushMsgService;
- }
- private IConnection con;
- private IModel channel;
- public Task StartAsync(CancellationToken cancellationToken)
- {
- Task.Run(async () =>
- {
-
-
-
-
-
-
- await AddRabbitMQ();
-
-
-
-
-
-
- });
- return Task.CompletedTask;
- }
- public async Task AddRabbitMQ()
- {
- try
- {
- var factory = new ConnectionFactory()
- {
- HostName = _rabbitMQModel.HostName,
- Port = _rabbitMQModel.Port,
- UserName = _rabbitMQModel.UserName,
- VirtualHost = _rabbitMQModel.VirtualHost,
- Password = _rabbitMQModel.Password,
- };
- if (con == null || con.IsOpen == false)
- {
- con = factory.CreateConnection();
- }
- if (channel == null || channel.IsOpen == false)
- {
- channel = con.CreateModel();
- }
- channel.ExchangeDeclare(_rabbitMQModel.ExchangeName, type: ExchangeType.Direct);
-
- var queueName = channel.QueueDeclare(
- queue: _rabbitMQModel.QueueName,
- durable: false,
- exclusive: false,
- autoDelete: false,
- arguments: null
- ).QueueName;
- channel.QueueBind(queueName, _rabbitMQModel.ExchangeName, _rabbitMQModel.RoutingKey);
-
- channel.BasicQos(0, 1, false);
- channel.ConfirmSelect();
-
- var consumer = new EventingBasicConsumer(channel);
- consumer.Received += async (model, ea) =>
- {
- try
- {
- var body = ea.Body.ToArray();
- var message = Encoding.UTF8.GetString(body);
- log.Info("【RabbitMQ】" + message);
- bool result = await WebScadaAlarmExecute(message);
- if (result)
- {
-
- channel.BasicAck(deliveryTag: ea.DeliveryTag, multiple: false);
- }
- else
- {
- channel.BasicNack(ea.DeliveryTag, false, true);
- }
- }
- catch (Exception ex)
- {
- channel.BasicNack(ea.DeliveryTag, false, true);
- log.Info("【RabbitMQ-接收消息处理异常了】" + ex.Message);
- }
- };
-
- channel.BasicConsume(queue: _rabbitMQModel.QueueName, autoAck: false, consumer: consumer);
- }
- catch (Exception ex)
- {
- log.Info("【异常-RabbitMQ】" + ex.Message);
- }
- }
-
-
-
-
-
- public async Task<bool> WebScadaAlarmExecute(string msgData)
- {
- bool result = false;
- try
- {
- var pushMsg = JsonConvert.DeserializeObject<TpushMsgModel>(msgData);
- Inspection.Common.Helper.RabbitMQModel rabbitMQModels =new Inspection.Common.Helper.RabbitMQModel();
- rabbitMQModels.QueueName = "rab.video.record.mqtt";
- rabbitMQModels.UserName = _rabbitMQModel.UserName;
- rabbitMQModels.Password = _rabbitMQModel.Password;
- rabbitMQModels.HostName = _rabbitMQModel.HostName;
- rabbitMQModels.Port = _rabbitMQModel.Port;
- rabbitMQModels.VirtualHost = _rabbitMQModel.VirtualHost;
- rabbitMQModels.ExchangeName = rabbitMQModels.QueueName+".DirectExchange";
- rabbitMQModels.RoutingKey = rabbitMQModels.QueueName + ".key";
- bool bols = await _pushMsgService.PushAlarmMsgAsync(pushMsg, pushMsg.Subject, rabbitMQModels);
- if (bols)
- {
- result = true;
- }
- }
- catch (Exception ex)
- {
- log.Info("【异常-WebScadaAlarmExecute】" + ex.Message);
- }
- return result;
- }
-
-
-
-
-
- public async Task<bool> WebScadaAlarmExecuteAPI(string msgData)
- {
- bool result = false;
- try
- {
- using (HttpClient httpClient = httpClientFactory.CreateClient())
- {
- var httpRequestMessage = new HttpRequestMessage
- {
- Method = HttpMethod.Post,
- RequestUri = new Uri(_cofingSetModel.PublicPushMessageAPI),
- Content = new StringContent(msgData, Encoding.UTF8, "application/json")
- };
- var response = await httpClient.SendAsync(httpRequestMessage);
- string responseResult = await response.Content.ReadAsStringAsync();
- if (response.StatusCode != HttpStatusCode.OK)
- {
- log.Info($"【错误-WebScadaAlarmExecute】WebScada服务的设备报警 发送数据失败【{msgData}】");
- }
- else
- {
-
- receiveModel resultReturn = JsonConvert.DeserializeObject<receiveModel>(responseResult);
- if (resultReturn.code == "0") { result = true; }
- }
- }
- }
- catch (Exception ex)
- {
- log.Info("【异常-WebScadaAlarmExecute】" + ex.Message);
- }
- return result;
- }
- public Task StopAsync(CancellationToken cancellationToken)
- {
- Dispose();
- return Task.CompletedTask;
- }
- public void Dispose()
- {
- if (channel!=null)
- {
- channel.Close();
- }
- if (con!=null)
- {
- con.Close();
- }
- }
- }
- public class receiveModel
- {
- public string code { get; set; }
- public string message { get; set; }
- }
- }
|