学习MQ(三) 一个实例。

现在有两台机器A和B,分别安装了MQ6.0,我要通过MQ进行A和B之间的双向通信。

我打算分两步,第一步:实现A到B的数据传输。

在A上:

1、创建队列管理器 QM_1001。

2、创建本地队列 LQ_1001

3、创建传输队列 XQ_1001

4、创建远程队列 RQ_1002

5、创建发送方通道 1001.1002

在B上:

1、创建队列管理器 QM_1002

2、创建本地队列 LQ_1002

3、创建接收方通道 1001.1002,名字必须与发送方通道相同。

4、创建侦听器,监听1414端口

这样,A到B的数据传输就可以了。

启动队列管理器QM_1001和QM_1002,启动B上的侦听器,A上启动发送方通道1001.1002,B上的接收方通道也会自动运行;

第二步:实现B到A的数据传输

在B上:

1、创建传输队列 XQ_1002

2、创建远程队列 RQ_1001

3、创建发送方通道 1002.1001

在A上:

1、创建接收方通道1002.1001

2、创建侦听器,侦听1414端口

启动A上的侦听器,启动B上的发送方通道1002.1001,这样A上的接收方通道会自动运行。

这样,由B到A的数据传输也能进行了。

这是我搞定的第一个例子,也是我学习MQ以来感觉有进步的一次。

下面是脚本。

在A上:

* 定义队列管理器

crtmqm -t 5000 -h 1000 -lc -lf 10240 -lp 30 -ls 32 -q QM_1001

*更改QM的字符集编码(CCSID)

    ALTER QMGR FORCE CCSID(1381)

* 定义本地队列

    DEFINE QLOCAL('LQ_1001') REPLACE +

           USAGE(normal) +

    DEFPSIST(YES)

* 定义传输队列

    DEFINE QLOCAL('XQ_1001') REPLACE +

           USAGE(XMITQ) +

    DEFPSIST(YES) +

    TRIGGER +

    TRIGTYPE(FIRST) +

    INITQ('SYSTEM.CHANNEL.INITQ') +

    PROCESS('') +

    TRIGDATA('1001.1002')

* 定义远程队列

    DEFINE QREMOTE('RQ_1002') +

    DEFPSIST(YES) +

    RNAME('LQ_1002') +

    RQMNAME('QM_1002') +

    XMITQ('XQ_1001')

* 定义发送方通道

    DEFINE CHANNEL('1001.1002') +

    CHLTYPE(SDR) +

    TRPTYPE(TCP) +

    CONNAME('192.168.110.35(1414)') +

    XMITQ('XQ_1001') +

    DISCINT(0) + 

    SHORTTMR(30) +

    SHORTRTY(999999999) +

    LONGTMR(1200) +

           LONGRTY(999999999)

* 定义接收方通道

    DEFINE CHANNEL('1002.1001') +

    CHLTYPE(RCVR) +

    TRPTYPE(TCP)

* 启动队列管理器

strmqm QM_1001

* 启动侦听器

runmqlsr -m QM_1001 -t TCP -p 1414 &

在B上:

* 定义队列管理器

crtmqm -t 5000 -h 1000 -lc -lf 10240 -lp 30 -ls 32 -q QM_1002

*更改QM的字符集编码(CCSID)

    ALTER QMGR FORCE CCSID(1381)

* 定义本地队列

    DEFINE QLOCAL('LQ_1002') REPLACE +

           USAGE(normal) +

    DEFPSIST(YES)

* 定义传输队列

    DEFINE QLOCAL('XQ_1002') REPLACE +

           USAGE(XMITQ) +

    DEFPSIST(YES) +

    TRIGGER +

    TRIGTYPE(FIRST) +

    INITQ('SYSTEM.CHANNEL.INITQ') +

    PROCESS('') +

    TRIGDATA('1002.1001')

* 定义远程队列

    DEFINE QREMOTE('RQ_1001') +

    DEFPSIST(YES) +

    RNAME('LQ_1001') +

    RQMNAME('QM_1001') +

    XMITQ('XQ_1002')

* 定义发送方通道

    DEFINE CHANNEL('1002.1001') +

    CHLTYPE(SDR) +

    TRPTYPE(TCP) +

    CONNAME('192.168.110.21(1414)') +

    XMITQ('XQ_1002') +

    DISCINT(0) + 

    SHORTTMR(30) +

    SHORTRTY(999999999) +

    LONGTMR(1200) +

           LONGRTY(999999999)

* 定义接收方通道

    DEFINE CHANNEL('1001.1002') +

    CHLTYPE(RCVR) +

    TRPTYPE(TCP)

* 启动队列管理器

strmqm QM_1002

* 启动侦听器

runmqlsr -m QM_1002 -t TCP -p 1414 &

剩下几个疑问没有明白

1、更改QM的字符集编码是做什么用的?

2、从资料上看到有个服务器传输通道,不知道是做什么用的?

