MagLev (software)

From Justapedia, unleashing the power of collective wisdom
Jump to navigation Jump to search
MagLev
Developer(s)GemTalk Systems
Initial release2008; 15 years ago (2008)
Stable release
1.2.0 Alpha 4 / May 17, 2013 (2013-05-17)
Written inSmalltalk, Ruby
Operating systemCross-platform: Solaris, AIX, Linux, Mac OS X
PlatformGemStone/S
TypeRuby programming language interpreter
LicenseMIT, GPL, others[1]
Websitemaglev.github.com

MagLev is an alternative implementation of the Ruby programming language built on the GemStone/S virtual machine from GemTalk Systems. Much of Maglev was set out to be written in Ruby as much as possible, resulting in some collaboration with the Rubinius project. As of the first beta release, the project runs RubyGems 1.3.5 natively, with support for C and Smalltalk extensions. MagLev has a distinct VM architecture that allows it to share code and data between runtimes and execution cycles through a Ruby API.[2]

Architecture

Maglev runs inside an image like Smalltalk, offering transparent object persistence[3][failed verification][4] to Ruby objects and classes. Object persistence is based on ACID transactions that allow multiple running instances to see a shared object graph. Maglev uses a process-based concurrency model, mapping Ruby threads to Smalltalk Processes[5][self-published source?], which are scheduled in the VM as green threads. Using MagLev should yield performance increases when using Ruby, along with allowing Ruby processes over multiple machines to use the same objects at the same time.[6]

Installation

MagLev is installed with RVM, using the following code snippets, copied directly from the maglev github.[7]

rvm install maglev
rvm use maglev

The status can be checked using

$ maglev status

Ruby Compatibility

Maglev targets Ruby 1.8.7 and runs a significant number of RubySpec. It supports several C extensions including Nokogiri, JSON and bcrypt.

Gemstone/S Resources

  • GemStoneS 64 bit 3.1.x Documentation, July 3, 2012, retrieved July 29, 2012

References

External links