百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

「Weblogic学习」Weblogic知识要点之JMS发布与订阅实例演示

yuyutoo 2024-11-27 22:56 2 浏览 0 评论

互联网的时代,喜欢她就关注她,然后我们就能收到她的动态。你想知道这是什么原理,怎么实现的吗?JMS订阅与发布功能就能揭开这层神秘的面纱,一起看看吧……

每一个消息可以有多个消费者。

向某个话题订阅的客户程序只能收到那些在它订阅之后发布的消息。为了接收到消息, 订阅者必须保持活动状态。因此,发布者和订阅者之间存在时间上的依赖关系。JMS API在一定程度上放宽了对这种依赖关系的要求,允许创建持久性订阅(Durable Subscription)。有了持久性订阅,当订阅者不活动时发送的消息也能接收到。

下面的实例是非持久性订阅:

① Commons.java 公有类

② TopicProducer.java 主题发布类

package com.lession.day1024.topic;
import java.util.Date;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicPublisher;
import javax.jms.TopicSession;
import javax.naming.Context;
import com.lession.day1024.Commons;
public class TopicProducer
{
private TextMessage msg;
private TopicPublisher producer;
//private MessageProducer producer;
public TopicProducer() throws Exception
{
this("topic");
}
public TopicProducer(String jndiName)
throws Exception
{
Context context = Commons.getInitialContext();
TopicConnectionFactory factory = (TopicConnectionFactory) context.lookup(Commons.TOPICCONNECTION_FACTORY_JNDI);
TopicConnection connection = factory.createTopicConnection();
connection.start();
//创建一个Topic
Topic topic = (Topic) context.lookup("topic");
TopicSession session = connection.createTopicSession(false, Session.AUTO_ACKNOWLEDGE);
producer = session.createPublisher(topic);
//producer = session.createProducer(topic);
msg = session.createTextMessage();
}
public void sendMessage(String str)
throws Exception
{
msg.setText(str);
producer.send(msg);
}
public static void main(String[] args)
{
try
{
TopicProducer topic = new TopicProducer("topic");
for (int i = 0; i < 3; i++)
{
topic.sendMessage("Hello Topic" + i + "," + new Date().toString());
}
System.out.println("消息发送完成");
}
catch (Exception e)
{
e.printStackTrace();
}
}
}

③ SyncTopicReceive.java同步接收

package com.lession.day1024.topic;
import javax.jms.Message;
import javax.jms.TextMessage;
import javax.jms.Topic;
import javax.jms.TopicConnection;
import javax.jms.TopicConnectionFactory;
import javax.jms.TopicSession;
import javax.jms.TopicSubscriber;
import javax.naming.Context;
import com.lession.day1024.Commons;
public class SyncTopicReceive
{
private TopicSubscriber subscriber;
//private MessageConsumer subscriber;
public SyncTopicReceive()
throws Exception
{
this("topic");
}
public SyncTopicReceive(String jndiName)
throws Exception
{
Context context = Commons.getInitialContext();
TopicConnectionFactory factory = (TopicConnectionFactory)context.lookup(Commons.TOPICCONNECTION_FACTORY_JNDI);
TopicConnection conn = factory.createTopicConnection();
TopicSession session = conn.createTopicSession(false, TopicSession.AUTO_ACKNOWLEDGE);
Topic messageTopic = (Topic)context.lookup(jndiName);
subscriber = session.createSubscriber(messageTopic);
//subscriber = session.createConsumer(messageTopic);
conn.start();
}
public boolean receiveMessage() throws Exception
{
Message msg = subscriber.receive();
if(null != msg)
{
String msgText = "";
if (msg instanceof TextMessage)
{
msgText = ((TextMessage)msg).getText();
}
else
{
msgText = msg.toString();
}
System.out.println("The message:" + msgText);
return true;
}
return false;
}
public static void main(String[] args) throws Exception{
SyncTopicReceive receiver = new SyncTopicReceive("topic");
while(receiver.receiveMessage());
System.out.println("finish");
}
}

运行结果:

1)我先运行一个接收 SyncTopicReceive.java,然后运行 TopicProducer.java,可以看到刚刚发布的消息,已经被接收

2) 我再运行一个接收SyncTopicReceive.java(有两个了),然后运行 TopicProducer.java。请根据截图时间对比接收到的消息内容。

