Ruby on Rails
Rails is a hugely popular web development framework, implemented in Ruby.
The first version of Rails was released back in 2004. Embodying the idea of “convention over configuration” it grew rapidly, attracting followers who had become weary of repeating the mundane tasks required by other frameworks. Combined with the highly dynamic nature of the Ruby programming language, the Rails conventions made for a very productive development environment.
Rails Resources
There is a plethora of useful documentation, tutorials and blogs for you to read, but these sites stand out as being worthy of note:
- Railscasts – regular screencasts from Ryan Bates demonstrating how to achieve specific tasks in Rails.
- Railsbrain – JavaScript enhanced copies of the Rails API (to be viewed online or downloaded to your computer).
- News from the edge of Rails – Rails moves fast, and Ryan Daigle’s blog is a great way to keep up with the latest developments.
-
Merb
After the 1.x release Rails continued to improve and the code base grew. Some missed the simplicity of the early versions and several other similar Ruby frameworks were born. Merb was arguably the most obvious direct competitor to Rails. The Merb project has since merged with Rails and many of Merb’s design decisions have been incorporated into Rails 3.
Articles on Ruby on Rails
-
Finding performance problems
20 November 2009A user recently reported poor performance on one of our Rails apps. I pulled up New Relic’s performance graphs and checked what was happening around the time that we received the email. Sure enough there was a massive spike over a 10 minute period in the time taken to serve a request.
-
Testing Rails with Rack::Test
12 June 2009The biggest news in Rails 2.3 is its support for Rack, the WSGI inspired Ruby web server interface. Of all the Rack goodness that has come along lately, the one that has me the most excited is Bryan Helmkamp’s Rack::Test library, of which Bryan said “Basically, I extracted Merb’s request helper code into a small, reusable, framework agnostic library.”
-
Sharing CSS between Rails and PHP
01 March 2009Many web sites are built using a variety of web applications, using different web frameworks. These sub sites share the same branding and ought to re-use the same CSS and images. How do you re-use these files within your Rails application, without the maintenance overhead of copying and pasting the code into each new application?
-
Configure the Expires header for Rails under nginx
13 September 2008The images, CSS and JavaScript files served up by your Rails application can usually be cached by the web browser, rather than being downloaded (or checked) every time the browser loads a page on your site. For a properly configured site the net effect is faster page load times and a vastly improved user experience. Rails gives you some help here, but it doesn’t happen automatically – you need to configure your web server to set the HTTP Expires header. This article explains how to configure the expires header for a Rails application running behind the nginx HTTP proxy server.
-
database.yml should be checked in
24 May 2008It’s generally acknowledged to be good practice to keep your production
database.ymlfile away from your version control system. Why? So that people snooping around your version control system don’t find your database password. There are plenty of examples out there that tell you how to set your production password with Capistrano, but I’m talking about thedatabase.ymlfile used during development. -
Easy git-svn for Rails (or "git-me-up")
24 April 2008I’ve been trying to persuade
git-svnto work properly with Rails plugins that are installed viasvn:externals. Whilst working out how to do it I stumbled across several great articles, but I couldn’t get any of the solutions presented to work perfectly.After a bit of head scratching I got it sorted, and wrapped the process up in a little utility called git-me-up.
-
Monitoring BackgrounDRb with God
08 April 2008God is a very neat piece of software, frequently used by Rails developers to monitor mongrel servers, and restart them if/when they crash or use up too many system resources.
Its use isn’t limited purely to monitoring web servers though; you can monitor pretty much anything you like. Read on to see how to configure it to monitor the Ruby job processing daemon, BackgrounDRb.