AICon 北京站 Keynote 亮点揭秘,想了解 Agent 智能体来就对了! 了解详情
写点什么

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:531013
用户头像

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

关注

评论

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

Go 必知必会:探索 Go 语言中的数组和切片深入理解顺序集合

王中阳Go

数组 go语言 切片 go基础

有奖问卷调研|OpenTiny给你送天命人好礼啦!

OpenTiny社区

开源 低代码 用户体验 OpenTiny 前端组件库

行业首家!百度智能云通过中国信通院「H5 端人脸识别安全能力」测评

Baidu AICLOUD

人脸识别

电科金仓:数智未来,国产数据库大有可为

科技热闻

整顿职场再出新招?法行宝携手顶级律所助力职场维权

科技热闻

iStat Menus 系统状态监控工具 :全面掌控你的Mac

Rose

采取预测分析最佳战术,指点企业未来精准决策

智达方通

企业管理 全面预算管理 财务规划 财务预测 财务预测分析

Hidden Bar for mac 菜单栏图标隐藏工具|帮你收纳不常用的菜单栏项目

Rose

FTP客户端工具 Yummy FTP Pro for Mac中文直装版

Rose

第七在线携手美国男士内衣品牌Tommy John,共启智能订货新篇章

第七在线

浅析前端数据埋点监控:用户行为与性能分析的桥梁

不在线第一只蜗牛

数据库 前端开发

Translatium for Mac翻译软件(支持150多种语言和方言)

Rose

犀牛Rhinoceros 7:专业的3D建模软件

Rose

一文教你10分钟快速玩转魔乐社区

天翼云开发者社区

人工智能 开发者社区 天翼云

XLD音频无损解码 X Lossless Decoder for mac 中文版

Rose

文献解读-Genome-wide imputation using the practical haplotype graph in the heterozygous crop cassava

INSVAST

基因数据分析 生信服务

电商数据整合新篇章:京东商品详情API返回值应用实践

技术冰糖葫芦

api 网关 API Explorer API 策略 pinduoduo API

梦中情池!账单自动化#运营通知

开源物联卡管理平台-设备管理

物联网 IoT eSIM安全 java 技术提升

简单实用的苹果解压缩软件推荐

Rose

短剧APP遭遇DDoS攻击的解决方法

网络安全服务

负载均衡 IP DDoS DDoS 攻击 短剧app开发

Office 2021全套包支持mac和win安装下载

你的猪会飞吗

Office 2021 Office LTSC 2021 office2021 Mac破解版

阿里巴巴商品搜索API返回值中的图片与详情链接

技术冰糖葫芦

api 网关 API Explorer API 策略 pinduoduo API

AI图像放大工具,图片放大无所不能

程序那些事

程序那些事 Stable Diffusion

草图大师SketchUp Pro 2023中文版安装包分享【mac/win】

Rose

MiniMax 首个文生视频模型发布,可生成 6s,限时免费;阿里 Qwen2-VL 第二代视觉语言模型开源丨RTE 开发者日报

声网

人工智能 | Mistral 大语言模型

测吧(北京)科技有限公司

测试

TikTok直播为什么要用独立IP

Ogcloud

海外直播 tiktok直播 tiktok直播网络 海外IP 海外直播IP

探索淘宝拍立淘API:解锁以图搜图的购物新体验

代码忍者

api 网关 API 策略

Gauss游马会openGauss-全局临时表

Gauss松鼠会

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