IBM WebSphere MQ8.0 发送和接收消息

本文使用springboot集成IBM MQ的客户端, 简单的实现消息接收和发送逻辑.

pom依赖

  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jms</artifactId>
  </dependency>

  <dependency>
    <groupId>javax.jms</groupId>
    <artifactId>javax.jms-api</artifactId>
  </dependency>

  <dependency>
    <groupId>com.ibm.mq</groupId>
    <artifactId>com.ibm.mq.allclient</artifactId>
    <version>9.0.4.0</version>
  </dependency>

配置文件

这里的配置和上文中创建的队列信息一致

server.port=9111
## mq的连接ip
project.mq.host=192.168.0.106
## mq的连接端口
project.mq.port=1414
## mq的队列管理器名字
project.mq.queue-manager=QM144
## mq的java客户端连接通道
project.mq.channel=SYSTEM_DEF_SVRCONN
## mq的用户名
project.mq.username=mqm
## mq的密码
project.mq.password=Paic2023q2
## mq的接收超时时间
project.mq.receive-timeout=20000
## 收发队列名称(可选)
project.mq.queuename=QUEUE1

配置类

@Configuration
public class JmsConfig {
    @Value("${project.mq.host}")
    private String host;
    @Value("${project.mq.port}")
    private Integer port;
    @Value("${project.mq.queue-manager}")
    private String queueManager;
    @Value("${project.mq.channel}")
    private String channel;
    @Value("${project.mq.username}")
    private String username;
    @Value("${project.mq.password}")
    private String password;
    @Value("${project.mq.receive-timeout}")
    private long receiveTimeout;
    @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;
    }
    @Bean
    UserCredentialsConnectionFactoryAdapter userCredentialsConnectionFactoryAdapter(MQQueueConnectionFactory mqQueueConnectionFactory) {
        UserCredentialsConnectionFactoryAdapter userCredentialsConnectionFactoryAdapter = new UserCredentialsConnectionFactoryAdapter();
        userCredentialsConnectionFactoryAdapter.setUsername(username);
        userCredentialsConnectionFactoryAdapter.setPassword(password);
        userCredentialsConnectionFactoryAdapter.setTargetConnectionFactory(mqQueueConnectionFactory);
        return userCredentialsConnectionFactoryAdapter;
    }
    @Bean
    @Primary
    public CachingConnectionFactory cachingConnectionFactory(UserCredentialsConnectionFactoryAdapter userCredentialsConnectionFactoryAdapter) {
        CachingConnectionFactory cachingConnectionFactory = new CachingConnectionFactory();
        cachingConnectionFactory.setTargetConnectionFactory(userCredentialsConnectionFactoryAdapter);
        cachingConnectionFactory.setSessionCacheSize(500);
        cachingConnectionFactory.setReconnectOnException(true);
        return cachingConnectionFactory;
    }
    @Bean
    public PlatformTransactionManager jmsTransactionManager(CachingConnectionFactory cachingConnectionFactory) {
        JmsTransactionManager jmsTransactionManager = new JmsTransactionManager();
        jmsTransactionManager.setConnectionFactory(cachingConnectionFactory);
        return jmsTransactionManager;
    }
    @Bean
    public JmsOperations jmsOperations(CachingConnectionFactory cachingConnectionFactory) {
        JmsTemplate jmsTemplate = new JmsTemplate(cachingConnectionFactory);
        jmsTemplate.setReceiveTimeout(receiveTimeout);
        return jmsTemplate;
    }
}

发送消息

    public void sendMq(@RequestParam String msg) {
        log.info("获得报文并开始向mq发送:"+msg);

        jmsTemplate.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
        jmsTemplate.setExplicitQosEnabled(true);
        jmsTemplate.send("QUEUE1", session -> {
            TextMessage m = session.createTextMessage();
            m.setText(msg);
            m.setJMSCorrelationID("1111");
            return m;
        });

//        Message message = jmsTemplate.receiveSelected("QUEUE1", "JMSCorrelationID='2222'");
//        System.err.println("---->" + message.toString());

        log.info("======推送mq报文完成======");
    }

接收消息

@Slf4j
@Component
public class MQListener extends MessageListenerAdapter {
    @Autowired
    JmsOperations jmsOperations;

    @Autowired
    private JmsTemplate jmsTemplate;

    @Override
    @JmsListener(destination = "${project.mq.queuename}", selector = "JMSCorrelationID='1111'")
    public void onMessage(Message message) {
        log.info("从MQ接收的message报文:"+message);


        jmsTemplate.send("QUEUE1", session -> {
            TextMessage m = session.createTextMessage();
            m.setText("return data");
            m.setJMSCorrelationID("2222");

            return m;
        });
    }

}

代码地址: https://gitee.com/sharloon/ibm-mq80-demo.git

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
WebSphere MQ 8.0是IBM推出的一款企业级消息中间件产品,其安装步骤如下: 1. 首先,确保你已经获得了WebSphere MQ 8.0的安装介质。这可以通过IBM官方网站下载或者从其他渠道获取。 2. 解压安装介质,并运行安装程序。可以通过双击运行安装程序的可执行文件来开始安装过程。 3. 在安装向导中,接受许可协议并选择安装类型。通常提供核心安装和扩展安装两种选项,核心安装包含基本的MQ功能,而扩展安装还包括其他组件和插件。 4. 选择安装目标位置,默认情况下,WebSphere MQ 8.0将被安装在C:\Program Files\IBM\WebSphere MQ目录下,你可以选择其他目录进行安装。这个目录将成为WebSphere MQ的根目录。 5. 指定MQ数据目录,这是用来存储MQ队列管理器、通道定义和其他MQ对象的位置。这是一个重要的选择,确保你有足够的磁盘空间来存储这些对象。默认情况下,数据目录位于根目录下的qmdata目录中。 6. 设置队列管理器名称,队列管理器是WebSphere MQ的核心组件,用来管理消息队列和消息传递。为队列管理器分配一个唯一的名称,并指定其运行在哪个服务器上。 7. 安装WebSphere MQ服务器,选择是否将MQ服务器作为Windows服务来运行。如果选择是,则需要指定MQ服务器的用户账户和密码。 8. 安装WebSphere MQ客户端程序,这些程序用来连接到MQ服务器并发送接收消息。 9. 监测和配置安装,你可以选择安装MQ监控工具和其他辅助程序,如Event and Error Logging Tool。 10. 完成安装,根据安装向导的提示完成安装过程,并在安装完成后重启系统。 总之,以上就是WebSphere MQ 8.0的详细安装步骤。在安装过程中,需要注意选择合适的安装选项、指定正确的安装目标位置和数据目录,以及配置好队列管理器等重要组件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值