En este tutorial configuraremos un entorno de desarrollo Ruby on Rails en macOS 10.14 Mojave.
Instalando Homebrew
Lo primero que debemos tener instalado Homebrew, lo cual ya explicamos anteriormente aquí
Instalando Ruby
Ahora que tenemos instalado Homebrew, podemos usarlo para instalar Ruby.
Vamos a usar rbenv para instalar y administrar nuestras versiones de Ruby.
Para hacer esto, ejecuta los siguientes comandos en tu Terminal:
brew install rbenv ruby-build
# Agrega rbenv a bash para que se cargue cada vez que abra una terminal
echo 'if which rbenv > /dev/null; then eval "$(rbenv init -)"; fi' >> ~/.bash_profile
source ~/.bash_profile
# O si tienes zsh
echo 'if which rbenv > /dev/null; then eval "$(rbenv init -)"; fi' >> ~/.zshrc
source ~/.zshrc
# Instalar Ruby
rbenv install 2.6.3
rbenv global 2.6.3
ruby -vInstalando Rails
Instalar Rails es tan simple como ejecutar el siguiente comando en la Terminal:
gem install rails -v 6.0.0.rc1Rails ahora está instalado, pero para que podamos usar el ejecutable de rails, necesitamos decirle a rbenv que lo vea:
rbenv rehashY ahora podemos verificar que Rails está instalado:
rails -v
# Rails 6.0.0.rc1Configurar una base de datos
Vamos a instalar sqlite3 desde homebrew porque no podemos usar la versión integrada con macOS sin tener algunos problemas.
brew install sqlite3Rails usa sqlite3 como la base de datos predeterminada. Lo más probable es que no quierasusarlo porque está almacenado como un archivo simple en el disco. Probablemente quieras algo más robusto como MySQL o PostgreSQL.
Hay mucha documentación sobre ambos, por lo que puede elegir uno con el que se sienta más cómodo. Si viene de PHP, es posible que ya esté familiarizado con MySQL. Si eres nuevo en las bases de datos, te sugiero que saltes a configurar PostgreSQL.
MySQL
Puedes instalar el servidor MySQL y el cliente desde Homebrew:
brew install mysqlUna vez que este comando haya terminado, le da un par de comandos para ejecutar. Siga las instrucciones y ejecútelas:
# mysql se ejecutará al iniciar sesión:
brew services start mysqlPor defecto, el usuario mysql es root sin contraseña. Cuando haya terminado, puede saltar a los Pasos finales.
PostgreSQL
Puedes instalar el servidor y el cliente de PostgreSQL desde Homebrew:
brew install postgresqlUna vez que este comando haya terminado, le da un par de comandos para ejecutar. Siga las instrucciones y ejecútelas:
# postgresql se ejecutará al iniciar sesión:
brew services start postgresqlPor defecto, el usuario postgresql es su nombre de usuario OS X actual sin contraseña. Por ejemplo, mi usuario de OS X es lavaldi, por lo que puedo iniciar sesión en postgresql con ese nombre de usuario.
Pasos finales
Mojave cambió la ubicación de los archivos de encabezado necesarios para compilar extensiones C. Es posible que debas ejecutar el siguiente comando para instalar pg u otras gemas que requieren extensiones C:
sudo installer -pkg /Library/Developer/CommandLineTools/Packages/macOS_SDK_headers_for_macOS_10.14.pkg -target /Y ahora, el momento de la verdad. Creemos su primera aplicación Rails:
rails new myapp
#### Si usas MySQL
rails new myapp -d mysql
#### Si usas Postgres
# Ten en cuenta que deberás cambiar el nombre de usuario en config/database.yml para que sea
# el mismo que su cuenta de usuario OSX. (por ejemplo, el mío es 'lavaldi')
rails new myapp -d postgresql
# Ingresa al directorio de la aplicación
cd myapp
# Si configura MySQL o Postgres con un nombre de usuario/contraseña, modifique el
# archivo config/database.yml para que contenga el nombre de usuario/contraseña que especificó
# Crear la BD
rake db:create
rails server¡Ahora puedes ir a http://localhost:3000 para ver tu nuevo sitio web!
Ahora que tienes la configuración de tu máquina, es hora de comenzar a construir algunas aplicaciones Rails.
Si recibiste un error que decía Access denied for user 'root'@'localhost' (using password: NO), entonces necesitas actualizar el archivo config/database.yml para que coincida con el nombre de usuario y la contraseña de la base de datos 😉