写点什么

Einstein:一门实验性的 SOA 第四代语言

  • 2008-06-29
  • 本文字数:1340 字

    阅读完需:约 4 分钟

实现SOA 一般需要使用多种技术来实现诸如分布式、并行处理、编配等需求。虽有多种工具来支持这些需求的实现,包括解决调用的 Web 服务框架,解决路由的企业服务总线(ESB),实现业务流程的编配引擎等,但是实现SOA 依旧是一项艰巨的任务,至少需要对这些完全不同的技术、它们的编程模型、它们的实现和部署方式等都有所了解。

一种解决这种复杂性的可能方案是“SOA 编程语言”——针对SOA 的领域特定语言,如 Wsper Einstein 。这些语言背后的动机是进一步提升抽象层次,使之更贴近实际的 SOA 开发问题。正如 Edsger Dijkstra 所说的:

任何一样工具最重要但也是最难以捉摸的地方,是对那些学习使用该工具的人们的习惯的影响。如果这里的工具是一门编程语言的话,那么该影响就是对我们思考习惯的影响(不论我们是否喜欢它)。

由于 Wsper 已经在 Jean-Jacque Dubray 的 InfoQ 迷你书《组合软件构造(Composite Software Construction)》中得到了很好的描述,所以本文接下来将主要讲述Einstein。

Einstein 是一门针对分布式 SOA 复杂环境而设计的语言,它建立在以下主要原则基础之上:

  • 分布式:Einstein 被设计成允许(潜在的)每条指令可以在彼此分离的机器上执行。接下来由用户决定代码中实际期望的分布式和并发性的程度。
  • 事件驱动:Einstein 是一门基于流程的编程语言,各条指令通过消息进行通信。
  • 并发性友好:在创建时,Einstein 就考虑支持并发性;它使用一组经过验证的避免共享状态的技术(消息传递、只读元组等),具备运行时感知的线程安全性。
  • 适当的复杂性:Einstein 采用了一些包括资源和模型在内的简单技术来减少实现分布式系统的复杂性。
  • 代替各种技术:Einstein 意在解决过去用来进行多系统集成的技术过多问题。目前,在构建一个资源交叉(cross-resource)系统时,我们常常依赖 ESB、网格技术、分布式状态系统、协调技术(如 BPEL)和工作流等技术。Einstein 被设计成一种代替所有这些技术的工具。

Einstein 的语言基于以下概念:

  • 资源,与变量极为相似,但是一般是粗粒度的。资源使用 URI 来访问。资源可被描述成不稳定(可安全用于多线程访问)、局部(不打算用于多节点访问或串行化)和幂等(接收一条消息多次的效果和只接受其一次的效果相同)。
  • 提供者,为任何资源接收、传送、执行、查询、路由或以某种方式处理消息提供了一致接口。一个提供者可被分成 3 个组件:ResourceProvider(扮演一个资源工厂),Resource(实现)和 Facades(一个资源为其所提供功能暴露的简单粗粒度接口视图)。提供者被自动加载进 Einstein 注册中心,中心包含了与所有可用资源和提供者相关的信息。
  • 消息是 Einstein 资源间交换数据的主要机制。一条消息的有效负荷包括一个数据对象而非一个语言对象,它允许多种数据格式(如 XML、对象图、CSV 文件等)与 Einstein 进行交互。
  • 执行组,包括流程执行组(顺序执行、类似编配语言中的 sequence)、元组执行组(并行执行,类似编配语言中的 fork/join)、组合执行组(与元组类似,但是至少有一个分支结束时即结束)和映射执行组(以上组的结合)。

超级实验性的 Einstein 0.1 版已经现在发布了。根据项目路线图所示,核心语言的预览要到7 月15 号才出来,接着到9 月1 号正式发布核心语言。

查看英文原文 Einstein: an Experimental 4GL for SOA

2008-06-29 23:531232
用户头像

发布了 255 篇内容, 共 68.7 次阅读, 收获喜欢 10 次。

关注

评论

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

性能测试思考分析

Andy

量化机器人管理系统开发|市值管理机器人模式系统开发

W13902449729

市值管理机器人开发 市值管理系统开发

接口测试--获取动态参数进阶

测试人生路

接口测试

腾讯大佬直言:只要掌握了这份“Redis实战笔记”就掌握了云计算的未来!

比伯

Java 编程 架构 面试 程序人生

CSS03 - 常用字体样式

Mr.Cactus

html/css

区块链推动电力能源管理新一轮技术变革

CECBC

区块链

别无分号只此一家,Python3接入支付宝身份认证接口( alipay.user.certify)体系(2021年最新攻略)

刘悦的技术博客

Python 支付宝 身份认证 刷脸 实名认证

区块链:能源行业出现破坏性创新的基础?

CECBC

区块链 能源

RocketMQ如何保证消息顺序性

废材姑娘

RocketMQ

实物资产卡片多数量拆分流程整理2021.01.06

Flychen

简述CAP原理

Andy

使用Github Actions部署静态网站

玉龙BB

GitHub Pages Hugo Github Actions

面向行业智能,华为数据通信推动的2020之变

脑极体

CSS01 - 引入方式

Mr.Cactus

html/css

CSS04 - 常用外观属性

Mr.Cactus

html/css

干货速递,百度BML自动超参搜索技术原理揭秘与实战攻略!

百度大脑

更新完IOS14,网络工程师又开始背锅了

区块链技术如何真实有效的赋能智慧交通?

CECBC

区块链

视频混剪怎么准备素材?会声会影视频消音操作步骤详解!

奈奈的杂社

视频剪辑 视频后期 混剪 视频消音

全球台式机CPU市场份额AMD超越Intel?别再混淆视听,误导消费者了!

E科讯

MySQL蜜罐获取攻击者微信ID

Java架构师迁哥

ml-agents项目实践(一)

行者AI

模型训练

如何使用ClickHouse实现时序数据管理和挖掘?

京东科技开发者

数据库 数据采集 数据库管理工具

有奖话题 | 2021 新年Flag,牛转乾坤!

InfoQ写作社区官方

话题讨论 热门活动

同城快递系统设计文档

业哥

1499飞天茅台脚本使用过程中遇到的Python问题汇总索引目录【淘宝-天猫超市、京东】

谙忆

飞天茅台 茅台

LeetCode题解:104. 二叉树的最大深度,BFS,JavaScript,详细注释

Lee Chen

算法 大前端 LeetCode

CSS02 - 选择器

Mr.Cactus

html/css

通过 Oracle 变量更新公司名称

Flychen

揭秘人民日报创作大脑:百度大脑智能创作平台助力打造“十八般武艺”

百度大脑

波场链智能合约DAPP系统开发技术

薇電13242772558

智能合约 dapp

Einstein:一门实验性的SOA第四代语言_SOA_Boris Lublinsky_InfoQ精选文章