学习MQ(三) 一个实例的更多相关文章

  1. tensorflow学习笔记三:实例数据下载与读取

    一.mnist数据 深度学习的入门实例,一般就是mnist手写数字分类识别,因此我们应该先下载这个数据集. tensorflow提供一个input_data.py文件,专门用于下载mnist数据,我们 ...

  2. rabbit mq的一个实例,异步功能

    简单的使用场景:消息队列的场景有:解耦,异步,削峰. 此例用的场景,异步 有时候会有请求消耗时间过长,不能老让用户等待返回结果,可以用消息队列来做异步实现,之前用过workmain等类似的异步,但不如 ...

  3. 逆向学习XXclient怎样仅仅执行一个实例

    个人觉得学习分两种, 一种是当面请教和直接从书本网络中的资料学习. 其二就是看着令你惊叹的作品-顿悟. 什么?顿悟不了?那我们就一起来逆向学习吧!差点忘了,我并不打算提供Demo,这并不重要,难道你打 ...

  4. 让程序只运行一个实例(Delphi篇)(三种方法,其中使用全局原子的方法比较有意思)

    Windows 下一个典型的特征就是多任务,我们可以同时打开多个窗口进行操作,也可以同时运行程序的多个实例,比如可以打开许多个资源管理器进行文件的移动复制操作.但有时出于某种考虑(比如安全性),我们要 ...

  5. JavaWeb学习之三层架构实例(三)

    引言 通过上一篇博客JavaWeb学习之三层架构实例(二)我们基本上已经实现了对学生信息列表的增删改查操作(UI除外),但是不难看出,代码冗余度太高了,尤其是StudentDao这个类,其中的增删改查 ...

  6. LINUX内核分析第三周学习总结——构造一个简单的Linux系统MenuOS

    LINUX内核分析第三周学习总结——构造一个简单的Linux系统MenuOS 张忻(原创作品转载请注明出处) <Linux内核分析>MOOC课程http://mooc.study.163. ...

  7. Linux第三周学习总结——构造一个简单的Linux系统MenuOS

    第三周学习总结--构造一个简单的Linux系统MenuOS 作者:刘浩晨 [原创作品转载请注明出处] <Linux内核分析>MOOC课程http://mooc.study.163.com/ ...

  8. [学习笔记]一个实例理解Lingo的灵敏性分析

    一个实例理解Lingo的灵敏性分析     线性规划问题的三个重要概念:    最优解就是反应取得最优值的决策变量所对应的向量.    最优基就是最优单纯形表的基本变量所对应的系数矩阵如果其行列式是非 ...

  9. ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心

    作者:Grey 原文地址:ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 很多程序往 ...

随机推荐

  1. Android开发学习之路--Android系统架构初探

    环境搭建好了,最简单的app也运行过了,那么app到底是怎么运行在手机上的,手机又到底怎么能运行这些应用,一堆的电子元器件最后可以运行这么美妙的界面,在此还是需要好好研究研究.这里从芯片及硬件模块-& ...

  2. Android程序崩溃异常收集框架

    最近在写Android程序崩溃异常处理,完成之后,稍加封装与大家分享. 我的思路是这样的,在程序崩溃之后,将异常信息保存到一个日志文件中,然后对该文件进行处理,比如发送到邮箱,或发送到服务器. 所以, ...

  3. Activity绑定自定义视图

    在安卓工程中,我们通过创建可以自动生成on_Create方法,这里面有个: setContentView(R.layout.activity_main);是系统自带的一个布局文件,但是在开发的过程中, ...

  4. General Ledger Useful SQL Scripts

    General Ledger Useful SQL Scripts – Oracle Applications 11i Contents GL Set of Books Configuration O ...

  5. 网站开发进阶(三十七)JSP页面跳转问题解决

    JSP页面跳转问题解决 PS:本篇博文质量欠佳,仅供个人学习之用. 前言 在做Web开发时,对别人的应用(jsp+servlet)进行服务器部署时出现了页面跳转无效的情况.但是项目在本地未出现此状况. ...

  6. 我眼中的Linux设备树(三 属性)

    三 属性(property)device_type = "memory"就是一个属性,等号前边是属性,后边是值.节点是一个逻辑上相对独立的实体,属性是用来描述节点特性的,根据需要一 ...

  7. ROS(indigo)_turtlebot仿真示例包括stage和gazebo

    ROS(indigo)_turtlebot仿真示例包括stage和gazebo 现上参考网址: turtlebot:http://wiki.ros.org/Robots/TurtleBot stage ...

  8. ZooKeeper实现命名服务

    使用场景  命名服务就是提供名称的服务,Zookeeper的命名服务有两个应用方面.一个是提供类似JNDI功能,另一个是制作分布式的序列号生成器.         JNDI功能,我们利用Zookeep ...

  9. 【算法导论】图的广度优先搜索遍历(BFS)

    图的存储方法:邻接矩阵.邻接表 例如:有一个图如下所示(该图也作为程序的实例): 则上图用邻接矩阵可以表示为: 用邻接表可以表示如下: 邻接矩阵可以很容易的用二维数组表示,下面主要看看怎样构成邻接表: ...

  10. 使用Gradle发布Android开源项目到JCenter

    喜欢做些开源项目的朋友,相信有不少人都希望能把自己的项目发布到公共的中央仓库,如maven中央仓库,以供别人方便地集成使用.而使用了Android Studio的同学,应该也对gradle和jcent ...