写点什么

通用 Ruby 多虚拟机 API 研究开始啦

  • 2008-03-03
  • 本文字数:1728 字

    阅读完需:约 6 分钟

过去 Ruby 在多核机器下运行是一个大问题 。直到 Ruby1.8,Ruby 的解释器一直在使用用户空间线程(userspace threading ),这意味着线程是由 Ruby 解释器调度运行的。Ruby 1.9通过使用内核线程(kernel threads )改变了这一切——除了它使用一个像 Python 那样的全局解释器锁(Global Interpreter Lock,即GIL)。GIL 意味着一次只能运行一个 Ruby 线程,而本地代码就可以多线程方式运行。

运行在 JVM 上的JRuby早已开始支持本地线程了。对于多核的一个解决方案是运行多个 Ruby 进程,这些进程可由操作系统在多核之间调度。而 JRuby 线程可以使用多核,像Rails 之类的应用——并不是线程安全的,他们必须使用JRuby 进程——对JRuby 来说这也会成为一个合适的解决方案。

使用多个Ruby 虚拟机会产生很多部署问题,像如何加载新的Ruby 进程、如何与其他进程通信等等。最明显的问题就是加载一个新的Ruby 进程。通过下面简单的方式来加载一个新的Ruby 进程

system("ruby", file_to_run)然而如果上面的代码运行在 JRuby 下,那么很多时候会产生失败的结果,前提是系统中唯一的 Ruby 实现就是 JRuby,而它则必须由“jruby”加载。性能问题也是值得关注的:使用“'jruby” 命令加载一个或多个 JRuby 会导致多个 JVMs 的加载。既然多个 JRuby 实例可以共享相同的 JVM,那么这就是不必要的了。但是,需要特定于 JRuby 的代码来完成新实例的实例化工作,这会根据主机架构的不同而发生变化,如 BSF 或者 Java6 中的实现。

Rubinius是一个 Ruby 实现,它现在也在使用用户空间线程, 最近它还增加了多虚拟机支持 。通过下面的代码

vm = Rubinius::VM.spawn "blah", "-e", "puts 'hello\n'"可以加载一个新的虚拟机。这个方案确实使用了多核,因为每个虚拟机都运行在其本地线程上。这表示所有的虚拟机都驻留在同一个操作系统的地址空间中并且并行运行。但是虚拟机不能共享任何引用,或者说——任何东西;唯一的通信手段是通过一个特定于 Rubinius 的消息传递 API。

所有这些不同的解决方案归纳如下:跨越 Ruby 实现来编写运行于多核上的代码是不切实际的,因为每个 Ruby 实现都需要不同的处理。举例来说,如果一个程序想要使用 Skynet( MapReduce 的 Ruby 版本 ),还想使用多虚拟机来并行运行任务,那么其必须进行适配以适合每种 Ruby 实现。

该问题有可能被一个新的研究项目所解决,该项目是由东京大学与 Sun 的 JRuby 小组联合发起的,目的在于寻求能工作于所有 Ruby 实现的解决方案。下面的内容来自新闻

由东京大学信息科学与技术研究所的 Ikuo Takeuchi 教授领导的小组将联合 Sun 的 Tim Bray(Web 技术主管)与 JRuby 小组成员一起去实现可应用于 Ruby 与 JRuby 的多虚拟机(MVM)环境。该 MVM 环境目的在于使 Ruby 程序更加高效地运行。按计划,研究成果将通过 Ruby 社区开源,这会激发更多的创新。 以前,在 Ruby 上同时运行一个以上应用时需要多个解释器,这造成内存的浪费。MVM 环境会在一个解释器上产生多个虚拟机实例,这会让应用的运行效率得到提高。该协作研究的目的在于明确技术问题如使用 MVM 的通用接口定义,虚拟机实例的并行运行以及内存共享,接下来实现可应用于 Ruby 与 JRuby 的技术。因为 Ruby 已经在商业和其他环境中得到了广泛的应用,所以对 MVM 的研究将进一步增进 Ruby 的性能和用途。

简而言之,期望的结果就是产生出可以加载和使用多个 Ruby 虚拟机的通用 API。通过该通用 API,每个 Ruby 实现将有一个后盾以确保提供最有效率的实现。对于 Rubinius 和 JRuby,虚拟机可以共享相同的地址空间;对于老版本的 Ruby,可以加载多个进程。

