有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...