SpringBoot 连接 ibm mq

有2中方式操作ibm mq,第一种是IBM MQ Explorer(界面),第二种是MQSC(命令行)
我这里使用MQSC

在mq服务端操作

创建队列管理器
crtmqm -q ECIS_QM
其中ECIS_QM是队列管理器的名称

启动队列管理器
strmqm ECIS_QM

运行队列管理器
runmqsc ECIS_QM

创建监听
DEFINE LISTENER(LSR_4_ECIS_QM)TRPTYPE(TCP) PORT(8930) CONTROL(QMGR) REPLACE
其中LSR_4_ECIS_QM是监听名称
8930是端口号

启动监听
START LISTENER(LSR_4_ECIS_QM)

创建本地队列
DEFINE QLOCAL(QLOCAL_SVC2ADP_4_TELNET) REPLACE
QLOCAL_SVC2ADP_4_TELNET为本地队列名称

创建服务器连接通道
DEFINE CHANNEL(ECIS.SVRCONN) CHLTYPE(SVRCONN) MCAUSER(‘mqm’)
REPLACE ECIS.SVRCONN为通道名称

到此服务端的mq需要用到的元素设置完毕
接下来是客户端(springboot)

application.properties
#服务ip
project.mq.host=172.1.8.35
#端口
project.mq.port=8930
#(队列管理器名称)
project.mq.queue-manager=ECIS_QM
#(通道名称)
project.mq.channel=ECIS.SVRCONN
#创建的MQ用户
project.mq.username=mqm
#创建的MQ用户连接密码
project.mq.password=mqm
#超时时间
project.mq.receive-timeout=10000

maven依赖(我这里使用的mq的版本是9.1.0.0,附上查版本号的命令dspmqver)

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

接下来是配置

package com.mqdemo.demo.config;

import com.ibm.mq.jms.MQQueueConnectionFactory;
import com.ibm.msg.client.wmq.WMQConstants;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.jms.connection.CachingConnectionFactory;
import org.springframework.jms.connection.JmsTransactionManager;
import org.springframework.jms.connection.UserCredentialsConnectionFactoryAdapter;
import org.springframework.jms.core.JmsOperations;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.transaction.PlatformTransactionManager;

@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;

    /**
     * mq连接工厂
     * @return
     */
    @Bean
    public MQQueueConnectionFactory mqQueueConnectionFactory() {
        MQQueueConnectionFactory mqQueueConnectionFactory = new MQQueueConnectionFactory();
        mqQueueConnectionFactory.setHostName(host);
        try {
        qQueueConnectionFactory.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;
    }
}

测试发送和接收
发送方

package com.mqdemo.demo.config;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsOperations;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;

@Component
public class SendMessage {
    @Autowired
    JmsOperations jmsOperations;

    //@PostConstruct在服务器加载Servle的时候运行,并且只会被服务器执行一次, @PreDestroy在destroy()方法执行执行之后执行
    @PostConstruct
    public void send(){
        jmsOperations.convertAndSend("QLOCAL_SVC2ADP_4_TELNET", "my message...");
        System.out.println("开始发送消息");
    }
}

接收方

package com.mqdemo.demo.config;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.annotation.JmsListener;
import org.springframework.jms.core.JmsOperations;
import org.springframework.jms.listener.adapter.MessageListenerAdapter;
import org.springframework.stereotype.Component;

import javax.jms.Message;

@Component
public class ReceiveMessage extends MessageListenerAdapter {
    @Autowired
    JmsOperations jmsOperations;

    @Override
    @JmsListener(destination = "QLOCAL_SVC2ADP_4_TELNET")
    public void onMessage(Message message) {
        String messageBody = new String(message.toString());
        System.out.println("成功监听QLOCAL_SVC2ADP_4_TELNET消息队列,传来的值为:" + messageBody);
    }
}

执行结果

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.0.5.RELEASE)

