Overview
En esta guía puedes aprender cómo agregar Mongoid a una aplicación existente de Sinatra o Ruby on Rails (Rails). Para aprender a configurar una nueva aplicación que utilice Mongoid, consulta una de las siguientes guías:
Aplicación Sinatra
Para comenzar a utilizar Mongoid en una aplicación Sinatra existente, realice los siguientes pasos:
Agregar el
mongoiddependencia deGemfilede su aplicación.Crea un archivo de configuración
config/mongoid.ymly especifica tu objetivo de conexión, como se muestra en el paso Configura el Back End de la guía de Inicio Rápido.Cree un archivo de aplicación y cargue su archivo de configuración, como se muestra en el paso Ejecutar su aplicación de la Guía de inicio rápido.
Cree modelos de Mongoid para interactuar con sus datos.
Aplicación Rails
Puedes añadir Mongoid a una aplicación Rails existente para que se ejecute junto con otros adaptadores de Active Record. Para usar una combinación de adaptadores, puedes añadir la dependencia mongoid y completar el archivo de configuración con la información de tu conexión para empezar a usar MongoDB en tu aplicación.
Para adaptar una aplicación Rails existente y utilizar solamente Mongoid en lugar de Active Record, es necesario realizar otros cambios de configuración, como se describe en las siguientes secciones.
Modificar dependencias
Agrega la gema mongoid a los Gemfile de tu aplicación:
gem 'mongoid'
Para utilizar Mongoid como el único adaptador de base de datos, remueva o comente cualquier librería RDBMS mencionada en el Gemfile, como sqlite o pg.
Luego, instale las dependencias ejecutando el siguiente comando:
bundle install
Configuración de Mongoid
Genere la configuración predeterminada de Mongoid ejecutando el siguiente comando:
bin/rails g mongoid:config
Este generador crea el archivo de configuración config/mongoid.yml que se utiliza para configurar la conexión con la implementación de MongoDB y el archivo inicializador config/initializers/mongoid.rb que se puede utilizar para establecer otras opciones.
En el archivo config/mongoid.yml, especifique su cadena de conexión y otras opciones de conexión.
Modificar marcos
Abre el archivo config/application.rb y examina el contenido. Si el archivo utiliza la instrucción require "rails/all" para cargar todos los componentes de Rails, elimina esta instrucción. Debes añadir una declaración require separada para cada componente de Rails, como se muestra en el siguiente archivo de muestra config/application.rb:
# Remove or comment out rails/all #require "rails/all" # Add the following instead of rails/all: require "rails" # Comment out unneeded frameworks # require "active_record/railtie" rescue LoadError # require "active_storage/engine" rescue LoadError require "action_controller/railtie" rescue LoadError require "action_view/railtie" rescue LoadError require "action_mailer/railtie" rescue LoadError require "active_job/railtie" rescue LoadError require "action_cable/engine" rescue LoadError # require "action_mailbox/engine" rescue LoadError # require "action_text/engine" rescue LoadError require "rails/test_unit/railtie" rescue LoadError
Nota
Debido a que dependen de Active Record, las ActionText Los adaptadores ActiveStorage y ActionMailbox no se pueden utilizar junto con Mongoid.
Desactivar adaptadores de Active Record
En config/application.rb y en los otros archivos de configuración de tu aplicación, remueve o comenta cualquier referencia a config.active_record y config.active_storage.
Ajustar modelos
Para migrar de Active Record a Mongoid, debes ajustar los modelos existentes de tu aplicación.
Los modelos de registro activo se derivan de la clase ApplicationRecord y no tienen definiciones de columnas, mientras que los modelos Mongoid generalmente no tienen superclase pero deben incluir el atributo Mongoid::Document.
Al crear modelos Mongoid, puede definir campos de las siguientes maneras:
Define los campos explícitamente
Usa campos dinámicos
Por ejemplo, un modelo básico de Active Record Post puede parecerse a lo siguiente:
class Post < ApplicationRecord has_many :comments, dependent: :destroy end
Un modelo Mongoid Post similar podría parecerse al siguiente:
class Post include Mongoid::Document field :title, type: String field :body, type: String has_many :comments, dependent: :destroy end
En lugar de utilizar campos predefinidos, puedes definir el modelo Post utilizando campos dinámicos, como se muestra en el siguiente código:
class Post include Mongoid::Document include Mongoid::Attributes::Dynamic has_many :comments, dependent: :destroy end
Migración de datos
Si ya tienes datos en una base de datos relacional que deseas mover a MongoDB, debes realizar una migración de datos. No es necesario realizar una migración de esquema porque MongoDB no requiere un esquema predefinido para almacenar los datos.
Las herramientas de migración suelen ser específicas para los conjuntos de datos. Aunque Mongoid admite un superconjunto de asociaciones Active Record, las referencias de modelos se almacenan de forma diferente en las colecciones al utilizar Mongoid en comparación con Active Record.
Visita los siguientes recursos para obtener más información sobre la migración de un RDBMS a MongoDB:
Guía de migración de RDBMS a MongoDB en la documentación de AWS
Moderniza tus aplicaciones con MongoDB Atlas en el sitio web de MongoDB
API de Rails
El proceso para crear una aplicación de la API de Rails que use Mongoid es prácticamente el mismo que para crear una aplicación normal. La única diferencia es que debe agregar el indicador --api al ejecutar rails
new para crear la aplicación. La migración de una aplicación de la API de Rails a Mongoid sigue el mismo proceso descrito en las secciones anteriores.