MagLev (software)

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search
MagLev
MagLev logo.gif
Developer(s)GemTalk Systems
Initial release2008; 13 years ago (2008)
Stable release
1.2.0 Alpha 4 / May 17, 2013 (2013-05-17)
Repository Edit this at Wikidata
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[edit]

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[edit]

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[edit]

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[edit]

  • GemStoneS 64 bit 3.1.x Documentation, July 3, 2012, retrieved July 29, 2012 CS1 maint: discouraged parameter (link)

References[edit]

  1. ^ https://raw.github.com/MagLev/maglev/master/Licenses/README.txt
  2. ^ https://www.igvita.com/2010/01/15/distributed-ruby-with-the-maglev-vm/
  3. ^ "Programming Guide for GemStone/S 64 Bit Version 1" (PDF), VMware, July 2012, retrieved July 29, 2012 CS1 maint: discouraged parameter (link)
  4. ^ "MagLev – Object Persistence with Ruby and Smalltalk" (PDF), Bachelor thesis, Hasso Plattner Institute, July 1, 2013, retrieved February 22, 2014 CS1 maint: discouraged parameter (link)
  5. ^ Phoenix, Evan (October 14, 2011), "Ruby, Concurrency, and You", Engine Yard Blog, retrieved July 29, 2012 CS1 maint: discouraged parameter (link)
  6. ^ http://www.rubyinside.com/maglev-alpha-released-2807.html
  7. ^ https://maglev.github.io/docs/get_started.html

External links[edit]