|Initial release||April 2006|
|Stable release||4.1.2.005 / 11th Dec 2013|
|Operating system||Windows, Linux, Unix, Mac OS X|
|Available in||English, German|
Railo Server, commonly referred to as Railo (// raɪ-lo), is open source software which implements the general-purpose CFML server-side scripting language, often used to create dynamic websites, web applications and intranet systems. CFML is a dynamic language supporting multiple programming paradigms and runs on the Java Virtual Machine (JVM).
Railo was created by the Swiss company Railo Technologies GmbH, intended as a high performance alternative to Adobe ColdFusion. In 2008, Railo switched to an open source community-driven model, and became a JBoss project. The Railo Open Source project is led by Railo Technologies, with development work funded by consulting and support contracts, but anyone may contribute code for consideration.
Railo began in 2002 as a student project to compile CFML code into PHP, a choice made due to the ubiquity of PHP, however it was found that this did not give the desired performance and stability, and the decision was made to switch to the Java platform instead.
The project was successful enough that it was decided to continue to develop into a full product. Several alpha and beta releases were made before the official 1.0 release in April 2006. Railo continued to be developed but was relatively unknown to many CFML developers, until June 2008 at the Scotch on the Rocks conference in Edinburgh, when Railo Technologies used the Day 2 keynote to announce a partnership with JBoss and a switch to open source.
Railo was named after an alien dog in Star Trek Enterprise. The dog is actually named Rhylo, but written phonetically in German it is Railo. Thus, Railo can be pronounced either as rhy-lo or as rai-lo - both are acceptable.
Railo major releases have a codename of notable and loyal dogs from history.
|Red||Old release||No development|
|Yellow||Stable release||Security fixes|
|Green||Stable release||Bug and security fixes|
|Blue||Future release||New features|
|Minor version||Release date||Notes|
|0||Alpha 1||2004-04-10||The first official release of the Railo CFML engine.|
|Beta 1||2005-01-16||The first beta release of Railo.|
|RC1||2005-09-23||The first release candidate of Railo was presented to the German CFUG in Munich.|
|3.1.0.000||2009-08-12||First Open Source release of Railo.|
|3.3.1.000||2011-11-03||Added built-in support for ORM and many other features.|
|4.1.2.005||2013-12-11||Current stable release of Railo|
Platforms and license
Railo runs on the JVM as a servlet, and will work with any servlet container (e.g. Apache Tomcat, Eclipse Jetty) or application server (e.g. JBoss AS, GlassFish). It is possible to connect a web server (e.g. Apache, IIS, nginx, Cherokee) in front, using connectors such as mod jk, mod proxy, or equivalent, but this is not required by Railo.
A primary aim of Railo was to provide the functionality of ColdFusion using less resources and giving better performance, and the Railo Technologies team continue to "treat slowness as a bug" as a core development philosophy. Many performance tests have shown Railo to perform faster than other CFML engines.
In addition to this, Railo attempts to resolve many inconsistencies found in traditional CFML. These are either forced changes in behaviour, or configurable options in the Railo Administrator.
The Railo Technologies team have always been open to feedback and active at CFML community events, and are keen to remind people that Railo is a community project.
Railo Technologies also creates strong technology partnerships with CFML software companies, including Blue River Interactive Group (developers of Mura CMS), CONTENS Software GmbH (developers of CONTENS CMS), and Intergral GmbH (developers of FusionReactor and FusionDebug), to help ensure their software works well with Railo. In addition, Railo Technologies offer formal "Partner Programs" for Solutions (development), Hosting, and Training.
The Railo Application Server currently averages 7,000 downloads (and growing) per month.
Railo is used by a number of companies, notably including:
- Amtrak california (Californian rail company) 
- Apple Inc. (consumer electronics and software company) 
- DistroKid (Music publishing / distribution service, by Philip J. Kaplan)
- IDG Germany (publisher of Computer World, GameStar, PCWorld magazines) 
- Fandalism (social network for musicians, by Philip J. Kaplan)
- NASA Jet Propulsion Laboratory (center for the robotic exploration of space)
- The List (UK entertainment magazine) 
- RTL Group (Europe's second largest TV, radio, and production company)
- STV Player (Scottish video on-demand service) 
- Swisscom (A major telecommunications provider in Switzerland) 
- Supports object-oriented programming with inheritance, mixins and metaclasses
- Dynamic typing and duck typing
- Literal notation for arrays and structs
- Embedding variables in strings (interpolation)
- Named arguments, optional arguments, and default arguments
- Three levels of object variable scope: This (object public), Variables (object private), Local (function private)
- Multiple global variable scope: Request, Session, Client, Application, Server, Cluster
- Distinct user-provided variable scopes: Form (post), Url (get), Cookie, CGI
- Automatic garbage collection, (via JVM)
- Global and local exception handling, (via
- Custom dispatch behaviour (through
onMissingMethodand implicit getters and setters)
- Implicit object conversion (through
- Native threads
- Support for Unicode, multiple character encodings, and i18n
- Large standard library, covering common web development needs
- Railo Extension Store and Extension Manager for easy installation of additional software and extensions
- Native plug-in API in CFML or Java
- Native handling for easily creating and consuming web services
- Separate GUI Administrators for individual web contexts, plus a global server administrator
- All admin settings configurable programmatically, or via editing XML config files
- Native resources for all built-in filesystem tags and functions.
- Clustering and Synchronization for both traditional and cloud servers
- Task Manager for scheduling repeated actions, or re-trying failed events
- Native support for Hibernate ORM
- Large number of image manipulation functions
- Event Gateways for asynchronous code execution
- Native support for a variety of different caching mechanisms
- Native session management (CFML sessions or J2EE sessions) with
- Built-in user authentication and roles functionality.
CFML has built-in functionality for preventing code injection, via the
cfqueryparam tag, and functions such as
JsStringFormat. There are also third-party CFML implementations of the OWASP Enterprise Security API, and the AntiSamy project.
One of the key architecture decisions with Railo was to follow the JEE servlet model, with support for multiple independent web contexts on a single server. This is a key security factor, as it prevents unrelated applications from interfering with each other, as may happen on a shared ColdFusion server (which only has a single web context).
Differences from other languages
CFML has a tag-based syntax which is visually different from most other languages, though aside from this it is similar to other dynamic languages, with the following exceptions:
- CFML contains two syntaxes, a tag-based syntax (not XML compliant) and a C-style syntax called cfscript.
- Arrays in CFML are indexed from one, not from zero.
- CFML supports both ordered and named function arguments, or a combination.
- CFML does not have static variables.
Differences from Adobe ColdFusion
Whilst Railo implements CFML, and is generally compatible with Adobe ColdFusion (ACF), the original CFML engine, there are some notable differences between the two:
- Railo is Open Source LGPL v2.1 software. ACF is proprietary technology.
- Railo uses a multi web context architecture, compared to ACF's single web context.
- Railo allows you create "built-in" user-defined functions, using standard CFML.
- Railo is unable to decrypt (or execute) templates that have been encrypted with ACF's encryption mechanism.
- Railo has a significantly faster release cycle for major, minor, and patch releases.
- In Railo, scopes always take priority. In ACF, creating a variable named "Url" may block access to the Url scope. In Railo, the variable can only be accessed as "Variables.Url".
- Railo only searches for CFCs inside the custom tag path if defined accordingly in the administrator (it has a distinct CFC path instead).
- Railo 4.x introduces a command line interface (CLI) that allows executing CFML scripts from the command line
- Railo allows using object methods. So instead of using arrayAppend(arr, "value") one can write: arr.append("value").append("anotherValue").
- Adobe ColdFusion - the original CFML engine.
- Open BlueDragon - another Open Source CFML engine.
- CFML - the language Railo uses.
- Uses Railo-powered Mura CMS on http://www.amtrakcalifornia.com
- Uses Railo-powered Mura CMS internally.
- "Philip kaplan officially launches distrokid". techcrunch.com.
- Railo powers IDG's German websites, e.g. http://www.computerwoche.de
- "I have 404,772 users. Now what?". News.ycombinator.com. Retrieved 2012-11-08.
- "NASA achieves data goals for Mars rover with open source software". opensource.com. Retrieved 2012-11-08.
- Railo powers public website http://www.list.co.uk
- Uses Railo internally, also uses Railo-powered CONTENS CMS to generate public websites.
- Railo powers http://player.stv.tv service.
- Railo powers https://io.swisscom.ch service.