环境无关的环境
软件开发过程中常常需要搭建各种环境,开发环境,测试环境,集成构建环境等等。一个不可复制的环境是低效的根源,它会引起很多问题。本文将告诉你,如何创建一个“环境无关的环境”。
作者 Sadek Drobi 译者 郭晓刚 发布于 2008年11月9日 下午7时32分
Dan Pritchett在博客上提出了一种数据仓库应用的替代方案。虽然厌恶“只能单一位置及单一存储空间上实现的方案”,他也承认有时候必须先聚合数据才能作分析。他所说的正是数据仓库应用的功能——沿着某些变量轴聚合信息并转化数据间的关系。而在Pritchett看来,数据仓库应用在使用中有许多缺点。数据仓库应用不仅非常昂贵,“比较小的组织一般难以企及”,而且ETL(Extract, Transform and Load,提取、转换、装载)软件的工作方式意味着要付出可伸缩性和反应能力的代价:
首先,ETL给生产数据库增加了明显的负担。如果你的业务有空窗期可以做ETL,那是最好的;如果没有,管理可伸缩性就是很大的挑战。第二,数据仓库里的数据新鲜度一般滞后24小时或更长,随着业务增长,滞后时间会越来越长。
Dan Pritchett相信有一种方案更便宜,也更可伸缩:用ESP(Event Stream Processor)处理事件流。
ESP用类似SQL的语言处理各种事件流。与数据库和数据仓库通过SQL分析数据表类似,ESP用它们的查询语言分析事件流。要想理解ESP,可以把事件类比成数据库表中的行,而事件的属性则对应数据库表的列。每一种事件类型就等于是一张表。[…]
[ESP分析]数据的变化,而且就在变化发生的当时分析。我们不再进行批量的ETL,而是把业务事件变成一连串的数据状态变化。这就创造出一种更易于管理的生产系统的伸缩模型。
[…]
ESP可以做水平伸缩,因此可以达至一种更具成本效益的业务方案。而且由于ESP执行分析是实时的,因此得到的业务指标更加应时,并且不受业务增长的影响。
Dan也特别指出这种方法的弱点,就是不能进行历史性的分析,不能从当前以外的角度去观察业务活动。Pritchett提出用一种捕捉并重演事务的框架去克服此弱点,不过该方案相当昂贵。Tahir Akhtar在帖子的留言中提出另一种弥补方法:用ESP替代ETL,但在享用ESP的可伸缩性和反应能力优势的同时,继续使用数据仓库应用以保留历史分析能力。
查看英文原文:Event Stream Processing: Scalable Alternative to Data Warehouses?
本演讲针对Flex体系架构,从三个方面进行剖析讲解。三个方面包括产品核心、工具及数据服务、应用开发。通过60分钟的讲解,能够从超越代码开发视角了解整个Flex生态系统和体系架构,帮助企业在RIA应用开发上进行更好的技术体系架构分析和技术决策。
Aptana RadRails: 在比较了Aptana RadRails IDE和其他现有的IDE之后,Javier Ramírez推荐使用此IDE,这个IDE可用于开发Ruby on Rails应用。
Wolfram|Alpha与Google究竟是什么关系,Wolfram|Alpha自己是如何定位的?Wolfram|Alaph在多大程度上是语义网搜索呢?InfoQ中文站就等等这些问题采访了Wolfram研究公司中国区商务经理王翔。
Vijay Narayanan在这篇文章中对数据服务的几个方面进行了介绍,它们都是SOA实践者和数据架构师感兴趣的内容。本文对数据服务的几个方面进行了介绍,包括需求定义,基本原理和好处、范围、开发以及消费模式。
没有回复
关注此讨论 回复