JMS简介及Ipedo Feeds(1)

2024-02-25 03:58
文章标签 简介 jms feeds ipedo

本文主要是介绍JMS简介及Ipedo Feeds(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 前言

当今社会,信息无处不在。他们的载体又大多是不同的系统。那如何在这些系统间进行信息交互呢?答案就是MOM(Message-Oriented Middleware)MOM允许两个或更多个企业级应用间以消息的形式来交互信息。而不同的MOM厂商提供了不同的API给开发人员来接受和发送消息、定义了不同的网络协议、管理工具等。为了统一这些关于消息的相关内容,SUN提出了JMS(Java Message Service)规范。JMS类似于JDBC,能够让应用程序开发人员重用相同的API来访问不同的系统。而实现了JMS规范(http://java.sun.com/products/jms/docs.html)的实体称为JMS provider,也就是消息交互之间的桥梁。在JMS规范中JMS client分为消息发送者(生产者)和消息接受者(消费者)

 

Fig1. JMS系统图

2. JMS消息组成

 

Fig2. JMS消息组成

从上图可以看出JMS定义了以下三种组成部分。

A.     Header: 包括用于描述谁创建了这个消息、何时创建、多长时间内该消息有效以及消息的destination(Topic queue)metadata信息。每一个header信息都有setget接口。参见下面的代码

   public interface Message {
      public Destination getJMSDestination( ) throws JMSException;
      public void setJMSDestination(Destination destination)throws JMSException;
      public int getJMSDeliveryMode( ) throws JMSException;
      public void setJMSDeliveryMode(int deliveryMode)throws JMSException;
      public String getJMSMessageID( ) throws JMSException;
      public void setJMSMessageID(String id) throws JMSException;
      public long getJMSTimestamp( ) throws JMSException;
      public void setJMSTimestamp(long timestamp) throws JMSException;

     .........

}

而其中有些header信息是由JMS provider自动设定的,也就是说开发人员调用set方法设定的值将会被JMS provider覆盖。比如JMSDestination(Topic or queue)JMSDeliveryMode(persistent or nonpersistent)等。另一些JMSReplyToJMSTypeheader信息则是由开发人员设定。

 

B. Properties: Properties的作用类似于一些额外的header信息。Property的值可以是boolean, byte, short, int, long, float, double, StringJMS接口也定义了这些类型的propertygetset方法。Properties又分为三类:

1.  应用相关的Property, 比如下面代码段中的username这个property,

TextMessage message = pubSession.createTextMessage( );

message.setText(text);

message.setStringProperty("username",username);

publisher.publish(message);

username在其他的应用中是没有意义的。

2.  JMS定义的property,这些property1中所讲的property具有相同的特性,只不过它们是由JMS provider设定,其实就是可选的headerProvider可以任意选择下列的property进行支持,或者一个也不支持。

     ·  JMSXUserID

·  JMSXAppID

·  JMSXProducerTXID

·  JMSXConsumerTXID

·  JMSXRcvTimestamp

·  JMSXDeliveryCount

·  JMSXState

·  JMSXGroupID

·  JMSXGroupSeq

3Provider相关的property,每一个JMS provider还可以定义一系列的私有的property,由客户端或provider自己设定,每一个JMS provider相关的property都以JMS_开头,后面跟property的名字。

同时,provider可以根据消息的headerproperty来定义消息的选择器(Message Selectors),达到消息过滤的功能。比如下面的选择器(黑体部分)用来告诉消息服务器只发送不包含username这个property等于William的消息给消息消费者:

TopicSubscriber subscriber =

session.createSubscriber(chatTopic, " username != 'William' ",false);

消息选择器基于SQL中的where子句。

 

C Payload: 就是消息包含的真正的数据。JMS定义了五种消息类型接口TextMessage,

StreamMessage, MapMessage, ObjectMessage, and BytesMessage,它们都继承于Message 这个interfaceTextMessage使用字符串作为消息的payloadObjectMessage使用可序列化的对象作为消息的payloadBytesMessage使用byte数组作为消息的payloadStreamMessage使用原始数据类型的流作为消息的payloadMapMessage使用name-value对作为消息的payload下面的代码说明了如何设置text message并发送这个message,其他类型的消息类似:

TextMessage textMessage = session.createTextMessage( );

textMessage.setText("Hello!");

topicPublisher.publish(textMessage);

...

TextMessage textMessage = session.createTextMessage("Hello!");

queueSender.send(textMessage);

 

这篇关于JMS简介及Ipedo Feeds(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/744322

相关文章

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle

【Tools】AutoML简介

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 AutoML(自动机器学习)是一种使用机器学习技术来自动化机器学习任务的方法。在大模型中的AutoML是指在大型数据集上使用自动化机器学习技术进行模型训练和优化。

SaaS、PaaS、IaaS简介

云计算、云服务、云平台……现在“云”已成了一个家喻户晓的概念,但PaaS, IaaS 和SaaS的区别估计还没有那么多的人分得清,下面就分别向大家普及一下它们的基本概念: SaaS 软件即服务 SaaS是Software-as-a-Service的简称,意思是软件即服务。随着互联网技术的发展和应用软件的成熟, 在21世纪开始兴起的一种完全创新的软件应用模式。 它是一种通过Internet提供

LIBSVM简介

LIBSVM简介 支持向量机所涉及到的数学知识对一般的化学研究者来说是比较难的,自己编程实现该算法难度就更大了。但是现在的网络资源非常发达,而且国际上的科学研究者把他们的研究成果已经放在网络上,免费提供给用于研究目的,这样方便大多数的研究者,不必要花费大量的时间理解SVM算法的深奥数学原理和计算机程序设计。目前有关SVM计算的相关软件有很多,如LIBSVM、mySVM、SVMLight等,这些

urllib与requests爬虫简介

urllib与requests爬虫简介 – 潘登同学的爬虫笔记 文章目录 urllib与requests爬虫简介 -- 潘登同学的爬虫笔记第一个爬虫程序 urllib的基本使用Request对象的使用urllib发送get请求实战-喜马拉雅网站 urllib发送post请求 动态页面获取数据请求 SSL证书验证伪装自己的爬虫-请求头 urllib的底层原理伪装自己的爬虫-设置代理爬虫coo

新一代车载(E/E)架构下的中央计算载体---HPC软件架构简介

老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节能减排。 无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事.而不是让内心的烦躁、焦虑、毁掉你本就不多的热情和定力。 时间不知不觉中,快要来到夏末秋初。一年又过去了一大半,成