以下是一个基于 Spring Cloud 和 RabbitMQ 的简单 “Hello World“ 示例,展示如何在 Spring Boot 应用中发送和接收消息

项目结构

本示例包含两个模块:

  1. RabbitMQ 生产者:发送消息到 RabbitMQ。
  2. RabbitMQ 消费者:从 RabbitMQ 接收消息。

1. 添加依赖

pom.xml 文件中添加 Spring Boot 和 RabbitMQ 的依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-amqp</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>

2. 配置 RabbitMQ

application.yml 文件中配置 RabbitMQ 的连接信息:

spring:
  rabbitmq:
    host: localhost
    port: 5672
    username: guest
    password: guest
    virtual-host: /

3. 生产者代码

创建一个简单的生产者,通过 HTTP 接口发送消息到 RabbitMQ。

3.1 生产者配置
@Configuration
public class RabbitConfig {
    public static final String QUEUE_NAME = "hello_queue";

    @Bean
    public Queue helloQueue() {
        return new Queue(QUEUE_NAME, true);
    }
}
3.2 生产者控制器
@RestController
public class RabbitController {
    @Autowired
    private RabbitTemplate rabbitTemplate;

    @GetMapping("/send")
    public String sendMessage(@RequestParam String message) {
        rabbitTemplate.convertAndSend(RabbitConfig.QUEUE_NAME, message);
        return "Message sent: " + message;
    }
}
3.3 生产者主类
@SpringBootApplication
public class RabbitProducerApplication {
    public static void main(String[] args) {
        SpringApplication.run(RabbitProducerApplication.class, args);
    }
}

4. 消费者代码

创建一个简单的消费者,从 RabbitMQ 接收消息。

4.1 消费者配置
@Configuration
public class RabbitConfig {
    public static final String QUEUE_NAME = "hello_queue";

    @Bean
    public Queue helloQueue() {
        return new Queue(QUEUE_NAME, true);
    }
}
4.2 消费者监听器
@Component
public class RabbitListener {
    @RabbitListener(queues = RabbitConfig.QUEUE_NAME)
    public void receiveMessage(String message) {
        System.out.println("Received message: " + message);
    }
}
4.3 消费者主类
@SpringBootApplication
public class RabbitConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(RabbitConsumerApplication.class, args);
    }
}

5. 测试

  1. 启动 RabbitMQ 服务。
  2. 启动生产者和消费者应用。
  3. 访问生产者的 HTTP 接口:
    http://localhost:8080/send?message=HelloRabbitMQ
    
  4. 消费者控制台将打印接收到的消息:
    Received message: HelloRabbitMQ
    

6. 总结

通过以上步骤,你可以在 Spring Boot 应用中快速集成 RabbitMQ,实现消息的发送和接收。这个简单的 “Hello World” 示例展示了 Spring Cloud 和 RabbitMQ 的基本用法,适合初学者入门。

  1. Queue:队列。计算机数据结构中的一种基本类型,遵循“先入先出”(FIFO)的原则,比如我们日常生活中常见的排队时的队伍就是一个队列。
  2. Message
    Queue:消息队列,简称MQ。消息队列本质上也是队列,只不过队列中的元素为Message(消息),而消息则是服务之间最常见的通信方式。流行的MQ框架主要有RabbitMq、ActiveMq、ZeroMq、kafka,以及阿里开源的RocketMQ。
  3. AMQP:Advanced Message Queuing
    Protocol,是一个提供统一消息服务的应用层标准高级消息队列协议,简单来说,它就是一个消息列队的协议,其标准高,要求严。
  4. Erlang:Erlang是一种通用的面向并发的编程语言,它由瑞典电信设备制造商爱立信所辖的CS-Lab开发,目的是创造一种可以应对大规模并发活动的编程语言和运行环境。
  5. RabbitMQ:RabbitMQ是一个实现了AMQP高级消息队列协议的消息队列服务,用Erlang语言实现。

在这里插入图片描述

package com.didispace;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class HelloApplication {

	public static void main(String[] args) {
		SpringApplication.run(HelloApplication.class, args);
	}

}

package com.didispace.rabbit;

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


@Configuration
public class RabbitConfig {

    @Bean
    public Queue helloQueue() {
        return new Queue("hello");
    }

}

package com.didispace.rabbit;

import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Component;

import java.util.Date;


@Component
@RabbitListener(queues = "hello")
public class Receiver {

    @RabbitHandler
    public void process(String hello) {
        System.out.println("Receiver : " + hello);
    }

}

package com.didispace.rabbit;

import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.util.Date;

@Component
public class Sender {

	@Autowired
	private AmqpTemplate rabbitTemplate;

	public void send() {
		String context = "hello " + new Date();
		System.out.println("Sender : " + context);
		this.rabbitTemplate.convertAndSend("hello", context);
	}

}
spring.application.name=rabbitmq-hello

spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=springcloud
spring.rabbitmq.password=123456

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.didispace</groupId>
	<artifactId>rabbitmq-hello</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>rabbitmq-hello</name>
	<description>Demo project for Spring Boot</description>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.3.7.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
		<java.version>1.8</java.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-amqp</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>
	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>
</project>

### 回答1: 我可以为您写一个Spring Cloud应用程序中的MQ消息发送示例: connectionFactory.createConnection(); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); Destination destination = session.createQueue("myQueue"); MessageProducer producer = session.createProducer(destination); TextMessage message = session.createTextMessage("Hello World"); producer.send(message); ### 回答2: MQ(消息队列)是一种常用的消息通信模式,在分布式系统中用于解耦应用间的通信,提高系统的稳定性可扩展性。Spring Cloud一个开源的分布式系统开发框架,提供了轻量级微服务架构的解决方案。 要将一个MQ消息发送Spring Cloud,可以按照以下步骤进行: 1. 配置MQ:在Spring Cloud中使用MQ之前,首先需要配置MQ服务器。可以选择使用常见的MQ实现,如RabbitMQ、Kafka等。根据MQ提供的文档,安装并设置相应的配置信息,如服务器地址、端口号、用户名、密码等。 2. 引入MQ依赖:借助Spring BootSpring Cloud的依赖管理功能,可以方便地引入MQ相关的依赖。 3. 创建消息生产者:在Spring Cloud中,可以使用Spring Integration集成MQ,通过配置使用消息通道(Message Channel)来发送消息。根据具体的业务需求,创建一个消息生产者,负责将待发送消息封装成MQ消息,并发送到指定的MQ服务器。 4. 配置消息通道:通过Spring Boot的自动配置,只需在应用的配置文件中指定MQ相关的配置信息,如服务器地址、端口号、用户名、密码等,Spring Cloud会自动根据配置创建消息通道,连接到相应的MQ服务器。 5. 发送消息:在代码中,通过注入消息通道的方式获取消息通道的引用。然后,将封装好的MQ消息发送消息通道中,即可发送给MQ服务器。 6. 监听消息:在Spring Cloud中,可以使用消息监听器(Message Listener)来监听MQ服务器上的消息。通过配置使用消息监听器,可以使应用实时获取MQ服务器上的消息,并进行相应的处理。 通过以上步骤,可以实现将一个MQ消息发送Spring Cloud。这样,消息就可以在分布式系统中进行传递处理,以达到解耦应用的目的。同时,Spring Cloud提供的一系列功能,如负载均衡、熔断、服务发现等,可以帮助开发者构建高可用的分布式系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Bol5261

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值