2025上半年,最新 AI实践都在这!20+ 应用案例,任听一场议题就值回票价 了解详情
写点什么

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

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

关注

评论

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

【设计模式】第十一篇 - 装饰模式 - 孙悟空的六神装

Brave

设计模式 装饰模式 11月日更

Android面经分享:我是如何一举拿下阿里、抖音,html5图片左右移动

android 程序员 移动开发

Android面试主题整理合集(三),Android屏幕适配很难嘛其实也就那么回事

android 程序员 移动开发

Android面试吃透这一篇就够了,没有拿不到的offer!1096页Android学习笔记

android 程序员 移动开发

Android面试官装逼失败之:关于Activity的启动模式,android界面开发工具

android 程序员 移动开发

Android题集四大组件之Content provider、BroadcastReceiver

android 程序员 移动开发

Android通用业务弹窗管理方案V2,hashmap扩容过程

android 程序员 移动开发

android面试之今日头条-字节跳动-android社招面试(附答案)

android 程序员 移动开发

Android面试必问:Handler、Bitmap(1),kotlin数据库框架

android 程序员 移动开发

Android面试:来说一说Context吧,Android中的Context跟Java有什么区别

android 程序员 移动开发

Android高工面试(难度:四星,Android开发三年月薪才12K

android 程序员 移动开发

Android进阶难题:普通公司的程序员跟BAT大公司的技术差距在哪?该如何选择

android 程序员 移动开发

Android隐藏系统状态栏(沉浸式状态栏)和设置状态栏颜色

android 程序员 移动开发

Android进阶——解密笔记(1),分享一些行业经验

android 程序员 移动开发

Android面经:入职网易的那一天,我哭了,狂刷200道数据结构与算法

android 程序员 移动开发

Android面试回忆录:Service有几种启动方式?,大佬带你看源码

android 程序员 移动开发

Android面试必备!爆火超全的《Android性能优化全方面解析

android 程序员 移动开发

Android面试抱佛脚:进程间通讯学习,从Binder使用看起

android 程序员 移动开发

Android面试题之Java基础篇,安卓rxjava使用

android 程序员 移动开发

Android面试必备的集合源码详解,看完之后简历上多一个技能!

android 程序员 移动开发

Android进阶:用最详细的方式解析Android消息机制的源码

android 程序员 移动开发

Android面试心得必备技能储备详解,已拿到offer,androidhtml5开发框架

android 程序员 移动开发

Android面试题之Listview篇,2021Android面试心得

android 程序员 移动开发

RabbitMQ详解——RabbitMQ服务端执行逻辑(三)

AiDaddy

RabbitMQ 服务端执行逻辑

【LeetCode】最长定差子序列Java题解

Albert

算法 LeetCode 11月日更

Android高工面试(难度:四星(1),真的太香了

android 程序员 移动开发

Android跨进程通信导论,极致干货

android 程序员 移动开发

Android进阶——解密笔记,flutter人脸识别模块

android 程序员 移动开发

Android进阶:十一、视频播放器初体验,给大家安排上

android 程序员 移动开发

Android进阶:高仿抖音上下滑动分页视频,要求页面流畅

android 程序员 移动开发

Android面试必问:Handler、Bitmap,android插件化开源

android 程序员 移动开发

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