David Heinemeier Hansson extracted Ruby on Rails from his work on the project management toolBasecamp at theweb application company37signals.[8] Hansson first released Rails as open source in July 2004, but did not sharecommit rights to the project until February 2005.[citation needed] In August 2006, the framework reached a milestone whenApple announced that it would ship Ruby on Rails withMac OS X v10.5 "Leopard",[9] which was released in October 2007.
Rails version 2.3 was released on 15 March 2009, with major new developments in templates, engines,Rack and nested model forms. Templates enable the developer to generate a skeleton application with customgems and configurations. Engines give developers the ability to reuse application pieces complete with routes, view paths and models. The Rack web server interface and Metal allow one to write optimized pieces of code that route around Action Controller.[10]
On 23 December 2008,Merb, another web application framework, was launched, and Ruby on Rails announced it would work with the Merb project to bring "the best ideas of Merb" into Rails 3, ending the "unnecessary duplication" across both communities.[11] Merb was merged with Rails as part of the Rails 3.0 release.[12][13]
Rails 3.1 was released on 31 August 2011, featuring Reversible Database Migrations, Asset Pipeline, Streaming,jQuery as defaultJavaScript library and newly introducedCoffeeScript andSass into the stack.[14]
Rails 3.2 was released on 20 January 2012 with a faster development mode and routing engine (also known as Journey engine), Automatic Query Explain and Tagged Logging.[15] Rails 3.2.x is the last version that supports Ruby 1.8.7.[16] Rails 3.2.12 supports Ruby 2.0.[17]
Rails 4.0 was released on 25 June 2013, introducing Russian Doll Caching, Turbolinks, and Live Streaming as well as making Active Resource, Active Record Observer and other components optional by splitting them as gems.[18]
Rails 4.1 was released on 8 April 2014, introducing Spring, Variants, Enums, Mailer previews, and secrets.yml.[19]
Rails 4.2 was released on 19 December 2014, introducing Active Job, asynchronous emails, Adequate Record, Web Console, andforeign keys.[20]
Rails 5.0 was released on 30 June 2016, introducing Action Cable, API mode, and Turbolinks 5.[21]
Rails 5.0.0.1 was released on 10 August 2016, with Exclusive use of rails CLI over Rake and support for Ruby version 2.2.2 and above.
Rails 5.1 was released on 27 April 2017, introducingJavaScript integration changes (management of JavaScript dependencies from NPM via Yarn, optional compilation of JavaScript usingWebpack, and a rewrite of Rails UJS to use vanilla JavaScript instead of depending on jQuery), system tests usingCapybara, encrypted secrets, parameterized mailers, direct & resolved routes, and a unified form_with helper replacing the form_tag/form_for helpers.[22]
Rails 5.2 was released on 9 April 2018, introducing new features that include ActiveStorage, built-in Redis Cache Store, updated Rails Credentials and a new DSL that allows for configuring a Content Security Policy for an application.[23]
Rails 5.2.2 was released on 4 December 2018, introducing numerous bug fixes and several logic improvements.[24]
Rails 6.0 was released on 16 August 2019, making Webpack default, adding mailbox routing, a defaultonline rich-text editor, parallel testing, multiple database support, mailer routing and a new autoloader.[25]
Rails 6.1 was released on 9 December 2020, adding per-database connection switching,horizontal database sharding, eager loading of all associations, Delegated Types as an alternative to single-table inheritance, asynchronous deletion of associations, error objects, and other improvements and bug fixes.[26]
Rails 7.0 was released on 15 December 2021, replacingNode.js andWebpack with import maps for JavaScript management by default, replacing Turbolinks with a combination of Turbo and Stimulus, adding at-work encryption into Active Record, using Zeitwerk exclusively for code loading, and more.[27]
Rails 7.1 was released on 5 October 2023,Dockerfiles support using Kamal in order to deploy your application, authentication improvements, and now including support forbun.[28]
Ruby on Rails 8.0.0 was released on 8 November 2024. This major release introduces fundamental shifts in Rails development, enabling individual developers to host and manage their applications independently without the need for aPlatform-as-a-service. The update focuses on empowering single developers to handle all aspects of application deployment and management seamlessly.[29]
Ruby on Rails evolves radically from release to release exploring the use of new technologies and adopting new standards on the Internet. Some features are very stable in Ruby on Rails while some are replaced in favour of new techniques.
Themodel–view–controller (MVC) pattern is the fundamental structure to organize application programming.
In a default configuration, amodel in the Ruby on Rails framework maps to a table in a database and to a Ruby file. For example, a model classUser will usually be defined in the file 'user.rb' in the app/models directory, and linked to the table 'users' in the database. While developers are free to ignore this convention and choose differing names for their models, files, and database table, this is not common practice and is usually discouraged in accordance with the "convention-over-configuration" philosophy.[47]
Acontroller is a server-side component of Rails that responds to external requests from the web server to the application, by determining which view file to render. The controller may also have to query one or more models for information and pass these on to the view. For example, in an airline reservation system, a controller implementing a flight-search function would need to query a model representing individual flights to find flights matching the search, and might also need to query models representing airports and airlines to find related secondary data. The controller might then pass some subset of the flight data to the corresponding view, which would contain a mixture of static HTML and logic that use the flight data to create an HTML document containing a table with one row per flight. A controller may provide one or more actions. In Ruby on Rails, an action is typically a basic unit that describes how to respond to a specific external web-browser request. Also, note that the controller/action will be accessible for external web requests only if a corresponding route is mapped to it. Rails encourages developers to useRESTful routes, which include actions such as create, new, edit, update, destroy, show, and index. These mappings of incoming requests/routes to controller actions can be easily set up in the routes.rb configuration file.
Aview in the default configuration of Rails is anerb file, which is evaluated and converted toHTML at run-time. Alternatively, many other templating systems can be used for views.[citation needed]
Ruby on Rails includes tools that make common development tasks easier "out-of-the-box", such asscaffolding that can automatically construct some of the models and views needed for a basicwebsite.[48] Also included areWEBrick, a simple Ruby web server that is distributed with Ruby, andRake, a build system, distributed as agem. Together with Ruby on Rails, these tools provide a basic development environment.[citation needed]
Ruby on Rails is most commonly not connected to the Internet directly, but through some front-endweb server.Mongrel was generally preferred[by whom?] over WEBrick in the early days,[citation needed] but it can also run onLighttpd,Apache,Cherokee,Hiawatha,Nginx (either as a module –Phusion Passenger for example – or viaCGI,FastCGI ormod ruby), and many others. From 2008 onward, Passenger replaced Mongrel as the most-used web server for Ruby on Rails.[49] Ruby is also supported natively onIBM i.[50]
Ruby on Rails is also noteworthy for its extensive use of theJavaScript librariesPrototype andScript.aculo.us for scriptingAjax actions.[51] Ruby on Rails 3.0 separates the markup of the page (which defines the structure of the page) from scripting (which determines functionality or logic of the page). As of version 7.0, new Ruby on Rails applications come with theHotwire family of JavaScript libraries installed by default.
By default, the server usesEmbedded Ruby in the HTML views, with files having an html.erb extension. Rails supports swapping-in alternative templating languages, such asHAML andMustache.
Ruby on Rails is separated into various packages, namelyActiveRecord (anobject-relational mapping system for database access), Action Pack, Active Support and Action Mailer. Prior to version 2.0, Ruby on Rails also included the Action Web Service package that is now replaced by Active Resource. Apart from standard packages, developers can makeplugins to extend existing packages. Earlier Rails supported plugins within their own custom framework; version 3.2 deprecates these in favor of standard Ruby "gems".[53]
Ruby on Rails is often installed usingRubyGems, a package manager[54] which is included with current versions of Ruby. Many freeUnix-like systems also support installation of Ruby on Rails and its dependencies through their nativepackage management system.
Ruby on Rails is typically deployed with a database server such asMySQL orPostgreSQL, and a web server such asApache running thePhusion Passenger module.
The Rails Doctrine (rubyonrails.org/doctrine) is an enduring enabler that guides the philosophy, design, and implementation of the Ruby on Rails framework.
"Convention over Configuration" means a developer only needs to specify unconventional aspects of the application. For example, if there is a classSale in the model, the corresponding table in the database is calledsales by default. It is only if one deviates from this convention, such as calling the table "products sold", that the developer needs to write code regarding these names. Generally, Ruby on Rails conventions lead to less code and less repetition.[55]
"Don't repeat yourself" means that information is located in a single, unambiguous place. For example, using theActiveRecord module of Rails, the developer does not need to specify database column names in class definitions. Instead, Ruby on Rails can retrieve this information from the database based on the class name.
"Fat models, skinny controllers" means that most of the application logic should be placed within the model while leaving the controller as light as possible.
HTML Over The Wire (Hotwire),[56][57]Conceptual compression,[58][59] and robust security[60] mark Rails 7.0's approach to the One person framework.[a]
In March 2007,David Heinemeier Hansson applied to register three Ruby on Rails-relatedtrademarks with theUSPTO. These applications concern the phrase "RUBY ON RAILS",[62] the word "RAILS",[63] and the official Rails logo.[64] In the summer of 2007, Hansson denied the publisherApress permission to use the Ruby on Rails logo on the cover of a new Ruby on Rails book written by some authoritative community members. The episode gave rise to a polite protest in the Ruby on Rails community.[65][66] In response to this criticism, Hansson replied:
I only grant promotional use [of the Rails logo] for products I'm directly involved with. Such as books that I've been part of the development process for or conferences where I have a say in the execution. I would most definitely seek to enforce all the trademarks of Rails.[65]
The trademark of the logo was cancelled on 25 October 2019.[64]
In earlier days, Rails running onMatz's Ruby Interpreter (thede facto reference interpreter for Ruby) had been criticized for issues with scalability.[67] These critiques often mentioned variousTwitter outages in 2007 and 2008, which spurred Twitter's partial transition toScala (which runs on theJava Virtual Machine) for theirqueueing system and othermiddleware.[68][69] The user interface aspects of the site continued to run Ruby on Rails[70] until 2011 when it was replaced due to concerns over performance.[71] On the other hand, many Rails business application developers relied on system architecture design, including choices of database engine, cache configuration, and servers, to tackle scalability issues. The original author of Rails, David Heinemeier Hansson, criticized Twitter, saying that their problems scaling were the consequences of their own poor architectural decisions and not the fault of Rails. According to Hansson, blaming Rails for their troubles while making no contributions to the framework is ungrateful and unjust.[72]
In 2011,Gartner Research noted that despite criticisms and comparisons to Java, many high-profile consumer web firms are using Ruby on Rails to build scalable web applications. Some of the largest sites running Ruby on Rails includeAirbnb,Cookpad,GitHub,GitLab,[73]Scribd,Shopify, andBasecamp.[74] As of January 2016, it is estimated that more than 1.2 million web sites are running Ruby on Rails.[75][76]
In March 2012, security researcher Egor Homakov discovered amass assignment vulnerability that allowed certain Rails applications to be remotely exploited, and demonstrated it by non-maliciously hackingGitHub after his earlier attempts at responsible disclosure were dismissed.[77]
On 24 September 2013, a session cookie persistence security flaw was reported in Ruby on Rails. In a default configuration, the entire session hash is stored within a session cookie known asCookieStore, allowing any authenticated session possessing the session cookie to log in as the target user at any time in the future. As a workaround, administrators are advised to configure cookies to be stored on the server using mechanisms such asActiveRecordStore.[78]
Researchers Daniel Jackson and Joseph Near developed a data debugger they called "Space" that can analyze the data access of a Rails program and determine if the program properly adheres to rules regarding access restrictions. On 15 April 2016, Near reported that an analysis of 50 popular Web applications using Space uncovered 23 previously unknown security flaws.[79]
^David (29 August 2010)."Rails 3.0: It's ready!".weblog.rubyonrails.org.Archived from the original on 31 August 2010. Retrieved30 August 2010.Rails 3.0 has been designed to work with Ruby 1.8.7, Ruby 1.9.2, and JRuby 1.5.2+.
^"5 Question Interview with Twitter Developer Alex Payne". radicalbehavior.com. 29 March 2007. Archived fromthe original on 23 April 2009. Retrieved4 November 2014.By various metrics Twitter is the biggest Rails site on the net right now. Running on Rails has forced us to deal with scaling issues - issues that any growing site eventually contends with – far sooner than I think we would on another framework.
^Steve Jenson; Alex Payne & Robey Pointer interview (3 April 2009)."Twitter on Scala". artima.com.Archived from the original on 19 June 2009. Retrieved18 July 2009.We had a Ruby-based queuing system that we used for communicating between the Rails front ends and the daemons, and we ended up replacing that with one written in Scala. The Ruby one actually worked pretty decently in a normal steady state, but the startup time and the crash behavior were undesirable.
^"Twitter jilts Ruby for Scala". theregister.co.uk. 1 April 2009.Archived from the original on 12 August 2017. Retrieved18 July 2009.By the end of this year, Payne said, Twitter hopes to have its entire middleware infrastructure and its APIs ported to the new language. Ruby will remain, but only on the front end. "We're still happy with Rails for building user facing features... performance-wise, it's fine for people clicking around web pages. It's the heavy lifting, asynchronous processing type of stuff that we've moved away from."
^Ryan King (25 September 2009)."Twitter on Ruby". Evan Weaver.Archived from the original on 27 September 2009. Retrieved29 September 2009.We use Scala for a few things at Twitter, but the majority of the site is Ruby.