2018-10-16 14:02:16.611  INFO 13140 --- [           main] com.mqdemo.demo.DemoApplication          : Starting DemoApplication on DESKTOP-BBN0508 with PID 13140 (D:\mq-demo\target\classes started by Zhao in D:\mq-demo)
2018-10-16 14:02:16.615  INFO 13140 --- [           main] com.mqdemo.demo.DemoApplication          : No active profile set, falling back to default profiles: default
2018-10-16 14:02:16.688  INFO 13140 --- [           main] ConfigServletWebServerApplicationContext : Refreshing org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@2fd6b6c7: startup date [Tue Oct 16 14:02:16 CST 2018]; root of context hierarchy
2018-10-16 14:02:18.228  INFO 13140 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8080 (http)
2018-10-16 14:02:18.250  INFO 13140 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2018-10-16 14:02:18.250  INFO 13140 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/8.5.34
2018-10-16 14:02:18.254  INFO 13140 --- [ost-startStop-1] o.a.catalina.core.AprLifecycleListener   : The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: [D:\Java\jdk1.8.0_171\bin;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\Program Files (x86)\Common Files\Oracle\Java\javapath;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\;E:\TortoiseSVN\bin;D:\apache-maven-3.5.3\bin\;d:\erl10.0\bin\;D:\RabbitMQServer\rabbitmq_server-3.7.0\sbin;C:\WINDOWS\System32\OpenSSH\;D:\nodejs\;D:\Java\jdk1.8.0_171\bin\;D:\Java\jdk1.8.0_171\lib\;d:\Git\cmd;d:\instantclient_11_2;C:\Users\Zhao\AppData\Local\Microsoft\WindowsApps;C:\Users\Zhao\AppData\Roaming\npm;.]
2018-10-16 14:02:18.366  INFO 13140 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2018-10-16 14:02:18.367  INFO 13140 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 1683 ms
2018-10-16 14:02:18.428  INFO 13140 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean  : Servlet dispatcherServlet mapped to [/]
2018-10-16 14:02:18.432  INFO 13140 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'characterEncodingFilter' to: [/*]
2018-10-16 14:02:18.433  INFO 13140 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
2018-10-16 14:02:18.433  INFO 13140 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'httpPutFormContentFilter' to: [/*]
2018-10-16 14:02:18.433  INFO 13140 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'requestContextFilter' to: [/*]
2018-10-16 14:02:18.971  INFO 13140 --- [           main] o.s.j.c.CachingConnectionFactory         : Established shared JMS Connection: com.ibm.mq.jms.MQQueueConnection@1a1d3c1a
开始发送消息
2018-10-16 14:02:19.240  INFO 13140 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-10-16 14:02:19.508  INFO 13140 --- [           main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@2fd6b6c7: startup date [Tue Oct 16 14:02:16 CST 2018]; root of context hierarchy
2018-10-16 14:02:19.558  INFO 13140 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2018-10-16 14:02:19.559  INFO 13140 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)
2018-10-16 14:02:19.582  INFO 13140 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-10-16 14:02:19.582  INFO 13140 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-10-16 14:02:19.784  INFO 13140 --- [           main] o.s.j.e.a.AnnotationMBeanExporter        : Registering beans for JMX exposure on startup
2018-10-16 14:02:19.805  INFO 13140 --- [           main] o.s.c.support.DefaultLifecycleProcessor  : Starting beans in phase 2147483647
2018-10-16 14:02:19.841  INFO 13140 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''
2018-10-16 14:02:19.846  INFO 13140 --- [           main] com.mqdemo.demo.DemoApplication          : Started DemoApplication in 3.731 seconds (JVM running for 4.888)
成功监听QLOCAL_SVC2ADP_4_TELNET消息队列,传来的值为:
  JMSMessage class: jms_text
  JMSType:          null
  JMSDeliveryMode:  2
  JMSDeliveryDelay: 0
  JMSDeliveryTime:  0
  JMSExpiration:    0
  JMSPriority:      4
  JMSMessageID:     ID:414d5120454349535f514d2020202020707ac55b0689d423
  JMSTimestamp:     1539669739131
  JMSCorrelationID: null
  JMSDestination:   queue:///QLOCAL_SVC2ADP_4_TELNET
  JMSReplyTo:       null
  JMSRedelivered:   false
    JMSXAppID: mqdemo.demo.DemoApplication 
    JMSXDeliveryCount: 1
    JMSXUserID: mqm         
    JMS_IBM_Character_Set: UTF-8
    JMS_IBM_Encoding: 273
    JMS_IBM_Format: MQSTR   
    JMS_IBM_MsgType: 8
    JMS_IBM_PutApplType: 28
    JMS_IBM_PutDate: 20181016
    JMS_IBM_PutTime: 06030798
my message...
  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值