GTLC全球技术领导力峰会·上海站,首批讲师正式上线! 了解详情
写点什么

使用 Google PubSubHubbub 协议实现即时通知

2009 年 9 月 08 日

PubSubHubbub 是一个“开放的、服务器对服务器、基于 Web-hook 的发布 / 订阅协议,是 Atom 和 RSS 的扩展”。凭借该协议,感兴趣的参与者在 feed 有更新时会收到即时通知。该协议由 Google 开发,在 Google Code 中可以找到同名的项目

PubSubHubbub 协议将“拉”机制转变成了“推”机制,客户端不用再定时轮询服务器以查看 feed 是否有更新。客户端订阅一个 Hub,当 feed 有更新时 Hub 会即时通知客户端。项目主页上描述的处理过程如下:

  • feed URL(“主题”)在 Atom 或 RSS 的 XML 文件中使用 <link rel=“hub” …> 描述自己的 Hub 服务。Hub 可以由 feed 的发布者运行,也可以作为任何人都能使用的公有Hub 。(它支持Atom 和 RssFeeds

  • 订阅者(对主题感兴趣的服务器)最初仍照常提取 Atom URL。如果 Atom 文件声明了其 Hub,订阅者就不用轮询 URL 了,而是注册 feed 的 Hub 并订阅更新。

  • 订阅者从主题 URL 声明的 Hub 中订阅主题 URL。

  • 发布者下次更新主题 URL 时,发布者软件会给 Hub 发送信息,告知 Hub 有更新了。

  • Hub高效地提取发布的 feed ,并向所有注册的订阅者组播新增或修改了的内容。

Google 已经在他们的几个服务中实现了该协议,包括 FeedBurner、Reader(共享条目)、Blogger,还有不久前推出的 Alerts。该协议是开放的,遵循 Apache License 2.0 许可。此外,Hub 可以在任何服务器上运行而并非限制在 Google App Engine 上。

Google 已经发布了一个 Hub 的参考实现,可用来测试发布 / 订阅过程以了解其工作方式。这个视频演示了一个实际使用该协议的例子。

查看英文原文: Instant Notifications Using Google’s PubSubHubbub Protocol

2009 年 9 月 08 日 01:482551
用户头像

发布了 151 篇内容, 共 53.0 次阅读, 收获喜欢 12 次。

关注

评论

发布
暂无评论
发现更多内容

SGY奇点交易所系统源码开发

DV:19924636653

软件开发

工具词典:精力管理

lidaobing

精力管理 张遇升 28天写作

(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路

Java鱼仔

Java 程序员 面试 大学生

股东变员工,所以不发工资?| 法庭上的CTO(18)

赵新龙

CTO 法庭上的CTO

计算机网络简述

lee

计算机网络 网络协议 网络

像用户一样测试:打破知识的诅咒

QualityFocus

测试 软件质量 可用性 用户体验

重学JS | 数组遍历的7种方法及兼容性处理(polyfill)

梁龙先森

前端 编程语言

为新基建按下加速键:从openEuler看中国操作系统的产业生态未来

脑极体

大作业一

黄立

创建493个测试账户,被公司索赔527万 | 法庭上的 CTO(14)

赵新龙

CTO 法庭上的CTO

英特尔赵宏:从硬件创新到平台突破,PC的未来非常值得期待

intel001

深入浅出 ZooKeeper

vivo互联网技术

zookeeper 分布式 ZAB

从一个模糊词查询需求的处理方案讨论到一种极速匹配方案的实现

行如风

模糊匹配 双数组trie树 ahocorasick ac自动机 黑名单过滤

ZooX首发双向电动无人车,会成为自动驾驶出行的主流吗?

脑极体

劫持Chrome浏览器“获利”8000万元 | 法庭上的CTO(13)

赵新龙

CTO 法庭上的CTO

“有点技术之外,基本什么都没有”的CTO | 法庭上的CTO(15)

赵新龙

CTO 法庭上的CTO

阿里P8大牛手把手教你!高级Android晋升之View渲染机制,先收藏了

欢喜学安卓

android 程序员 面试 移动开发

未签订劳动合同的CTO | 法庭上的 CTO(17)

赵新龙

CTO 法庭上的CTO

人工智能不过尔尔,基于Python3深度学习库Keras/TensorFlow打造属于自己的聊天机器人(ChatRobot)

刘悦的技术博客

人工智能 tensorflow chatbot 聊天机器人 keras

“盗窃”公司源代码被开除的CTO | 法庭上的CTO(20)

赵新龙

CTO 法庭上的CTO

为什么要TDD(测试驱动开发)

sherlockq

敏捷开发 TDD 极限编程

智慧仓储管理系统,是否能解决购物狂欢节后新一轮爆仓危机?

一只数据鲸鱼

物联网 数据可视化 智慧物流 智慧仓储

甲方日常 75

句子

工作 随笔杂谈 日常

生产环境全链路压测建设历程 21:某快递 A 股上市公司的生产压测案例之基于测试流量的混沌工程(故障演练)

数列科技杨德华

全链路压测 七日更

anonymous匿名者场外交易系统APP软件开发

开發I852946OIIO

系统开发

混合用工、被拖欠工资的 CTO | 法庭上的 CTO(16)

赵新龙

CTO 法庭上的CTO

犯“走私罪”的CTO | 法庭上的CTO(19)

赵新龙

CTO 法庭上的CTO

Spring 源码学习 11:invokeBeanFactoryPostProcessors

程序员小航

Java spring 源码 源码阅读

这个问题值得讨论吗?

Alan

沟通 团队文化 七日更 28天写作

什么是浮点数?

Kaito

计算机基础 浮点数

从MongoID的生成讨论分布式唯一ID生成方案

行如风

雪花算法 分布式ID 全局唯一ID 流星算法

DNSPod与开源应用专场

DNSPod与开源应用专场

使用Google PubSubHubbub协议实现即时通知-InfoQ