RabbitMQ随手笔记(十三)TTL(.netCore2.0)

两种TTL:如果两种都设置了,按照TTL小的那个处理

1.通过队列属性设置,通过队列发送出去的消息都遵循这个TTL;

2.通过对消息本身单独设置

第一种,一旦消息过期直接丢弃;第二种,即使消息过期,也不一定立刻丢弃,因为只有当消息被投递的时候,才能判断该消息是否过期。

设置队列TTL:

如果不设置TTL,则表示此消息不会过期,如果将TTL设置为0,则表示除非此时可以直接将消息投递到消费者,否则该消息立即被丢弃。

                ConnectionFactory factory = new ConnectionFactory();
                factory.HostName = IP_ADDRESS;
                factory.Port = PORT;
                factory.UserName = USER_NAME;
                factory.Password = PASSWORD;
                con = factory.CreateConnection();
                channel = con.CreateModel();
                channel.ExchangeDeclare(EXCHANGE_NAME, "topic", true, false, null);

                Dictionary<string, object> agres = new Dictionary<string, object>();
                //消息TTL01.Queue设置
                agres.Add("x-message-ttl", 6000);
                //队列TTL设置:1800000ms
                agres.Add("x-expires", 1800000);
                channel.QueueDeclare(QUEUE_NAME, true, false, false, agres);


                channel.QueueBind(QUEUE_NAME, EXCHANGE_NAME, BINDING_KEY, null);//channel.ExchangeBind()
                string message = "Hello Word!";
                var body = Encoding.UTF8.GetBytes(message);
                var properties = channel.CreateBasicProperties();
                properties.Persistent = true; //消息TTL01.Queue设置
                agres.Add("x-message-ttl", 6000);
                //队列TTL设置:1800000ms
                agres.Add("x-expires", 1800000);
                channel.QueueDeclare(QUEUE_NAME, true, false, false, agres);


                channel.QueueBind(QUEUE_NAME, EXCHANGE_NAME, BINDING_KEY, null);//channel.ExchangeBind()
                string message = "Hello Word!";
                var body = Encoding.UTF8.GetBytes(message);
                var properties = channel.CreateBasicProperties();
                properties.Persistent = true;

 

设置消息TTL:

 

     ConnectionFactory factory = new ConnectionFactory();
                factory.HostName = IP_ADDRESS;
                factory.Port = PORT;
                factory.UserName = USER_NAME;
                factory.Password = PASSWORD;
                con = factory.CreateConnection();
                channel = con.CreateModel();
                channel.ExchangeDeclare(EXCHANGE_NAME, "topic", true, false, null);

                //Dictionary<string, object> agres = new Dictionary<string, object>();
                消息TTL01.Queue设置
                //agres.Add("x-message-ttl", 6000);
                队列TTL设置:1800000ms
                //agres.Add("x-expires", 1800000);
                //channel.QueueDeclare(QUEUE_NAME, true, false, false, agres);


                channel.QueueBind(QUEUE_NAME, EXCHANGE_NAME, BINDING_KEY, null);//channel.ExchangeBind()
                string message = "Hello Word!";
                var body = Encoding.UTF8.GetBytes(message);
                var properties = channel.CreateBasicProperties();
                properties.Persistent = true;

                //消息TTL02.每条消息设置设置,如果两个都设置了,则按照TTL小的那个
                properties.Expiration = "6000";//TTL = 6000ms
                channel.BasicPublish(EXCHANGE_NAME, ROUTING_KEY, properties, body); properties.Expiration = "6000";//TTL = 6000ms
                channel.BasicPublish(EXCHANGE_NAME, ROUTING_KEY, properties, body);

 

更多精彩请关注公众号:隔壁王小猿(gbwxy-happy)

 

 

### 回答1: rabbitmq.4.lib 和 librabbitmq.4.lib 都是 RabbitMQ 的库文件,用于 Windows 平台开发者使用 RabbitMQ 的 C/C++ 客户端库。这两个库文件都是在 Windows 下编译时所生成的文件,主要用途是方便用户在 Visual Studio 开发环境下使用和编译 RabbitMQ 客户端。 这两个库文件也是 RabbitMQ 的一个重要组成部分,允许开发者将 RabbitMQ 的消息队列集成到他们的应用程序中,以便于实现跨平台的消息通信。其中,rabbitmq.4.lib 是 RabbitMQ 的 AMQP 协议 C++ 客户端库文件,包含了一系列的函数和类,使得开发者可以在他们的代码内部实现 RabbitMQ 消息队列。而 librabbitmq.4.lib 是 RabbitMQ 的 AMQP 协议 C 客户端库文件,一般在 Windows 系统下使用,用法与 rabbitmq.4.lib 类似,只是语言不同。 总之,这两个库文件都是实现 RabbitMQ 在 Windows 环境下的客户端库,它们允许开发者在 Windows 平台下更轻松地使用 RabbitMQ,并且在跨平台开发时更加方便快捷。 ### 回答2: RabbitMQ是一个开源的消息代理系统,通常用于分布式应用程序中的消息队列实现。librabbitmq是一个C语言客户端库,用于与RabbitMQ消息代理进行交互。librabbitmq.4.lib是librabbitmq库的一部分,是Windows操作系统下编译生成的动态库。这个库提供了一组API,可以实现基于RabbitMQ消息代理的消息传递。使用这个库,开发者可以在C语言中实现生产者、消费者模型,从消息队列中获取数据或发送数据到队列中等操作。此外,这个库还提供了诸如信道管理、连接管理等多个高级功能,为开发RabbitMQ应用程序提供了便利。RabbitMQ作为一款常用的消息代理系统,其在企业级应用、云计算等领域都有广泛的应用,而librabbitmq.4.lib作为RabbitMQ C语言客户端库,可以在Windows环境下提供高效的消息传递处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值