SpringBoot 集成 RabbitMQ
首先搭建SpringBoot项目,在POM XML文件中添加如下依赖
<依赖> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-amqp</artifactid></依赖><依赖> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid></依赖>
修改配置文件,添加如下RabbitMQ配置
服务器: port: 8888 # 设置端口号Spring: rabbitMQ: host: 127.0.0.1 # 设置 RabbitMQ 的主机 port: 5672 # 设置 RabbitMQ 服务端口 username: guest # 设置 RabbitMQ 用户名 password: guest # 设置 RabbitMQ 密码
新的公共常量类
public interface RabbitConstant { /** * 简单模式 */ String SIMPLE_QUEUE_NAME = "simple_queue"; /** * 工作模式 */ String WORK_QUEUE_NAME = "work_queue"; /** * 发布/订阅模式 */ String PUBLISH_SUBSCRIBE_EXCHANGE_NAME = "publish_subscribe_exchange"; 字符串 PUBLISH_SUBSCRIBE_FIRST_QUEUE_NAME = "publish_subscribe_first_queue"; 字符串 PUBLISH_SUBSCRIBE_SECOND_QUEUE_NAME = "publish_subscribe_second_queue"; /** * 路由模式 */ String ROUTING_EXCHANGE_NAME = "routing_exchange"; 字符串 ROUTING_FIRST_QUEUE_NAME = "routing_first_queue"; 字符串 ROUTING_SECOND_QUEUE_NAME = "routing_second_queue"; 字符串 ROUTING_THIRD_QUEUE_NAME = "routing_third_queue"; 字符串 ROUTING_FIRST_QUEUE_ROUTING_KEY_NAME = "routing_first_queue_routing_key"; 字符串 ROUTING_SECOND_QUEUE_ROUTING_KEY_NAME = "routing_second_queue_routing_key"; 字符串 ROUTING_THIRD_QUEUE_ROUTING_KEY_NAME = "routing_third_queue_routing_key"; /** * 主题模式 */ String TOPICS_EXCHANGE_NAME = "topics_exchange"; 字符串 TOPICS_FIRST_QUEUE_NAME = "topics_first_queue"; 字符串 TOPICS_SECOND_QUEUE_NAME = " 字符串 TOPICS_THIRD_QUEUE_NAME = "topics_third_queue"; String TOPICS_FIRST_QUEUE_ROUTING_KEY = "topics.first.routing.key"; String TOPICS_SECOND_QUEUE_ROUTING_KEY = "topics.second.routing.key"; String TOPICS_THIRD_QUEUE_ROUTING_KEY = "topics.third.routing.key"; 字符串 TOPICS_ROUTING_KEY_FIRST_WILDCARD = "#.first.#"; 字符串 TOPICS_ROUTING_KEY_SECOND_WILDCARD = "*.second.#"; 字符串 TOPICS_ROUTING_KEY_THRID_WILDCARD = "*.third.*"; /** * 标题模式 */ String HEADER_EXCHANGE_NAME = "header_exchange"; 字符串 HEADER_FIRST_QUEUE_NAME = "header_first_queue"; 字符串 HEADER_SECOND_QUEUE_NAME = "header_second_queue"; /** * rpc 模式 */ String RPC_QUEUE_NAME = "rpc_queue"; }
添加一个Controller请求类(用于验证结果,最后可以添加)
导入 com.example.rabbitmq.constant.RabbitConstant; 导入 org.springframework.amqp.core.Message; 导入 org.springframework.amqp.core.MessageProperties; 导入 org.springframework.amqp.rabbit.core.RabbitTemplate; 导入 org.springframework.beans.factory.annotation.Autowired; 导入 org.springframework.web.bind.annotation.GetMapping; 导入 org.springframework.web.bind.annotation.RestController; 导入 java.nio.charset.StandardCharsets;@RestController public class RabbitController { @Autowired private RabbitTemplate rabbitTemplate; @GetMapping(value = "/simple") public void simple() { rabbitTemplate.convertAndSend(RabbitConstant.SIMPLE_QUEUE_NAME, "你好世界!"); } @GetMapping(value = "/work") public void work() { rabbitTemplate.convertAndSend(RabbitConstant.WORK_QUEUE_NAME, "work hello!"); } @GetMapping(value = "/pubsub") public void pubsub() { rabbitTemplate.convertAndSend(RabbitConstant.PUBLISH_SUBSCRIBE_EXCHANGE_NAME, null, "发布/订阅你好"); } @GetMapping(value = "/routing") public void routing() { // 向第一个队列发送消息 rabbitTemplate.convertAndSend(RabbitConstant.ROUTING_EXCHANGE_NAME, RabbitConstant.ROUTING_FIRST_QUEUE_ROUTING_KEY_NAME, "路由你好"); } @GetMapping(value = "/topics") public void topics() { // 向第一个队列发送消息。这时候队列可以接收到消息,因为队列的通配符是#first.#,而routing_key是topics first。路由。键,匹配成功 rabbitTemplate.convertAndSend(RabbitConstant.TOPICS_EXCHANGE_NAME, RabbitConstant.TOPICS_FIRST_QUEUE_ROUTING_KEY, "topics hello"); // 向第二个队列发送消息。这时候队列也能收到消息了,因为队列的通配符是*秒#,而routing_key是topic秒。路由。键,匹配成功 rabbitTemplate.convertAndSend(RabbitConstant.TOPICS_EXCHANGE_NAME, RabbitConstant.TOPICS_SECOND_QUEUE_ROUTING_KEY, "topics hello"); // 向第三个队列发送消息。此时队列无法接受消息,因为队列通配符是*第三个*,而routing_key是topics第三个。路由。键,匹配失败 rabbitTemplate.convertAndSend(RabbitConstant.TOPICS_EXCHANGE_NAME, RabbitConstant.TOPICS_THIRD_QUEUE_ROUTING_KEY, "topics hello"); } @GetMapping(value = "/header") public void header() { // 这个消息应该被两个队列接收。第一个队列全部匹配成功,第二个队列 Hello 值任意匹配成功 MessageProperties messageProperties = new MessageProperties(); messageProperties.setHeader("matchAll", "YES"); messageProperties.setHeader("你好", "world"); Message message = new Message("header first hello".getBytes(StandardCharsets.UTF_8), messageProperties); rabbitTemplate.convertAndSend(RabbitConstant.HEADER_EXCHANGE_NAME, null, message); // 这个消息应该只被第二个队列接受。第一个队列全部匹配失败, MessageProperties messagePropertiesSecond = new MessageProperties(); messagePropertiesSecond.setHeader("matchAll", "NO"); Message messageSecond = new Message("header second hello".getBytes(StandardCharsets.UTF_8), messagePropertiesSecond); rabbitTemplate.convertAndSend(RabbitConstant.HEADER_EXCHANGE_NAME, null, messageSecond); } @GetMapping(value = "/rpc") public void rpc() { Object responseMsg = rabbitTemplate.convertSendAndReceive(RabbitConstant.RPC_QUEUE_NAME, "rpc hello!"); System.out.println("rabbit rpc 响应消息:" + responseMsg); } }
以上是SpringBoot怎么集成RabbitMQ的详细内容。更多信息请关注PHP中文网其他相关文章!

JavadevelovermentIrelyPlatForm-DeTueTososeVeralFactors.1)JVMVariationsAffectPerformanceNandBehaviorAcroSsdifferentos.2)Nativelibrariesviajnijniiniininiinniinindrododerplatefform.3)