由两次运行的结果,我们可以知道:只有订阅者是活动状态,发布者发布的消息才能被接收到;每条消息都可以被正在运行的订阅者接收。

发布/订阅模型的特点:

? 每个消息都可以有多个(0,1,……)订阅者

每条消息可以有多个消费者,如果报纸和杂志一样,谁订阅了谁都可以获得。

? 订阅者只能消费他们订阅之后出版的消息

这就要求订阅者必须先订阅,生产者再发布。即订阅者必须先运行,再等待生产者的运行,这和点对点类型有所差异。

? 订阅者必须保持为活动状态才能使用这些消息

即订阅者必须保持活动状态等待发布者发布的消息,如果订阅者在发布者发布消息之后才运行,则不能获得先前发布者发布的消息。

相关推荐

TCP协议原理,有这一篇就够了

先亮出这篇文章的思维导图:TCP作为传输层的协议,是一个软件工程师素养的体现,也是面试中经常被问到的知识点。在此,我将TCP核心的一些问题梳理了一下,希望能帮到各位。001.能不能说一说TC...

Win10专业版无线网络老是掉线的问题

有一位电脑基地的用户,使用...

学习计算机网络需要掌握以下几方面基础知识

计算机基础知识操作系统:了解常见操作系统(如Windows、Linux)的基本操作和网络配置,例如如何设置IP地址、子网掩码、网关和DNS服务器等,以及如何通过命令行工具(如ping、tr...

网络工程师的圣经!世界级网工手绘268张图让TCP/IP直接通俗易懂

要把知识通俗地讲明白,真的不容易。——读者说TCP/IP从字面意义上讲,有人可能会认为TCP/IP是指TCP和IP两种协议。实际生活当中有时候也确实就是这两种协议。然而在很多情况下,它只是...

三分钟了解通信知识TCP与IP协议(含“通信技术”资料分享)

TCP/IPTCP/IP分层模型①应用层...

网闸与防火墙:网络安全设备的差异与应用

在网络安全领域,网闸(安全隔离网闸,GAP)和防火墙(Firewall)是两类重要的防护设备。尽管它们都服务于网络安全防护,但在设计理念、技术原理、安全效能及适用场景等方面存在显著差异,以下从五个维度...

S7-300的TCP/IP通信

一、首先在项目中创建2个S7-300的站点;二、硬件组态中,设置合适的TCP/IP地址,在同一网段内;...

西门子S7-1500 PLC的 MODBUS TCP通信

MODBUSTCP使MODBUS_RTU协议运行于以太网,MODBUSTCP使用TCP/IP和以太网在站点间传送MODBUS报文,MODBUSTCP结合了以太网物理网络和网络标准TC...

系统规划与管理师新版备考必备:第7章考点思维导图解析

备考系统规划与管理师的小伙伴们,福利又来啦!今天为大家带来《系统规划与管理师(第2版)》第7章考点的思维导图,助你高效梳理重点,让备考更有方向!...

TCP/IP、Http、Socket 有何区别与联系?

HTTP协议对应于应用层,Socket则是对TCP/IP协议的封装和应用(程序员层面上)。HTTP是应用层协议,主要解决如何包装数据。而我们平时说的最多的Socket是什么呢?实际上...

西门子PLC串口协议与以太网通信协议对比

西门子plc品牌众多,通信协议的类型就更多了,具体可分为串口协议和以太网通信协议两大类。...

网络编程懒人入门(十三):一泡尿的时间,快速搞懂TCP和UDP的区别

本文引用了作者Fundebug的“一文搞懂TCP与UDP的区别”一文的内容,感谢无私分享。1、引言...

程序员必备的学习笔记《TCP/IP详解(一)》

为什么会有TCP/IP协议在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别。就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样...

一文读懂TCP/IP协议工作原理和工作流程

简述本文主要介绍TCP/IP协议工作原理和工作流程。含义TCP/IP协议,英文全称TransmissionControlProtocol/InternetProtocol,包含了一系列构成互联网...

如何在 Windows 10 和 Windows 11 上重置 TCP/IP 堆栈

传输控制协议/Internet协议,通常称为TCP/IP,是您的WindowsPC如何与Internet上的其他设备进行通信的关键部分。但是当事情出错时会发生什么?你如何解决它?幸运的...

取消回复欢迎 发表评论: