Ruby on Rails (simplificado como Rails ) es un marco de aplicación web del lado del servidor escrito en Ruby bajo la licencia MIT . Rails es un marco de modelo-vista-controlador (MVC) que proporciona estructuras predeterminadas para una base de datos , un servicio web y páginas web . Fomenta y facilita el uso de estándares web como JSON o XML para la transferencia de datos y HTML , CSS y JavaScript para la interfaz de usuario. Además de MVC, Rails enfatiza el uso de otros patrones y paradigmas de ingeniería de software bien conocidos , incluida la convención sobre configuración (CoC), no repetirse (DRY) y el patrón de registro activo . [4]
La aparición de Ruby on Rails en 2005 influyó enormemente en el desarrollo de aplicaciones web, a través de características innovadoras como la creación fluida de tablas de bases de datos , migraciones y andamios de vistas para permitir un desarrollo rápido de aplicaciones. La influencia de Ruby on Rails en otros frameworks web sigue siendo evidente hoy en día, con muchos frameworks en otros lenguajes tomando prestadas sus ideas, incluido Django en Python ; Catalizador en Perl ; Laravel , CakePHP y Yii en PHP ; Griales en Groovy ; Fénix en Elixir ; Juega en Scala ; y Sails.js en Node.js.
Los sitios conocidos que utilizan Ruby on Rails incluyen Airbnb , Crunchbase , Dribbble , [5] GitHub , [6] Twitch [7] y Shopify .
David Heinemeier Hansson extrajo Ruby on Rails de su trabajo en la herramienta de gestión de proyectos Basecamp en la empresa de aplicaciones web 37signals . [8] Hansson lanzó Rails por primera vez como código abierto en julio de 2004, pero no compartió los derechos de compromiso del proyecto hasta febrero de 2005. [ cita necesaria ] En agosto de 2006, el marco alcanzó un hito cuando Apple anunció que enviaría Ruby on Rails. con Mac OS X v10.5 "Leopard" , [9] que fue lanzado en octubre de 2007.
La versión 2.3 de Rails se lanzó el 15 de marzo de 2009, con importantes novedades en plantillas, motores, bastidores y formas de modelos anidados. Las plantillas permiten al desarrollador generar una aplicación esqueleto con gemas y configuraciones personalizadas. Los motores brindan a los desarrolladores la capacidad de reutilizar piezas de aplicaciones completas con rutas, ver rutas y modelos. La interfaz del servidor web Rack y Metal permiten escribir piezas de código optimizadas que se enrutan alrededor de Action Controller. [10]
El 23 de diciembre de 2008, se lanzó Merb , otro marco de aplicaciones web, y Ruby on Rails anunció que trabajaría con el proyecto Merb para llevar "las mejores ideas de Merb" a Rails 3, poniendo fin a la "duplicación innecesaria" en ambas comunidades. . [11] Merb se fusionó con Rails como parte de la versión Rails 3.0. [12] [13]
Rails 3.1 se lanzó el 31 de agosto de 2011 e incluye migraciones de bases de datos reversibles, Asset Pipeline, Streaming, jQuery como biblioteca JavaScript predeterminada y CoffeeScript y Sass recientemente introducidos en la pila. [14]
Rails 3.2 se lanzó el 20 de enero de 2012 con un modo de desarrollo más rápido y un motor de enrutamiento (también conocido como motor Journey), explicación automática de consultas y registro etiquetado. [15] Rails 3.2.x es la última versión que admite Ruby 1.8.7. [16] Rails 3.2.12 es compatible con Ruby 2.0. [17]
Rails 4.0 se lanzó el 25 de junio de 2013, presentando Russian Doll Caching, Turbolinks, Live Streaming, además de hacer que Active Resource, Active Record Observer y otros componentes sean opcionales dividiéndolos como gemas. [18]
Rails 4.1 se lanzó el 8 de abril de 2014 y presenta Spring, Variants, Enums, vistas previas de Mailer y secrets.yml. [19]
Rails 4.2 se lanzó el 19 de diciembre de 2014 e incluye Active Job, correos electrónicos asincrónicos, Adequate Record, Web Console y claves externas . [20]
Rails 5.0 se lanzó el 30 de junio de 2016 y presenta Action Cable, modo API y Turbolinks 5. [21]
Rails 5.0.0.1 se lanzó el 10 de agosto de 2016, con uso exclusivo de Rails CLI sobre Rake y soporte para Ruby versión 2.2.2 y superiores.
Rails 5.1 se lanzó el 27 de abril de 2017, introduciendo cambios en la integración de JavaScript (administración de dependencias de JavaScript desde NPM a través de Yarn, compilación opcional de JavaScript usando Webpack y una reescritura de Rails UJS para usar JavaScript básico en lugar de depender de jQuery), pruebas del sistema usando Capybara , secretos cifrados, correos publicitarios parametrizados, rutas directas y resueltas, y un formulario unificado con ayudante que reemplaza form_tag/form_for ayudantes. [22]
Rails 5.2 se lanzó el 9 de abril de 2018 e introduce nuevas funciones que incluyen ActiveStorage, Redis Cache Store integrado, credenciales Rails actualizadas y un nuevo DSL que permite configurar una política de seguridad de contenido para una aplicación. [23]
Rails 5.2.2 se lanzó el 4 de diciembre de 2018 e introdujo numerosas correcciones de errores y varias mejoras lógicas. [24]
Rails 6.0 se lanzó el 16 de agosto de 2019, haciendo que Webpack sea el predeterminado, agregando enrutamiento de buzones de correo, un editor de texto enriquecido en línea predeterminado , pruebas paralelas, soporte para múltiples bases de datos, enrutamiento de correo y un nuevo cargador automático. [25]
Rails 6.1 se lanzó el 9 de diciembre de 2020 y agregó conmutación de conexión por base de datos, fragmentación horizontal de la base de datos , carga inmediata de todas las asociaciones, tipos delegados como alternativa a la herencia de una sola tabla, eliminación asincrónica de asociaciones, objetos de error y otras mejoras. corrección de errores. [26]
Rails 7.0 se lanzó el 15 de diciembre de 2021, reemplazando Node.js y Webpack con mapas de importación para la administración de JavaScript de forma predeterminada, reemplazando Turbolinks con una combinación de Turbo y Stimulus, agregando cifrado en el trabajo en Active Record y usando Zeitwerk exclusivamente para la carga de código. , y más. [27]
Rails 7.1 se lanzó el 5 de octubre de 2023, Dockerfiles admite el uso de Kamal para implementar su aplicación, mejoras de autenticación y ahora incluye soporte para bun . [28]
Ruby on Rails evoluciona radicalmente de un lanzamiento a otro explorando el uso de nuevas tecnologías y adoptando nuevos estándares en Internet. Algunas características son muy estables en Ruby on Rails, mientras que otras se reemplazan por nuevas técnicas.
El patrón modelo-vista-controlador (MVC) es la estructura fundamental para organizar la programación de aplicaciones.
En una configuración predeterminada, un modelo en el marco de Ruby on Rails se asigna a una tabla en una base de datos y a un archivo Ruby. Por ejemplo, una clase de modelo Usuario generalmente se definirá en el archivo 'user.rb' en el directorio app/models y se vinculará a la tabla 'users' en la base de datos. Si bien los desarrolladores son libres de ignorar esta convención y elegir nombres diferentes para sus modelos, archivos y tablas de bases de datos, esto no es una práctica común y generalmente se desaconseja de acuerdo con la filosofía de " convención sobre configuración ".
Un controlador es un componente del lado del servidor de Rails que responde a solicitudes externas del servidor web a la aplicación, determinando qué archivo de vista representar. Es posible que el controlador también tenga que consultar uno o más modelos para obtener información y pasarla a la vista. Por ejemplo, en un sistema de reservas de aerolíneas, un controlador que implemente una función de búsqueda de vuelos necesitaría consultar un modelo que represente vuelos individuales para encontrar vuelos que coincidan con la búsqueda, y también podría necesitar consultar modelos que representen aeropuertos y aerolíneas para encontrar datos secundarios relacionados. Luego, el controlador podría pasar algún subconjunto de los datos del vuelo a la vista correspondiente, que contendría una mezcla de HTML estático y lógica que utiliza los datos del vuelo para crear un documento HTML que contiene una tabla con una fila por vuelo. Un controlador puede proporcionar una o más acciones. En Ruby on Rails, una acción suele ser una unidad básica que describe cómo responder a una solicitud externa específica del navegador web. Además, tenga en cuenta que el controlador/acción será accesible para solicitudes web externas solo si se le asigna una ruta correspondiente. Rails anima a los desarrolladores a utilizar rutas RESTful , que incluyen acciones como crear, crear, editar, actualizar, destruir, mostrar e indexar. Estas asignaciones de solicitudes/rutas entrantes a acciones del controlador se pueden configurar fácilmente en el archivo de configuración route.rb.
Una vista en la configuración predeterminada de Rails es un archivo erb , que se evalúa y convierte a HTML en tiempo de ejecución. Alternativamente, se pueden utilizar muchos otros sistemas de plantillas para las vistas.
Ruby on Rails incluye herramientas que facilitan las tareas de desarrollo comunes "listas para usar", como andamios que pueden construir automáticamente algunos de los modelos y vistas necesarios para un sitio web básico . [48] También se incluyen WEBrick , un servidor web Ruby simple que se distribuye con Ruby, y Rake , un sistema de compilación, distribuido como una gema . Junto con Ruby on Rails, estas herramientas proporcionan un entorno de desarrollo básico.
Ruby on Rails normalmente no está conectado directamente a Internet, sino a través de algún servidor web front-end . En general , el mestizo era el preferido [ ¿por quién? ] sobre WEBrick en los primeros días, [ cita necesaria ] pero también puede ejecutarse en Lighttpd , Apache , Cherokee , Hiawatha , Nginx (ya sea como un módulo, Phusion Passenger , por ejemplo, o mediante CGI , FastCGI o mod ruby ), y muchos otros. A partir de 2008, Passenger reemplazó a Mongrel como el servidor web más utilizado para Ruby on Rails. [49] Ruby también es compatible de forma nativa con IBM i . [50]
Ruby on Rails también destaca por su uso extensivo de las bibliotecas JavaScript Prototype y Script.aculo.us para programar acciones Ajax . [51] Ruby on Rails inicialmente utilizó SOAP ligero para servicios web; esto fue posteriormente reemplazado por servicios web RESTful . Ruby on Rails 3.0 separa el marcado de la página (que define la estructura de la página) de las secuencias de comandos (que determinan la funcionalidad o la lógica de la página).
Desde la versión 2.0, Ruby on Rails ofrece HTML y XML como formatos de salida estándar. Este último es la instalación para servicios web RESTful.
Rails 3.1 introdujo Sass como plantilla CSS estándar .
De forma predeterminada, el servidor utiliza Embedded Ruby en las vistas HTML, con archivos que tienen una extensión html.erb. Rails admite el intercambio de lenguajes de plantillas alternativos, como HAML y Moustache .
Ruby on Rails 3.0 ha sido diseñado para funcionar con Ruby 1.8.7, Ruby 1.9.2 y JRuby 1.5.2+; Las versiones anteriores no son compatibles. [52]
Ruby on Rails 3.2 es la última serie de versiones que admiten Ruby 1.8.7.
Ruby on Rails se divide en varios paquetes, a saber, ActiveRecord (un sistema de mapeo relacional de objetos para acceso a bases de datos), Action Pack, Active Support y Action Mailer. Antes de la versión 2.0, Ruby on Rails también incluía el paquete Action Web Service que ahora es reemplazado por Active Resource. Además de los paquetes estándar, los desarrolladores pueden crear complementos para ampliar los paquetes existentes. Los Rails anteriores admitían complementos dentro de su propio marco personalizado; La versión 3.2 los desaprueba en favor de las "gemas" estándar de Ruby. [53]
Ruby on Rails a menudo se instala usando RubyGems , un administrador de paquetes [54] que se incluye con las versiones actuales de Ruby. Muchos sistemas gratuitos tipo Unix también admiten la instalación de Ruby on Rails y sus dependencias a través de su sistema de gestión de paquetes nativo .
Ruby on Rails normalmente se implementa con un servidor de base de datos como MySQL o PostgreSQL y un servidor web como Apache que ejecuta el módulo Phusion Passenger .
Ruby on Rails pretende enfatizar la Convención sobre la Configuración (CoC) y el principio No repetirse (DRY).
La Doctrina Rails es un habilitador duradero que guía la filosofía, el diseño y la implementación del marco Ruby on Rails.
"Convención sobre configuración" significa que un desarrollador sólo necesita especificar aspectos no convencionales de la aplicación. Por ejemplo, si hay una clase Venta en el modelo, la tabla correspondiente en la base de datos se llama ventas de forma predeterminada. Sólo si uno se desvía de esta convención, como llamar a la tabla "productos vendidos", el desarrollador necesita escribir código con respecto a estos nombres. Generalmente, las convenciones de Ruby on Rails generan menos código y menos repetición. [55]
"No te repitas" significa que la información está ubicada en un lugar único e inequívoco. Por ejemplo, al utilizar el módulo ActiveRecord de Rails, el desarrollador no necesita especificar los nombres de las columnas de la base de datos en las definiciones de clases. En cambio, Ruby on Rails puede recuperar esta información de la base de datos según el nombre de la clase.
"Modelos gordos, controladores delgados" significa que la mayor parte de la lógica de la aplicación debe colocarse dentro del modelo dejando el controlador lo más liviano posible.
HTML Over The Wire (Hotwire), [56] [57] Compresión conceptual, [58] [59] y seguridad sólida [60] marcan el enfoque de Rails 7.0 hacia el marco de una sola persona. [a]
En marzo de 2007, David Heinemeier Hansson solicitó registrar tres marcas comerciales relacionadas con Ruby on Rails ante la USPTO . Estas solicitudes se refieren a la frase "RUBY ON RAILS", [62] la palabra "RAILS", [63] y el logotipo oficial de Rails. [64] En el verano de 2007, Hansson negó al editor Apress el permiso para usar el logotipo de Ruby on Rails en la portada de un nuevo libro de Ruby on Rails escrito por algunos miembros autorizados de la comunidad. El episodio dio lugar a una educada protesta en la comunidad de Ruby on Rails. [65] [66] En respuesta a esta crítica, Hansson respondió:
Sólo concedo uso promocional [del logotipo de Rails] para productos con los que estoy directamente involucrado. Como libros en los que he formado parte del proceso de desarrollo o conferencias en las que tengo voz y voto en la ejecución. Definitivamente buscaría hacer cumplir todas las marcas comerciales de Rails. [sesenta y cinco]
La marca del logo fue cancelada el 25 de octubre de 2019. [64]
En días anteriores, Rails ejecutándose en Ruby Interpreter de Matz (el intérprete de referencia de facto para Ruby) había sido criticado por problemas de escalabilidad. [67] Estos críticos mencionaron a menudo varias interrupciones de Twitter en 2007 y 2008, que estimularon la transición parcial de Twitter a Scala (que se ejecuta en la máquina virtual Java ) para su sistema de colas y otro middleware . [68] [69] Los aspectos de la interfaz de usuario del sitio continuaron ejecutando Ruby on Rails [70] hasta 2011, cuando fue reemplazado debido a preocupaciones sobre el rendimiento. [71] Por otro lado, muchos desarrolladores de aplicaciones empresariales Rails confiaron en el diseño de la arquitectura del sistema, incluidas las opciones de motor de base de datos, configuración de caché y servidores, para abordar los problemas de escalabilidad. El autor original de Rails, David Heinemeier Hansson, criticó a Twitter, diciendo que sus problemas de escala eran consecuencia de sus propias malas decisiones arquitectónicas y no culpa de Rails. Según Hansson, culpar a Rails por sus problemas sin hacer ninguna contribución al marco es ingrato e injusto. [72]
En 2011, Gartner Research señaló que a pesar de las críticas y comparaciones con Java, muchas empresas web de consumo de alto perfil están utilizando Ruby on Rails para crear aplicaciones web escalables. Algunos de los sitios más grandes que ejecutan Ruby on Rails incluyen Airbnb , Cookpad , GitHub , GitLab , [73] Scribd , Shopify y Basecamp . [74] En enero de 2016, se estima que más de 1,2 millones de sitios web ejecutan Ruby on Rails. [75] [76]
En marzo de 2012, el investigador de seguridad Egor Homakov descubrió una vulnerabilidad de asignación masiva que permitía explotar remotamente ciertas aplicaciones Rails, y lo demostró pirateando GitHub de forma no maliciosa después de que sus intentos anteriores de divulgación responsable fueran descartados. [77]
El 24 de septiembre de 2013, se informó de una falla de seguridad en la persistencia de las cookies de sesión en Ruby on Rails. En una configuración predeterminada, el hash completo de la sesión se almacena dentro de una cookie de sesión conocida como CookieStore , lo que permite que cualquier sesión autenticada que posea la cookie de sesión inicie sesión como el usuario objetivo en cualquier momento en el futuro. Como solución alternativa, se recomienda a los administradores configurar las cookies para que se almacenen en el servidor mediante mecanismos como ActiveRecordStore . [78]
Los investigadores Daniel Jackson y Joseph Near desarrollaron un depurador de datos al que llamaron "Space" que puede analizar el acceso a los datos de un programa Rails y determinar si el programa cumple adecuadamente con las reglas relativas a las restricciones de acceso. El 15 de abril de 2016, Near informó que un análisis de 50 aplicaciones web populares que utilizaban Space descubrió 23 fallas de seguridad previamente desconocidas. [79]
Rails 3.0 ha sido diseñado para funcionar con Ruby 1.8.7, Ruby 1.9.2 y JRuby 1.5.2+.
Según varias métricas, Twitter es el sitio Rails más grande de la red en este momento.
La ejecución sobre Rails nos ha obligado a lidiar con problemas de escala (problemas con los que eventualmente se enfrenta cualquier sitio en crecimiento) mucho antes de lo que creo que lo haríamos en otro marco.
Teníamos un sistema de colas basado en Ruby que usábamos para comunicarnos entre las interfaces de Rails y los demonios, y terminamos reemplazándolo por uno escrito en Scala.
El Ruby en realidad funcionó bastante decentemente en un estado estable normal, pero el tiempo de inicio y el comportamiento de falla no fueron deseables.
Para finales de este año, dijo Payne, Twitter espera tener toda su infraestructura de middleware y sus API trasladadas al nuevo lenguaje.
Ruby permanecerá, pero sólo en la parte delantera.
"Todavía estamos contentos con Rails para crear funciones orientadas al usuario... en cuanto al rendimiento, está bien para las personas que hacen clic en las páginas web. Es el tipo de cosas de procesamiento asincrónico y de trabajo pesado de las que nos hemos alejado".
Usamos Scala para algunas cosas en Twitter, pero la mayor parte del sitio es Ruby.