微服务项目使用RabbitMQ
微服务项目使用RabbitMQ
很久未用RabbitMQ了,根据网上的Demo,大多数是一个服务包含所有的生产者和消费者和配置,当自己去搭建服务的时候,还需要一些思考各种包的划分.无法无脑CV大法,所以,下文,我根据实际项目抽离出一个比较完整的小Demo演示微服务项目使用RabbitMQ.注意:这个小Demo并没有做消息的可靠性相关操作!
公共服务
一般微服务有一个公共服务,用于存放一些配置类或者常量类等,这里我以service_util举例,这个服务下,应该会有以下四个包,如下:
├─config -- 配置类的包
│ RabbitMQConfig.java
│
├─MQConstant -- 常量的包
│ RabbitMQConstant.java
│
├─service -- 封装的服务的包
│ RabbitService.java
│
└─vo -- Vo的包
OrderVo.java
RabbitMQConfig
这个类下,我们可以配置基本的RabbitMQ的消息的序列化,在消息的传输过程中,对象和Json的互相转化,详细代码如下:
package com.leixin.mq.config;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.amqp.support.converter.MessageConverter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* @Classname RabbitMQConfig
* @Description TODO
* @Date 2023-08-07 21:25
* @Created by LeiXin
*/
/*
这个配置类的作用是将一个消息转换器添加到RabbitMQ中,
这样在消息发送和接收时,
就能够自动地将Java对象转换为JSON格式的消息,
以及将JSON格式的消息转换回Java对象。
*/
@Configuration
public class RabbitMQConfig {
// 声明一个@Bean注解,表示这是一个Spring Bean,会由Spring容器进行管理和实例化
@Bean
public MessageConverter getMessageConverter() {
// 创建并返回一个Jackson2JsonMessageConverter实例作为消息转换器
// 这个转换器用于在消息发送和接收之间进行JSON格式的转换
return new Jackson2JsonMessageConverter();
}
}
RabbitMQConstant
这个包用于指定消息队列的常量
package com.leixin.mq.MQConstant;
/**
* @Classname RabbitMQConstant
* @Description TODO
* @Date 2023-08-07 23:23
* @Created by LeiXin
*/
public class RabbitMQConstant {
/**
* 预约下单
*/
public static final String EXCHANGE_DIRECT_ORDER = "exchange.direct.order";
public static final String ROUTING_ORDER = "order";
//队列
public static final String QUEUE_ORDER = "queue.order";
/**
* 短信
*/
public static final String EXCHANGE_DIRECT_SMS = "exchange.direct.msm";
public static final String ROUTING_SMS_ITEM = "msm.item";
//队列
public static final String QUEUE_MSM_SMS = "queue.msm.item";
}
RabbitService
这个包用于封装消息的发送方式,之后发送消息只要使用RabbitService.
package com.leixin.mq.service;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* @Classname RabbitService
* @Description TODO
* @Date 2023-08-07 23:07
* @Created by LeiXin
*/
@Service
public class RabbitService {
@Autowired
private RabbitTemplate rabbitTemplate;
/**
* 发送消息
* @param exchange
* @param routingKey
* @param message
* @return
*/
public boolean sendMessage(String exchange,String routingKey,Object message){
rabbitTemplate.convertAndSend(exchange,routingKey,message);
return true;
}
}
OrderVo
这里注意Vo包都要放在公共包中,因为生产者和消费者的服务都使用这个对象进行消息的封装传输,这个OrderVo类,只是简单举个例子.
package com.leixin.mq.vo;
/**
* @Classname OrderVo
* @Description TODO
* @Date 2023-08-08 0:04
* @Created by LeiXin
*/
public class OrderVo {
String id;
String orderName;
Integer count;
public Integer getCount() {
return count;
}
public void setCount(Integer count) {
this.count = count;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getOrderName() {
return orderName;
}
public void setOrderName(String orderName) {
this.orderName = orderName;
}
}
依赖
<parent>
<groupId>com.leixin</groupId>
<artifactId>SpringBoot-RabbitMq</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<artifactId>service_util</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 提供 Spring Boot 对 AMQP(高级消息队列协议)的支持,包括 RabbitMQ -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<!-- 提供 Java 的 Lombok 库,可以简化代码中的重复和样板代码,提高代码可读性和可维护性 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!-- 提供 Spring Boot 单元测试和集成测试所需的支持 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
生产者
生产者用于发送消息,简单举例,就直接在Controller层发送消息
└─producer
│ XxxApplication.java
│
└─controller
XxxController.java
XxxApplication
SpringBoot的启动类,注意,这个CompontScan主要是为了扫描到公共包的一些配置或者组件
@SpringBootApplication
@ComponentScan("com.leixin")
public class XxxApplication {
public static void main(String[] args) {
SpringApplication.run(XxxApplication.class, args);
}
}
XxxController
生产者的服务发送至消息队列
@RestController
@RequestMapping("/test")
public class XxxController {
@Autowired
private RabbitService rabbitService;
@GetMapping
public void testSendMessage(){
OrderVo orderVo = new OrderVo();
orderVo.setCount(100);
rabbitService.sendMessage(RabbitMQConstant.EXCHANGE_DIRECT_ORDER
,RabbitMQConstant.ROUTING_ORDER,
orderVo);
}
}
配置类
application.yml
# Spring配置部分
spring:
rabbitmq:
# RabbitMQ主机地址
host: localhost
# RabbitMQ端口
port: 5672
# 连接RabbitMQ的用户名
username: guest
# 连接RabbitMQ的密码
password: guest
# 虚拟主机,默认为根虚拟主机"/"
virtual-host: /
# Spring Boot内嵌服务器配置部分
server:
# 内嵌服务器监听的端口号
port: 8092
依赖
<dependencies>
<dependency>
<groupId>com.leixin</groupId>
<artifactId>service_util</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
消费者
消费者主要用于处理一些消息,文件如下:
│ YyyApplication.java
│
└─listener
YyyMQListener.java
YyyMQListener
这里就是用于处理消息
package com.leixin.mq.listener;
import com.leixin.mq.MQConstant.RabbitMQConstant;
import com.leixin.mq.vo.OrderVo;
import com.rabbitmq.client.Channel;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
/**
* @Classname YyyMQListener
* @Description TODO
* @Date 2023-08-07 23:54
* @Created by LeiXin
*/
@Component
public class YyyMQListener {
// 使用 @RabbitListener 注解标记这个方法作为消息监听器
// bindings 属性用于定义队列、交换机以及路由关系
@RabbitListener(bindings = {
@QueueBinding(
value = @Queue(name = RabbitMQConstant.QUEUE_ORDER, durable = "true"), // 创建队列
exchange = @Exchange(name = RabbitMQConstant.EXCHANGE_DIRECT_ORDER), // 创建交换机
key = RabbitMQConstant.ROUTING_ORDER
)
})
// consume 方法用于处理收到的消息
public void consume(OrderVo order, Message message, Channel channel) {
// 从传入的 OrderVo 对象中获取订单数量,并将其减少
Integer count = order.getCount();
count--;
// 输出调试信息,展示订单数量的变化
System.out.println(count);
// 在这里可以添加你的业务逻辑,处理订单相关的操作
// 例如,更新数据库中的订单状态、发送通知等
// 最后,可能需要手动确认消息的处理,通过 channel.basicAck 方法
}
}
配置文件
application.yml
spring:
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
virtual-host: /
server:
port: 8093
依赖
<dependencies>
<dependency>
<groupId>com.leixin</groupId>
<artifactId>service_util</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
微服务项目使用RabbitMQ的更多相关文章
- SpringCloud(1)---基于RestTemplate微服务项目案例
基于RestTemplate微服务项目 在写SpringCloud搭建微服务之前,我想先搭建一个不通过springcloud只通过SpringBoot和Mybatis进行模块之间额通讯.然后在此基础上 ...
- Docker部署golang微服务项目
这篇博客是为了记录一下部署步骤. 因为实训需要,我要在服务器上用docker部署我们小组的微服务项目.我们的微服务有Gateway,User,Scene,Device四个部分,分别占用不同的端口,其中 ...
- 探索解析微服务下的RabbitMQ
概览 本文主要介绍如何使用RabbitMQ消息代理来实现分布式系统之间的通信,从而促进微服务的松耦合. RabbitMQ,也被称为开源消息代理,它支持多种消息协议,并且可以部署在分布式系统上.它轻量级 ...
- docker微服务部署之:三,搭建Zuul微服务项目
docker微服务部署之:二.搭建文章微服务项目 一.新增demo_eureka模块,并编写代码 右键demo_parent->new->Module->Maven,选择Module ...
- docker微服务部署之:二、搭建文章微服务项目
docker微服务部署之:一,搭建Eureka微服务项目 一.新增demo_article模块,并编写代码 右键demo_parent->new->Module->Maven,选择M ...
- docker微服务部署之:一,搭建Eureka微服务项目
先说明一下docker需要搭建的微服务的基本情况: 项目情况:一个demo_parent项目,下面三个子模块:demo_eureka(eureka服务).demo_article(文章服务).demo ...
- 【spring colud】spring cloud微服务项目搭建【spring boot2.0】
spring cloud微服务项目搭建 =================================== 示例版本: 1.spring boot 2.0版本 2.开发工具 IntellJ IDE ...
- Docker 搭建 ELK 读取微服务项目的日志文件
思路: 在docker搭建elasticsearch与kibana来展示日志,在微服务部署的机子上部署logstash来收集日志传到elasticsearch中,通过kibana来展示,logstas ...
- .Net Core 商城微服务项目系列(一):使用IdentityServer4构建基础登录验证
这里第一次搭建,所以IdentityServer端比较简单,后期再进行完善. 1.新建API项目MI.Service.Identity,NuGet引用IdentityServer4,添加类InMemo ...
- 毕业设计代做,各种系统微服务项目ssm项目,员工管理系统,微信小程序,购物商城,二手商城系统,销售系统,等等
毕业设计代做,各种系统,微服务项目,ssm项目 小程序,商城等,期末作业等都可以,价格好说,长期接单, 有项目说明书,软件介绍相关文档,答辩的时候包过,知识点对接好,给你讲解等, 毕业设计代做,各种系 ...
随机推荐
- vue中点击其他任意位置关闭弹框
mounted() { //点击任意位置关闭区域弹窗 document.addEventListener('click', (e) => { //获取弹窗对象 const userCon = d ...
- 2022-02-17:寻找最近的回文数。 给定一个表示整数的字符串 n ,返回与它最近的回文整数(不包括自身)。如果不止一个,返回较小的那个。 “最近的”定义为两个整数差的绝对值最小。 示例 1: 输
2022-02-17:寻找最近的回文数. 给定一个表示整数的字符串 n ,返回与它最近的回文整数(不包括自身).如果不止一个,返回较小的那个. "最近的"定义为两个整数差的绝对值最 ...
- 2021-06-12:已知一棵搜索二叉树上没有重复值的节点,现在有一个数组arr,是这棵搜索二叉树先序遍历的结果。请根据arr生成整棵树并返回头节点。
2021-06-12:已知一棵搜索二叉树上没有重复值的节点,现在有一个数组arr,是这棵搜索二叉树先序遍历的结果.请根据arr生成整棵树并返回头节点. 福大大 答案2021-06-12: 先序遍历+中 ...
- 记一次 .NET 某医院门诊软件 卡死分析
一:背景 1. 讲故事 前几天有位朋友找到我,说他们的软件在客户那边卡死了,让我帮忙看下是怎么回事?我就让朋友在程序卡死的时候通过 任务管理器 抓一个 dump 下来,虽然默认抓的是 wow64 ,不 ...
- 与世界分享我刚编的mysql http隧道工具-hersql原理与使用
原文地址:https://blog.fanscore.cn/a/53/ 1. 前言 本文是与世界分享我刚编的转发ntunnel_mysql.php的工具的后续,之前的实现有些拉胯,这次重构了下.需求背 ...
- PlayWright(一)
1.如何安装? 安装playwright只需要一条命令,就是pip安装命令,命令如下: pip install playwright 注:playwright需要Python3.7或更新的版本 2.然 ...
- Tomcat请求处理流程与源码浅析
系列文章目录和关于我 一丶Connector 在tomcat中,Connector负责开启socket并且监听客户端请求,返回响应数据. 其中: Endpoint:tomcat中没有这个接口,只有Ab ...
- es mysql 适用场景对比
es mysql 适用场景对比 问题一 全文检索毫无疑问直接上es,那么除了这种场景,什么时候该选es?为啥mysql不行? 对枚举字段的搜索 mysql创建索引的原则是对于那些区别度高字段建立索引, ...
- Java的运算符和表达式(基础语法学习)
一.运算符 在Java中用于程序计算的操作符统称为运算符,运算符分为如下几类 1.算数运算符 运算符 说明 + 加号两边是数值,可以运算,如果一边存在字符串,则当作连接符 a+b - 两个数相加, ...
- 开源 API 网关-访问策略(二)
在上篇文章API网关:开源 API 网关-访问策略(一) 中,我们简单演示了如何在IP维度中对请求路径设置黑白名单,以此来限制客户端请求的权限和范围. 此外,Apinto网关为客户端提供了一种统一的. ...