2019-03-05

什么是jms

jms(java message service) Java消息服务, jms是一种规范是jdk底层定义的, 各大厂商对这个规范都是实现的技术.

jms作用:

在分布式系统当中, 系统和系统之间进行异步消息传递.

同步通讯技术:

代表的技术有: dubbo, springCloud, webService

技术特点: 例如controller中调用多个service, 每个service的执行要等待上一行代码执行完成后才会继续执行

下一行代码.

优点: 实时性比较好, 因为controller调用service, 然后service就去立即执行

缺点: 执行速度慢, 因为代码执行的顺序是串行执行, 下一行的代码执行要等待上一行代码执行完成后方可执行.

异步通讯技术:

代表的技术有: jms一系列的, activemq, rabbitmq, rokitmq, zeromq, kafka等

技术特点: 例如controller将消息发送给消息服务器, 消息服务器接收到消息后, 会以广播的形式发给其他处理

具体业务的服务器. 其他具体处理业务的服务器接收到消息后就会根据消息完成工作.

优点: 将以前串行执行的业务可以改为并行执行, 处理速度会比以前快, 能够更合理的分配每台计算机的性能.

缺点: 如果消息服务器正处于繁忙状态, 那么处理发消息的任务可能不及时. 所以对实时性要求不高的业务可以使用

这个技术.

消息中间件技术分类:使用的时候用封装之后的jmsTemplet,它是spring全家桶的一份子,不论使用哪一个他们底层都是调用的各自的客户端工具包,所有会使用一个其他的都可以使用了

activeMq: 是apache公司的, 一个老牌的消息中间件, 性能均衡, 不是最快的, 传递数据的安全性也不是最好的.

RabbitMQ: 阿里巴巴公司生产的, 它比较安全. 因为这个中间件有分布式消息级别事务功能.

ZeroMQ: 史上最快的队列系统

Kafka: 史上最快的消息中间件技术, 可以达到单机每秒10万的吞吐量

消息中间件支持的传输数据对象的类型:

TextMessage--一个字符串对象

MapMessage--一套名称-值对

ObjectMessage--一个序列化的 Java 对象

BytesMessage--一个字节的数据流

StreamMessage -- Java 原始值的数据流

消息中间件支持的两种发送模式:

点对点(Queue): 一个消息发送方, 一个消息接收方. 相当于qq的私聊

如果是多个发送方, 一个接收方也算点对点模式

订阅发布模式(Topic): 一个消息发送方, 多个消息接收方. 相当于qq的群聊.

如果多个发送方, 多个接收方也算发布订阅模式

activeMq中保证数据安全性机制(保证数据不会丢):

点对点模式:

a. 发送方将数据发送给消息服务器, 进入消息服务器中的队列

b. 消息服务器接收到消息后会从队列中将数据发送给接收方

c. 如果接收方接收到数据后, 会返回响应给消息服务器, 消息服务器接收到响应后认为接收成功

这个时候会将这个数据从队列中删除

d. 如果接收方处于宕机状态, 无法接收到数据, 那么也就无法返回响应给消息服务器, 消息服务器在

一段时间后没有接受到接收方的响应, 则会认为消息接收方宕机, 会将数据从队列中拿出来进行持久化

保存到消息服务器的硬盘中, 每个一段时间会发送给消息接收方一次. 直到接收到消息接收方的响应

则会认为发送成功, 将持久化的数据删除

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,084评论 1 32
  • 在分布式服务框架中,一个最基础的问题就是远程服务是怎么通讯的,在Java领域中有很多可实现远程通讯的技术,例如:R...
    java菜阅读 979评论 0 2
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,858评论 6 13
  • 按照宋鸿兵老师的金融环流说法(现在很多人看一本《货币战争》就说是小说,来黑宋鸿兵,你知道士别三日当刮目相看吗!),...
    叮宕阅读 344评论 0 0
  • ‘天下不如意事,十常居七八’ 我看的小说不多,而且有的还是看过很多遍,每次看到结尾时会翻回去再看看开头,这种就好像...
    仂七阅读 294评论 0 0