Cluster环境中我们有多个server来处理业务,应用代码怎么来通过调用一个JNDI来向jms目标发生消息,
能比较均衡的发送到各个jmsServer的目标上.jmsServer配置和server是一对一的。这时候我们可以配置Distributed Queue 来分发消息。
不过有一种方法是不用Distributed Queue,就是代码直接调用jmsServer目标queue来发消息,然而jmsServer目标queue的jndi是唯一的,那么如果你cluster有8个server那么就得配8个目标queue,代码里也就要写8个目标queue的JNDI。这样就得不尝适。
用了Distributed Queue,配置一个Distributed Queue的JNDI即可。Distributed Queue可以加入多个Members,这些Member都是分别属于各个jmsServer的目标。
我这里配置的是2个server组成的cluster,这里从配置开始记录了测试过程。
还有两个测试发送和接受消息的程序QueueSend.java,QueueReceive.java
1.环境如下:
data:image/s3,"s3://crabby-images/39423/394231d15493ad3613cb21f4e52bb3e67beee6c8" alt="北京联动北方科技有限公司"
2.配置JMSStore
这里为了方便我建立的是FileStore,消息是以文件的方式存储。
建立JDBCStore作用是一样的,只是消息存贮在DB里。
3.配置JMS Server
data:image/s3,"s3://crabby-images/58c65/58c6512c2e3b2d9bde199af5ae82ca9e3a37b300" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/9cdce/9cdce86cd9168350b8107910053d47f401ef8d1f" alt="北京联动北方科技有限公司"
同样方法建立JMSServer-2.
4.配置JMS Modules
data:image/s3,"s3://crabby-images/ecf38/ecf38edd421785540d87d1e75a81b917fd70960a" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/a8b89/a8b899f2f56623fcc0578bed52ba3952c4ef58c7" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/1a464/1a464c541e3b4ba66076b645961c9873e1482e57" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/57650/57650e1543080393f006e13156d58db3cf525e27" alt="北京联动北方科技有限公司"
5.配置Connection Factory
data:image/s3,"s3://crabby-images/67de8/67de8e76d462350465eb3ec873315a8e39ffab54" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/d6efa/d6efaf46235331f1a237ce8e4f78ee329f24f2b0" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/2ed7f/2ed7f04d8676babe7015c93fab6fbdcbd6b76f92" alt="北京联动北方科技有限公司"
6.配置queue
data:image/s3,"s3://crabby-images/942d6/942d6db95fbd861dec81021ff5e7f972b2f79455" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/1ba77/1ba77dfd22a9486bec2d88a0ab586adcbf678ecb" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/20636/206365d53562349390c7d79499ecda8e2dd872e7" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/054d7/054d7a99118e50c3284984f058d8271a75105839" alt="北京联动北方科技有限公司"
这里一定要选择建一个Subdeployment,否则无法部署到jmsserver上。
data:image/s3,"s3://crabby-images/a62a2/a62a2e94d3d8f789cae62e8c99fdd6f3b5c7cb3a" alt="北京联动北方科技有限公司"
OK,Queue-1建好了,按照同样的步骤建Queue-2,部署到JMSServer-2.
7.配置Distributed Queue
data:image/s3,"s3://crabby-images/782b2/782b27296005a799deb65fb3737015145b6f522d" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/c9861/c98610c895e59b536e06486ad5c71953d81eff0c" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/1a1cf/1a1cf802c7129f01a817a0a791a66fc9971f75da" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/41e8e/41e8ead16a0c95907a83b415310c54b7d239aa6e" alt="北京联动北方科技有限公司"
点击 finish按钮,结束完成。
8.所有配置完成后,可以查看server上的JNDI确认自己配的是否正确。
data:image/s3,"s3://crabby-images/da7b3/da7b3f45172df052a3ebc15dd0000e18e63665c4" alt="北京联动北方科技有限公司"
点击“View JNDI Tree”,会打开新的窗口。
data:image/s3,"s3://crabby-images/3d31c/3d31c62a2235c8941c7f9f267d1f0e577d880d1e" alt="北京联动北方科技有限公司"
到这里我关于JMS的配置已经完成了,下面我们就可以测试了发消息了。
监控现在消息数,点击JMSServer -> Monitoring -> Active Destinations.
data:image/s3,"s3://crabby-images/8b1e3/8b1e384905f4601caa45198716d1f33ae0cf51be" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/d0e19/d0e192ff22e6a2bce8c3daa12ee39975d7364a5d" alt="北京联动北方科技有限公司"
现在的Message Current 都是0.
发送消息的代码配置如下:
data:image/s3,"s3://crabby-images/f3ec3/f3ec3e17fa3993aa24a219a1f17f6a49ce9792f4" alt="北京联动北方科技有限公司"
注意QUEUE写的是DistributedQueue的JNDI。执行发送消息,然后监控如下:发现消息都发送到了
JMSServer-1的queue中去了。
data:image/s3,"s3://crabby-images/7b6b6/7b6b61d3211df7badf4839c51439e427b3b9a567" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/03c65/03c651b39d4da1028c423286ea87806e63fe0351" alt="北京联动北方科技有限公司"
下面我把DistributedQueue-1成员中的Queue-1删掉,然后再发消息,再继续发消息,发现都发到
Queue2中去了。
data:image/s3,"s3://crabby-images/8afd8/8afd884c727705de6293b04c5a3a02abf9343ad1" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/57fcd/57fcdab9c747c010f8acfd69dab47bc28a28754f" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/60e62/60e62bdee5e8a1b6b47c16f18c117b4a127cd5f4" alt="北京联动北方科技有限公司"
data:image/s3,"s3://crabby-images/03437/0343719fddd951baa07460c42f4cc425c48d930a" alt="北京联动北方科技有限公司"
这就说明调用公共的DistributedQueue发送消息可以到cluster中任何一个JMSServer上的目标。读消息也是一样的,从DistributedQueue读消息可以读到任何一个JMSServer目标存贮的消息。