RabbitMQ - 简单使用

本文详细介绍了如何在RabbitMQ中配置虚拟主机、交换器、队列,并通过示例展示了绑定队列到交换器的过程及如何指定路由键。同时,文章提供了使用Java进行消息发送和接收的代码示例,包括点对点和订阅模式。

一、理解

  1.步骤

  •  建立虚拟主机virtual hosts
  •  建立交换器Exchanges(交换器主要是三种类型direct,fanout, topic)
  •  建立队列Queues
  •  队列与交换器绑定,在此过程中指定绑定的路由键 --> 路由键可以精确匹配也可以使用 # 进行模糊匹配(匹配零个或多个)

二、简单使用测试

  /**
     * mq控制类
     */
    @Autowired
    private AmqpAdmin amqpAdmin;
    /**
     * mq调用类
     */
    @Autowired
    private RabbitTemplate rabbitTemplate;


    //创建交换器
    @Test
    public void contextLoads() {
        amqpAdmin.declareExchange(new DirectExchange("myone"));//持久化:DirectExchange(String name, boolean durable, boolean autoDelete)- autoDelete 是否持久化
        amqpAdmin.declareExchange(new FanoutExchange("mytwo"));
    }

    //创建队列
    @Test
    public void cont213213extLoads() {
        amqpAdmin.declareQueue(new Queue("haone"));//持久化:Queue(String name, boolean durable) - autoDelete 是否持久化
        amqpAdmin.declareQueue(new Queue("hatwo"));
    }

    //绑定并指定路由键
    @Test
    public void cont2132sadasd13extLoads() {
        amqpAdmin.declareBinding(new Binding("haone", Binding.DestinationType.QUEUE,"myone","keyone",null));
        amqpAdmin.declareBinding(new Binding("hatwo", Binding.DestinationType.QUEUE,"mytwo","keytwo",null));
        amqpAdmin.declareBinding(new Binding("haone", Binding.DestinationType.QUEUE,"mytwo","keythree",null));
    }

    //发送点对点消息
    @Test
    public void cont2132sasfgdsgdasd13extLoads() {
        Map<String,String> map = new HashMap<String,String>();
        map.put("方哈儿","大笨蛋");
        rabbitTemplate.convertAndSend("myone","keyone",map);
    }
    //发送订阅消息
    @Test
    public void cont2132sadasdfghfghgfg13extLoads() {
     //要判断是否为null,因为消费后,消息就消失了,
        Object haone = rabbitTemplate.receiveAndConvert("haone");
        System.out.println(haone.getClass());
        System.out.println(haone);
    }

 三、是否序列话成json,需要的话要添加一个配置类

@Configuration
public class CustomerRabbitMQConfig {

    @Bean
    public MessageConverter messageConverter(){
        return new Jackson2JsonMessageConverter();
    }
}

 四、配置文件

spring:
  rabbitmq:
    host: localhost
    virtual-host: rlzy
    username: lalademaxiya
    password: 123456

 

### 关于 RabbitMQ-C 的使用教程 #### 安装过程 对于希望在 C 语言环境中利用 RabbitMQ 进行开发的应用开发者来说,安装 `rabbitmq-c` 库是一个必要的前提条件。通过下载源码包并借助 cmake 工具可以完成这一库的编译与安装工作[^4]。 #### 发布消息实例 下面提供了一个简单的例子展示怎样创建一个发布者应用: ```c #include <stdio.h> #include <stdlib.h> #include <amqp.h> #include <amqp_tcp_socket.h> int main(int argc, char const *const *argv) { amqp_connection_state_t conn; int status; // 创建连接对象 conn = amqp_new_connection(); struct amqp_tcp_socket_t *socket = amqp_tcp_socket_new(conn); if (!socket) abort(); status = amqp_socket_open(socket, "localhost", 5672); // 建立到RabbitMQ服务器的TCP连接 if (status) abort(); // 登录虚拟主机 '/' amqp_rpc_reply_t reply = amqp_login(conn, "/", 0, 131072, 0, AMQP_SASL_METHOD_PLAIN, "guest", "guest"); if(reply.reply_type != AMQP_RESPONSE_NORMAL){ printf("Login failed\n"); return 1; } amqp_channel_open(conn, 1); // 打开信道 reply = amqp_get_rpc_reply(conn); if(reply.reply_type != AMQP_RESPONSE_NORMAL){ printf("Channel open error\n"); return 1; } amqp_basic_properties_t props; props._flags = AMQP_BASIC_CONTENT_TYPE_FLAG | AMQP_BASIC_DELIVERY_MODE_FLAG; props.content_type = amqp_cstring_bytes("text/plain"); props.delivery_mode = 2; /* persistent delivery mode */ amqp_publish(conn, 1, /* channel */ amqp_cstring_bytes("test-exchange"),/* exchange */ amqp_empty_bytes, /* routing key */ 0, /* mandatory */ 0, /* immediate */ &props, amqp_cstring_bytes("Hello from rabbitmq-c!")); /* message body */ sleep(1); amqp_channel_close(conn, 1, AMQP_REPLY_SUCCESS); amqp_connection_close(conn, AMQP_REPLY_SUCCESS); amqp_destroy_connection(conn); return 0; } ``` 这段代码展示了如何建立至 RabbitMQ 服务端的 TCP 连接、登录验证以及发送一条简单文本消息的过程。 #### 订阅消息实例 订阅来自队列的消息同样重要,在这里给出一段基础示例来解释这个操作是如何实现的: ```c // ... 上面省略部分初始化代码 ... void handle_delivery(amqp_envelope_t envelope, void* ignored) { printf("Received a message: %.*s\n", (int)envelope.message.body.len, (char *)envelope.message.body.bytes); } reply = amqp_queue_declare(conn, 1, amqp_empty_bytes, 0, 0, 0, 1, amqp_empty_table); if (reply.reply_type != AMQP_RESPONSE_NORMAL) { /* Handle errors */ } amqp_basic_consume(conn, 1, reply.method.queue.name, amqp_empty_bytes, 0, 1, 0, amqp_empty_table); while(true) { amqp_rpc_reply_t res = amqp_consume_message(conn, &envelope, NULL, 0); if(res.reply_type == AMQP_RESPONSE_LIBRARY_EXCEPTION && res.library_error == AMQP_STATUS_TIMEOUT) continue; if(res.reply_type != AMQP_RESPONSE_NORMAL){ break;} handle_delivery(envelope, NULL); free(envelope.message.body.bytes); amqp_destroy_envelope(&envelope); } // ... 后续关闭资源 ... ``` 此段代码实现了声明一个新的队列,并设置消费者去监听该队列中的新消息到达事件的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值