rabbitmq发送json消息

本文档详细介绍了如何使用Java编程语言通过RabbitMQ发送JSON格式的消息,适用于构建分布式系统中的异步通信。
摘要由CSDN通过智能技术生成

rabbitmq发送json格式消息

package org.secp.rabbitmq.exchange;

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.TopicExchange;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @ClassName
 * @Author lzp
 * @Date 2022/5/18 19:11
 * @Version 1.0
 **/
@Configuration
public class TopicMqConfig {
   

    /**
     * 交换机名称
     */
    public static final String SECP_TOPIC_EXCHANGE_NAME = "secp.topic.exchange";

    /**
     * 定义bindingKey,模糊匹配
     */
    public static final String BINGDING_KEY_TEST1 = "*.*.userInfo";

    public static final String BINGDING_KEY_TEST2 = "*.*.basics";

    public static final String BINGDING_KEY_TEST3 = "*.*.organization";

    /**
     * 构建topic类型交换机
     *
     * @return
     */
    @Bean
    public TopicExchange topicExchange() {
   
        return new TopicExchange(SECP_TOPIC_EXCHANGE_NAME, true, false);
    }

    /**
     * 用户同步队列名称
     */
    public final static String SECP_DATA_USER_INFO = "secp_data_user_info";
    /**
     * 基础数据同步队列名称
     */
    public final static String SECP_DATA_BASICS = "secp_data_basics";
    /**
     * 组织数据同步队列名称
     */
    public final static String SECP_DATA_ORGANIZATION = "secp_data_organization";

    /**
     * 创建队列 设置路由 构建序列 
     * userQueue
     *
     * @return
     */
    @Bean
    public Queue userQueue() {
   
        // 支持持久化
        return new Queue(SECP_DATA_USER_INFO, true);
    }

    /**
     * 创建队列 设置路由 构建序列 
     * basicsQueue
     *
     * @return
     */
    @Bean
    public Queue
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Python中使用RabbitMQ传递JSON消息,可以使用pika库来连接和操作RabbitMQ。同时,Python标准库中也提供了json模块来进行JSON编码和解码。 下面是一个简单的示例代码,演示如何使用pika库和json模块向RabbitMQ发送JSON消息和接收JSON消息: ```python import pika import json # 创建RabbitMQ连接 connection = pika.BlockingConnection(pika.ConnectionParameters('localhost')) channel = connection.channel() # 声明队列 channel.queue_declare(queue='json_queue') # 发送JSON消息 message = {'name': 'Alice', 'age': 25} json_message = json.dumps(message) channel.basic_publish(exchange='', routing_key='json_queue', body=json_message) # 接收JSON消息 def callback(ch, method, properties, body): json_message = json.loads(body) print("Received JSON message:", json_message) channel.basic_consume(queue='json_queue', on_message_callback=callback, auto_ack=True) print('Waiting for JSON messages...') channel.start_consuming() # 关闭连接 connection.close() ``` 在以上示例代码中,我们首先使用pika库创建了一个RabbitMQ连接,并声明了一个名为json_queue的队列。然后,我们使用json模块将一个Python字典对象转换为JSON字符串,并将其作为消息发送json_queue队列中。 接着,我们定义了一个回调函数callback,用于接收从json_queue队列中接收到的消息,并使用json模块将JSON字符串转换为Python字典对象,最后打印出接收到的消息。 最后,我们使用basic_consume方法来启动一个消费者,等待从json_queue队列中接收JSON消息。在接收到消息后,回调函数将被调用,将消息体传递给它进行处理。 需要注意的是,以上示例代码中使用了auto_ack参数来自动确认接收到的消息。这意味着一旦消息被接收,它就会被立即确认。如果你需要手动确认消息,则可以将auto_ack参数设置为False,并在处理完消息后调用basic_ack方法来手动确认消息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值