zoukankan      html  css  js  c++  java
  • 当asp.net core偶遇docker一(模型验证和Rabbitmq 二)

    上一篇我们说到构建了一个Rabbitmq容器

    现在我们说说如何在一个悄悄传输消息到队列

    我们现在设计一个Rabbitmq发送消息部分的模块

    先设计一个远程发送的接口

        public interface IRemoteSend
        {
            void Send(object entity);
        }

    写一个Rabbitmq配置实体

        public class RabbitmqConfigura
        {
            public string Host { get; set; }
            public int Port { get; set; }
            public string User { get; set; }
            public string Password { get; set; }
            public string VirtualHost { get; set; }
        }

    写一个实现IRemoteSend的RabbitmqRemoteSend

        public class RabbitmqRemoteSend : IRemoteSend
        {
            private RabbitmqConfigura Configura { get; }
            public RabbitmqRemoteSend(IOptions<RabbitmqConfigura> options)
            {
                Configura = options.Value;
            }
    
            public void Send(object entity)
            {
                throw new NotImplementedException();
            }
        }

    我们再实现以下Send方法

        public class RabbitmqRemoteSend : IRemoteSend
        {
            public int DelaySend { get; set; }
            private RabbitmqConfigura Configura { get; }
            public RabbitmqRemoteSend(IOptions<RabbitmqConfigura> options)
            {
                Configura = options.Value;
            }
    
            public void Send(object entity)
            {
                var factory = new ConnectionFactory
                {
                    HostName = Configura.Host,
                    Port = Configura.Port,
                    UserName = Configura.User,
                    Password = Configura.Password,
                    VirtualHost = Configura.VirtualHost,
    
                    AutomaticRecoveryEnabled = true,
                    NetworkRecoveryInterval = TimeSpan.FromSeconds(30)
                };
    
                using (var connection = factory.CreateConnection())
                {
                    var model = connection.CreateModel();
    
                    var type_name = entity.GetType();
                    var ExchangeName = type_name + ".exchange";
                    var RouteKeyName = type_name + ".input";
                    var QueueName = type_name + ".input";
    
                    model.ConfirmSelect();
                    model.ExchangeDeclare(ExchangeName, ExchangeType.Direct);
                    model.QueueDeclare(QueueName, false, false, false);
                    model.QueueBind(QueueName, ExchangeName, RouteKeyName);
    
                    var args = new Dictionary<string, object>();
                    args.Add("x-message-ttl", DelaySend);
                    args.Add("x-dead-letter-exchange", ExchangeName);
                    args.Add("x-dead-letter-routing-key", QueueName);
                    model.QueueDeclare(QueueName + ".delay", false, false, false, args);
    
                    var bytes = new byte[];
                    var props = model.CreateBasicProperties();
    
                    props.ContentType = "text/plain";
                    props.DeliveryMode = 2;
                    model.BasicPublish(ExchangeName, RouteKeyName, props, bytes);
                    model.WaitForConfirms();
                }
            }
        }

    我们需要定义一个序列化的接口做数据编码

        public interface IFormattor
        {
            byte[] SerializeObject(object entity);
        }

    写一个默认实现

        public class JsonFormattor : IFormattor
        {
            public byte[] SerializeObject(object entity)
            {
                var jsonString = JsonConvert.SerializeObject(entity);
                return Encoding.UTF8.GetBytes(jsonString);
            }
        }

    再修改以下RabbitmqRemoteSend

    public class RabbitmqRemoteSend : IRemoteSend
        {
            public int DelaySend { get; set; }
            private RabbitmqConfigura Configura { get; }
            private IFormattor Formattor { get; }
            public RabbitmqRemoteSend(IOptions<RabbitmqConfigura> options, IFormattor formattor)
            {
                Configura = options.Value;
                Formattor = formattor;
            }
    
            public void Send<TEntity>(TEntity entity) where TEntity : class
            {
                var factory = new ConnectionFactory
                {
                    HostName = Configura.Host,
                    Port = Configura.Port,
                    UserName = Configura.User,
                    Password = Configura.Password,
                    VirtualHost = Configura.VirtualHost,
    
                    AutomaticRecoveryEnabled = true,
                    NetworkRecoveryInterval = TimeSpan.FromSeconds(30)
                };
    
                using (var connection = factory.CreateConnection())
                {
                    var model = connection.CreateModel();
    
                    var type_name = entity.GetType().Name;
                    var ExchangeName = type_name + ".exchange";
                    var RouteKeyName = type_name + ".input";
                    var QueueName = type_name + ".input";
    
                    model.ConfirmSelect();
                    model.ExchangeDeclare(ExchangeName, ExchangeType.Direct);
                    model.QueueDeclare(QueueName, false, false, false);
                    model.QueueBind(QueueName, ExchangeName, RouteKeyName);
    
                    var args = new Dictionary<string, object>();
                    args.Add("x-message-ttl", DelaySend);
                    args.Add("x-dead-letter-exchange", ExchangeName);
                    args.Add("x-dead-letter-routing-key", QueueName);
                    model.QueueDeclare(QueueName + ".delay", false, false, false, args);
    
                    var bytes = Formattor.SerializeObject(entity);
                    var props = model.CreateBasicProperties();
    
                    props.ContentType = "text/plain";
                    props.DeliveryMode = 2;
                    model.BasicPublish(ExchangeName, RouteKeyName, props, bytes);
                    model.WaitForConfirms();
                }
            }
        }

    我们加入asp.net core测试一下

    在ConfigureServices内增加代码

                #region Rabbitmq
                services.Configure<RabbitmqConfigura>(p => 
                {
                    p.User = "admin";
                    p.Password = "123456";
                    p.Host = "127.0.0.1";
                });
                services.AddScoped<IFormattor, JsonFormattor>();
                services.AddScoped<IRemoteSend, RabbitmqRemoteSend>();
                #endregion

    在Configure增加代码

                var scope = app.ApplicationServices.CreateScope();
                var remoteSend = scope.ServiceProvider.GetRequiredService<IRemoteSend>();
                remoteSend.Send(new User()
                {
                    Name = "hello",
                    Account = "account"
                });

    这段代码是完全用来测试的

    User实体对象

        public class User
        {
            public string Name { get; set; }
            public string Account { get; set; }
        }

    我们在看看Rabbitmq内

    看看内容

  • 相关阅读:
    [20190415]10g下那些latch是共享的.txt
    [20190415]11g下那些latch是共享的.txt
    [20190409]pre_page_sga=true与连接缓慢的问题.txt
    [20190402]Library Cache mutex.txt
    scrapy简单使用方法
    PHP多进程系列笔(转)
    RdKafka文档翻译
    python判断字符串中是否包含子字符串
    python 逐行读取txt文件
    redis使用watch完成秒杀抢购功能(转)
  • 原文地址:https://www.cnblogs.com/NCoreCoder/p/9939594.html
Copyright © 2011-2022 走看看