Java代码在不同平台上运行时会有性能差异。1)JVM的实现和优化策略不同,如OracleJDK和OpenJDK。2)操作系统的特性,如内存管理和线程调度,也会影响性能。3)可以通过选择合适的JVM、调整JVM参数和代码优化来提升性能。

Java'splatFormentenceHaslimitations不包括PerformanceOverhead,versionCompatibilityIsissues,挑战WithnativelibraryIntegration,Platform-SpecificFeatures,andjvminstallation/jvminstallation/jvmintenance/jeartenance.therefactorscomplicatorscomplicatethe“ writeOnce”

PlatformIndependendecealLowsProgramStormonanyPlograwsStormanyPlatFormWithOutModification,而LileCross-PlatFormDevelopmentRequiredquiresMomePlatform-specificAdjustments.platFormIndependence,EneblesuniveByjava,EnablesuniversUniversAleversalexecutionbutmayCotutionButMayComproMisePerformance.cross.cross.cross-platformd

JITcompilationinJavaenhancesperformancewhilemaintainingplatformindependence.1)Itdynamicallytranslatesbytecodeintonativemachinecodeatruntime,optimizingfrequentlyusedcode.2)TheJVMremainsplatform-independent,allowingthesameJavaapplicationtorunondifferen

javaispopularforcross-platformdesktopapplicationsduetoits“ writeonce,runanywhere”哲学。1)itusesbytbytybytecebytecodethatrunsonanyjvm-platform.2)librarieslikeslikeslikeswingingandjavafxhelpcreatenative-lookingenative-lookinguisis.3)

在Java中编写平台特定代码的原因包括访问特定操作系统功能、与特定硬件交互和优化性能。1)使用JNA或JNI访问Windows注册表;2)通过JNI与Linux特定硬件驱动程序交互;3)通过JNI使用Metal优化macOS上的游戏性能。尽管如此,编写平台特定代码会影响代码的可移植性、增加复杂性、可能带来性能开销和安全风险。

Java将通过云原生应用、多平台部署和跨语言互操作进一步提升平台独立性。1)云原生应用将使用GraalVM和Quarkus提升启动速度。2)Java将扩展到嵌入式设备、移动设备和量子计算机。3)通过GraalVM,Java将与Python、JavaScript等语言无缝集成,增强跨语言互操作性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

Atom编辑器mac版下载
最流行的的开源编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6
视觉化网页开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。