50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

后 HTTP 时代:使用 Meteor 开发实时 Web 应用

  • 2013-06-14
  • 本文字数:1318 字

    阅读完需:约 4 分钟

QCon New York 2013 大会的 HTML5 专场中, Matt DeBergalis Meteor 做了一场报告。Meteor 是开源的实时 Web 应用框架,Debergalis 是该框架的联合创建者。据 DeBergalis 介绍,从架构上看,选择客户端还是服务器,钟摆已经摇摆了多次:从主机(服务器端)到桌面(客户端),再到 Web(服务器端),现在又发展到了现代化的 Web——客户端功能越来越强,越来越多的工作又回到了客户端。然而,DeBergalis 认为用于构建这些现代化 Web 应用的工具还没有跟上。Meteor 的目标就是提供一种工具,让开发者更轻松、更一致地构建这类实时 Web 应用。

今天的现代化 Web 应用由两个不同的部分组成:

  1. 服务器端可能是使用诸如 PHP、Java 或 Ruby 等语言构建的,同时使用特定的服务器端 API 及工具来构建软件并管理依赖。
  2. 客户端会使用一种或多种 JavaScript 库、HTML 和 CSS,而且也是利用自己的构建工具(如 Google Closure Compiler )来构建的。

两者之间的通信本质上采用的是一种定制的线级协议,通常使用 HTTP 或 WebSocket 之上的 JSON 来编码,并以这种方式发送命令:发送一段数据、将这段新数据持久化及渲染这段数据等。

Meteor 反思了这种实现方式,并致力于让一切实时进行。HTTP 并不适合这一目标,相反,通过 WebSocket 使用 Meteor 自己的 DDP(分布式数据协议)进行通信更为合适,而且这里的通信不仅仅是交付 Web 资源。DDP 是一种通用协议(使用 JSON 编码),支持如下三种核心操作:

  • 订阅:利用该协议,客户端可以登录并发表自己的意见:“我对数据集合 X 感兴趣,请发给我它的所有数据的初始快照,然后不断地将数据的变化值发给我,以便我更新缓存的数据,使其保持最新。”
  • 发布:“实体 Y 的 X 属性,其值修改为 Z。”
  • 远程过程调用(RPC):这类操作用于执行远程过程,并以容错的方式返回执行结果。

Meteor 提供了一个用 JavaScript 编写的、支持服务器和客户端的 DDP 实现(在服务器上是支持 Fibers Node.js )。不过该协议与实现无关,因此可以编写另外的实现作为替代。比如,现在已经有了一个.NET 客户端库

Meteor 的第二个组件是其视图引擎,它能利用底层数据自动将 DOM 保持最新,与 AngularJS Web Components 支持的功能类似。

Meteor 的第三个组件是打包系统。因为 Meteor 组件不仅仅是服务器端或客户端,因此当前的打包系统并不合适。Meteor 的打包系统可以同时分发服务器端组件和客户端组件。

Meteor 本身可以确定哪部分代码需要运行在浏览器中,哪部分运行在服务器上。DeBergalis 提到,为了更好地分割代码,目前正在开发静态源码分析技术。有了这样的技术,就可以只推送客户端需要的代码。

实时推送数据,并不是 Meteor 中唯一涉及实时性的地方。热代码推送是 Demo 中最引人注目的特性之一是:不管开发者什么时候保存文件,Meteor 不仅能自动地重新加载服务器上的代码,还能自动地将代码打包,并将代码推送给所有客户端,确保所有客户端运行的是与服务端代码兼容的、最新最好的客户端代码。

Meteor 是一种有趣的全栈式实时 Web 应用开发方法。要学习更多知识,请阅读Meteor 网站提供的文档,并研究相关例子。此外,还有一本关于Meteor 的书,InfoQ 曾发布过相关书评

查看英文原文: The Post-HTTP Era: Real-Time Web Apps With Meteor

2013-06-14 07:323710
用户头像
臧秀涛 略懂技术的运营同学。

发布了 300 篇内容, 共 149.6 次阅读, 收获喜欢 35 次。

关注

评论

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

模块1 作业

KennyQ

固定资产管理系统的主要功能和优点

低代码小观

低代码 企业管理 资产管理 企业管理系统 CRM系统

Apache Shiro Realm实战及认证授权源码解读

编程江湖

协同·转型·智慧,WorkPlus移动平台帮助企业走好数字化转型之路

BeeWorks

阿里云智能编码插件,Cosy文档搜索上新了

阿里云云效

阿里云 代码管理 代码库 阿里云智能编码插件 Cosy

关于在hive任务中number of reducers的探讨

编程江湖

《2021年IT行业项目管理调查报告》重磅发布!

禅道项目管理

项目管理 DevOps 加班

深度确定性策略梯度(DDPG)

行者AI

机器使用成本下降 50%,TDengine 在同程旅行基础监控中的实践

TDengine

数据库 tdengine

Linux内核权限提升漏洞

网络安全学海

网络安全 信息安全 渗透测试 WEB安全 漏洞挖掘

私有化部署是什么意思?企业私有化部署的几种类型和利弊分析

BeeWorks

基于Prometheus的企业级监控体系探索与实践

中原银行

分布式 微服务 云原生 Prometheus 中原银行

《中国金融科技与数字普惠金融发展报告(2022)》发布 十大趋势研判未来行业发展

BeeWorks

视觉Transformer中的输入可视化方法

百度Geek说

后端

长治测评机构公司有几家?是正规的吗?

行云管家

网络安全 等保 等保测评

分布式事务揭秘

中原银行

分布式 分布式事务 云原生 中原银行

Apache Flink 在翼支付的实践应用

Apache Flink

大数据 flink 编程 流计算 实时计算

浅谈外挂常识和如何防御

行者AI

星河标杆案例 | 洞见科技与智慧齐鲁「基于隐私计算的省级公共数据开放平台建设」实践

洞见科技

隐私计算 数据流通

一起来DIVE!在基础软件知识海洋遨游,还能赢取万元奖品!

InfoQ写作社区官方

热门活动 DIVE

区块链中的共识机制简介

中原银行

区块链 中原银行

华为公布终端云最新数据:终端全球月活用户超过7.3亿

叶落便知秋

华为

Flink CDC 2.2 正式发布,新增四种数据源,支持动态加表,提供增量快照框架

Apache Flink

大数据 flink 编程 流计算 实时计算

优酷播放黑科技 | 自由视角技术的全链路策略与落地实践

阿里巴巴终端技术

客户端 音视频技术 视频技术

下一代对话系统中的关键技术

硬科技星球

网络编程入门从未如此简单(三):什么是IPv6?漫画式图文,一篇即懂!

JackJiang

网络编程 ipv6 ipv4 即时通讯IM

不后悔的星期四,明道云首次全网公开直播零代码训练营

明道云

字节跳动基于 Apache Hudi 的多流拼接实践

字节跳动数据平台

字节跳动 实时数仓 Hudi

云效流水线 Flow 是什么?为什么选择云效「Flow」

阿里云云效

阿里云 云原生 持续交付 研发 云效流水线 Flow

后HTTP时代:使用Meteor开发实时Web应用_JavaScript_Zef Hemel_InfoQ精选文章