当前位置: 首页 > news >正文

SpringBoot 集成 JMS 与 IBMMQ 代码示例教程

文章目录

  • 前言
  • 一、集成 JMS 与 IBMMQ
    • 1、pom 依赖
    • 2、yml 配置
    • 3、Properties 配置类
    • 4、Factory 连接工厂类
    • 5、配置连接认证
    • 6、配置缓存连接工厂
    • 7、配置事务管理器
    • 8、配置JMS模板
    • 9、消息发送与接收
  • 总结


前言

SpringBoot 集成 IBMMQ,实现两个服务间的消息通信。


一、集成 JMS 与 IBMMQ

1、pom 依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-activemq</artifactId>
</dependency><dependency><groupId>javax.jms</groupId><artifactId>javax.jms-api</artifactId><version>2.0.1</version>
</dependency><dependency><groupId>com.ibm.mq</groupId><artifactId>com.ibm.mq.allclient</artifactId><version>9.1.1.0</version>
</dependency>

2、yml 配置

project:  mq:host: 192.168.1.180				# 服务地址port: 1416						# 服务端口queue-manager: queueManager		# 队列管理器username: username				# 用户名password: password				# 密码channel: channel     			# 连接通道receive-timeout: 2000     		# 连接超时

3、Properties 配置类

@Data
@Configuration
@ConfigurationProperties(prefix = "project.mq")
public class JmsConfig {/*** 服务地址*/private String host;/*** 服务端口*/private Integer port;/*** 队列管理器*/private String queueManager;/*** 用户名*/private String username;/*** 密码*/private String password;/*** 连接通道*/private String channel;/*** 连接超时*/private long receiveTimeout;
}

4、Factory 连接工厂类

@Bean
public MQQueueConnectionFactory mqQueueConnectionFactory() {MQQueueConnectionFactory mqQueueConnectionFactory = new MQQueueConnectionFactory();mqQueueConnectionFactory.setHostName(host);try {mqQueueConnectionFactory.setTransportType(WMQConstants.WMQ_CM_CLIENT);mqQueueConnectionFactory.setCCSID(1208);mqQueueConnectionFactory.setChannel(channel);mqQueueConnectionFactory.setPort(port);mqQueueConnectionFactory.setQueueManager(queueManager);} catch (Exception e) {e.printStackTrace();}return mqQueueConnectionFactory;
}

CCSID要与连接到的队列管理器一致,Windows下默认为1381,Linux下默认为1208。1208表示UTF-8字符集,建议把队列管理器的CCSID改为1208。

5、配置连接认证

@Bean
UserCredentialsConnectionFactoryAdapter userCredentialsConnectionFactoryAdapter(MQQueueConnectionFactory mqQueueConnectionFactory) {UserCredentialsConnectionFactoryAdapter userCredentialsConnectionFactoryAdapter = new UserCredentialsConnectionFactoryAdapter();userCredentialsConnectionFactoryAdapter.setUsername(username);userCredentialsConnectionFactoryAdapter.setPassword(password);userCredentialsConnectionFactoryAdapter.setTargetConnectionFactory(mqQueueConnectionFactory);return userCredentialsConnectionFactoryAdapter;
}

如不需要账户密码链接可以跳过此步,直接将mqQueueConnectionFactory注入下一步的缓存连接工厂。

6、配置缓存连接工厂

@Bean
@Primary
public CachingConnectionFactory cachingConnectionFactory(UserCredentialsConnectionFactoryAdapter userCredentialsConnectionFactoryAdapter) {CachingConnectionFactory cachingConnectionFactory = new CachingConnectionFactory();cachingConnectionFactory.setTargetConnectionFactory(userCredentialsConnectionFactoryAdapter);cachingConnectionFactory.setSessionCacheSize(500);cachingConnectionFactory.setReconnectOnException(true);return cachingConnectionFactory;
}

不配置该类则每次与MQ交互都需要重新创建连接,大幅降低速度。

7、配置事务管理器

@Bean
public PlatformTransactionManager jmsTransactionManager(CachingConnectionFactory cachingConnectionFactory) {JmsTransactionManager jmsTransactionManager = new JmsTransactionManager();jmsTransactionManager.setConnectionFactory(cachingConnectionFactory);return jmsTransactionManager;
}

8、配置JMS模板

@Bean
public JmsOperations jmsOperations(CachingConnectionFactory cachingConnectionFactory) {JmsTemplate jmsTemplate = new JmsTemplate(cachingConnectionFactory);jmsTemplate.setReceiveTimeout(receiveTimeout);return jmsTemplate;
}

JmsOperations为JmsTemplate的实现接口。

重要:不设置setReceiveTimeout时,当队列为空,从队列中取出消息的方法将会一直挂起直到队列内有消息

9、消息发送与接收

  1. 发送消息

可直接使用jmsOperations的convertAndSend(String, Object)方法,第一个参数为队列名称,第二个参数为需发送的对象。

重要:发送的对象需实现序列化接口

@Autowired
JmsOperations jmsOperations;public void send(User user){jmsOperations.convertAndSend("QUEUE.USER", user);
}
  1. 接收消息

可直接使用jmsOperations的receiveAndConvert(String)方法,第一个参数为队列名称。

@Autowired
JmsOperations jmsOperations;public void receive(User user){jmsOperations.receiveAndConvert("QUEUE.USER");
}
  1. 开启事务

如需使用事务,只需在方法添加注解@Transactional(value = “jmsTransactionManager”)即可。


总结

使用 SpringBoot JMS 集成 IBMMQ 十分的方便。

http://www.lryc.cn/news/194561.html

相关文章:

  • 大模型之Prompt研究和技巧
  • 掌握Golang匿名函数
  • HarmonyOS云开发基础认证---练习题二
  • ffmpeg视频解码器的配置选项含义
  • enter ubuntu boot option in virt-manager
  • 电商运营该如何做 AB 测试
  • go环境部署
  • HTTP/2 中的漏洞
  • 智能油烟机 优化烹饪体验
  • 啥?PS一秒成图?Adobe的逆天黑科技大公开
  • 扫描器(xray和bp联动)
  • [C++]:1.初识C++和C语言缺陷补充。
  • BUUCTF学习(三): PHP 代码审计
  • 推荐《Blue prison》
  • goland安装教程
  • java中okhttp和httpclient那个效率高
  • 内存占用问题
  • 代码随想录二刷 Day 34
  • 软件开源快速开发框架:降本增效,助力流程化办公!
  • Flink on k8s容器日志生成原理及与Yarn部署时的日志生成模式对比
  • AD20绘制电路板的外形
  • linux 设置开机启动
  • IDEA实现远程Debug调试
  • SpringBoot项目入门: IDEA 创建SpringBoot项目
  • Vue2+SpringBoot实现数据导出到csv文件并下载
  • NewStarCTF2023week2-base!(base低位隐写)
  • 众和策略:国际油价走高,石油板块强势拉升,通源石油、和顺石油等涨停
  • C++笔记之获取线程ID以及线程ID的用处
  • 机器人硬件在环仿真:解决实体开发与测试挑战,提升效率与安全性
  • stream()