该 API 的另一个重要方面是定义虚拟机之间如何通信。可以利用 Rubinius 的消息传递方案,因为像 Erlang 这样的系统利用它来避免很多共享内存的问题。在 JSR-121 Application Isolation API 还使用了一个相似的解决方案。

查看英文原文: Common Ruby MVM API research kicked off - - - - - -

译者简介:张龙,同济大学软件工程硕士,现就职于理光软件研究所。主要从事文档工作流和办公自动化解决方案的研发工作。热衷于 Java 轻量级框架的研究,对敏捷方法很感兴趣。曾有若干年的 J2EE 培训讲师经历。参与 InfoQ 中文站内容建设,请邮件至 china-editorial[at]infoq.com

2008-03-03 00:50867
用户头像

发布了 88 篇内容, 共 262.3 次阅读, 收获喜欢 8 次。

关注

评论

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

重新定义 AI 部署效率与性能!ZOLOZ 如何借助 AC2 实现低成本高性能的提优?| AI 案例推荐

OpenAnolis小助手

AI 操作系统 容器镜像 龙蜥社区 ZOLOZ

开发者有福了,百度文心智能体平台免费开放文心大模型4.0

科技热闻

氛围共处(Ambient Co-presence)丨RTE 共读计划

声网

科研菜鸡的好助手——代码小浣熊+办公小浣熊

卟噜卟噜叭

线上观看人次3万+!「系统安全技术沙龙-龙蜥社区走进浪潮信息专场」圆满结束

OpenAnolis小助手

操作系统 系统安全 国产操作系统 龙蜥meetup

中软国际加入龙蜥社区,促进“技术+生态”双向赋能

OpenAnolis小助手

龙蜥社区 龙蜥生态 中软国际

商汤推出「可控」人物视频生成大模型;大阪将在多座车站部署实时语音识别系统丨 RTE 开发者日报

声网

携手豆包大模型,领克汽车在智能销售领域迈出坚实一步

新消费日报

护航端侧大模型平稳健康发展,百度大模型内容安全Lite版正式发布

百度安全

龙蜥技术认证携手成都东软学院,证书与学分互认互通

OpenAnolis小助手

开源 操作系统 龙蜥技术认证

MinIO:开源对象存储解决方案的领先者

数新网络官方账号

开源 前端 Minio

数字揭秘丨如何设计出坚不可摧的网球拍?

Altair RapidMiner

人工智能 数字孪生 仿真 altair

百度智能云:千帆大模型平台升级十大能力,企业级RAG全面升级

IT新闻资讯

通义灵码入选 2024 世界人工智能大会最高荣誉「镇馆之宝」

阿里云云效

阿里云 云原生 通义灵码

低代码开发平台助力中小企业服务数字化转型

不在线第一只蜗牛

低代码 数字化 企业转型

阿里面试:说说@Async实现原理?

王磊

Java 面试题

低代码开发在基层央行办公自动化系统上的探索

快乐非自愿限量之名

低代码 企业转型

深度报告 | 百度安全携手极越安全发布《整车安全渗透测试白皮书》

百度安全

Golang channel底层是如何实现的?(深度好文)

golang架构师k哥

golang

低代码平台在企业数字化转型中的关键角色与应用

EquatorCoco

低代码 数字化 企业转型

开发巴黎奥运会直播平台快速上线与深度定制的时间考量

软件开发-梦幻运营部

【XIAOJUSURVEY&北大】Authorization实现 - server源码阅读分析

XIAOJUSURVEY

鉴权 JWT Authorization

538个代码示例!麻省理工教授的Python程序设计+人工智能案例实践

我再BUG界嘎嘎乱杀

Python 人工智能 编程 程序设计 开发语言

碳课堂|搞清楚碳足迹,只看这篇文章就够了

AMT企源

碳中和 双碳 碳管理 碳核算

合合信息大模型“加速器”亮相2024世界人工智能大会,助力大模型学好“专业课”

合合技术团队

人工智能 合合信息 文档解析

从传统到智能,“小浣熊家族AI办公助手”引领数据处理的革命

完美句号

办公 办公平台 AI Agent 效率办公 小浣熊家族

2024 年 6 月区块链游戏研报:Pixels 引发 DAU 波动,行业用户留存率差异显著

Footprint Analytics

区块链游戏

职场<火焰杯>测试开发大赛决赛即将开始!

霍格沃兹测试开发学社

通用Ruby多虚拟机API研究开始啦_Java_Werner Schuster_InfoQ精选文章