springboot整合rabbitmq简单使用

使用rabbitmq去发送消息。
首先是rabbitmq的安装步骤
rabbitmq是基于erlang的,首先安装erlang:https://www.erlang.org/downloads 选择自我对应的,反正我的是这个
在这里插入图片描述
由于我安装到F盘了,所以配置环境变量的时候要注意
在这里插入图片描述
在这里插入图片描述
配置好了之后检测一下
在这里插入图片描述
下载rabbitmq https://www.rabbitmq.com/download.html
我选的是这个
在这里插入图片描述
下载完以后双击安装,找到这个位置 例如:F:\Program Files\RabbitMQ Server\rabbitmq_server-3.8.9\sbin
然后按照以下进行操作,就是进入到该位置然后输入rabbitmq-plugins enable rabbitmq_management
在这里插入图片描述
然后去刚才的位置,双击运行
在这里插入图片描述
访问这个:http://localhost:15672
在这里插入图片描述
账号密码都是guest
在这里插入图片描述
安装成功

开始使用:

 <!-- rabbitMq -->
        <dependency>
		    <groupId>org.springframework.boot</groupId>
		    <artifactId>spring-boot-starter-amqp</artifactId>
		</dependency>
#RabbitMq base config
spring.rabbitmq.host=127.0.0.1
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest

简单配置类

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.DirectExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 *  Broker:它提供一种传输服务,它的角色就是维护一条从生产者到消费者的路线,保证数据能按照指定的方式进行传输, 
	Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。 
	Queue:消息的载体,每个消息都会被投到一个或多个队列。 
	Binding:绑定,它的作用就是把exchange和queue按照路由规则绑定起来. 
	Routing Key:路由关键字,exchange根据这个关键字进行消息投递。 
	vhost:虚拟主机,一个broker里可以有多个vhost,用作不同用户的权限分离。 
	Producer:消息生产者,就是投递消息的程序. 
	Consumer:消息消费者,就是接受消息的程序. 
	Channel:消息通道,在客户端的每个连接里,可建立多个channel.

    rabbitMq都支持消息持久化。持久化消息主要是指:MQ down或者MQ所在的服务器down了,消息不会丢失的机制。
	rabbitmq的使用过程大概如下:
	客户端连接到消息队列服务器,打开一个channel。
	客户端声明一个exchange,并设置相关属性,相关属性包括exchange的名字,exchange是否可以被持久化(持久化到磁盘),exchange是否自动删除
	客户端声明一个queue,并设置相关属性,相关属性包括queue的名字,queue是否可以被持久化(持久化到磁盘),queue是否自动删除
	声明exchange和queue之间的binding关系,用唯一的key来进行绑定
	客户端投递消息到exchange。
	不同类型的exchange根据路由规则将消息分发到不同的queue中
	客户端监听到queue中的内容,将消息取出消费,发送ack到rabbitmq中,删除该条消息
*/

@Configuration
public class RabbitConfig {

    @Bean
    public Queue myQueue() {
        // 构造一个新队列,给定名称和持久性标志。该队列是非排他的和非自动删除的。
        return new Queue("myQueueTest", true);
    }

    @Bean
    public DirectExchange myExchange() {
    	//构造一个新的Exchange,给定名称、持久性标志和自动删除标志。
        return new DirectExchange("myExchangeTest", true, false);
    }

    @Bean
    //把队列和消费的exchange绑定在一起
    public Binding myBinding() {
        return BindingBuilder.bind(myQueue()).to(myExchange()).with("myRoutingKeyTest");
    }
	 
}

发送

@Controller
public class RabbitSend {

	 	@Autowired
	    RabbitTemplate rabbitTemplate;
	 	
	 	@RequestMapping("/sendMessage")
	    public void send() {
	        String message =  "message" + new Date();
	        System.out.println(new Date().toLocaleString()+"我发送了消息:" + message);
	        /**
	         * String exchange, String routingKey, final Object object
	         */
	        rabbitTemplate.convertAndSend("myExchangeTest", "myRoutingKeyTest", message);
	    }
}

接收

@Component
public class RabbitReceiver {

	@RabbitHandler
    @RabbitListener(queues = "myQueueTest")
    public void immediateProcess(String message) {
        System.out.println(new Date().toLocaleString()+"我接受到了消息:" + message);
    }
}

测试
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值