
vagrant init phusion/ubuntu-14.04-amd64 vagrant up vagrant ssh |
[codesyntax lang="bash"] # -*- mode: ruby -*- # vi: set ft=ruby : Vagrant.configure(2) do |config| config.vm.box = "phusion/ubuntu-14.04-amd64" config.vm.synced_folder ".", "/vagrant", :nfs => true config.vm.network :forwarded_port, guest: 80, host: 8080 config.vm.network :forwarded_port, guest: 3000, host: 3000 config.vm.network :forwarded_port, guest: 3001, host: 3001 config.vm.network :forwarded_port, guest: 3790, host: 3790 config.vm.network :private_network, ip: "10.0.0.100" config.vm.provider :vmware_fusion do |v| v.vmx["memsize"] = "1024" end end [/codesyntax] |
Eu uso o plugin de VMWare Fusion (que é ordens de grandeza mais estável e performático que o Virtualbox). Mas qualquer um funciona bem o suficiente pra desenvolver.
Depois de fazer vagrant ssh você vai estar dentro do Ubuntu já e a partir daí siga o seguinte:
sudo apt-get install curl build-essential openssl libreadline6 libreadline6-dev curl git-core zlib1g zlib1g-dev libssl-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt-dev autoconf libc6-dev ncurses-dev automake libtool bison subversion |
São os pacotes básicos que você sempre vai precisar. Feito isso, eu gosto de instalar o RVM mesmo:
curl -L https://get.rvm.io | bash -s stable source ~/.rvm/scripts/rvm |
O próximo passo é instalar pacotes que o RVM precisa para instalar novos Rubies. O próprio RVM toma conta disso fazendo o seguinte:
rvm requirements |
Isso já é suficiente para instalar o Ruby, para ver a lista de Rubies disponiveis basta executar:
rvm list known # para ver todos os rubies disponíveis rvm install 2.2.0 # para instalar o mais recente até a data deste artigo |
Isso já é suficiente para instalarmos o Rails mais recente e iniciar a programar:
gem install rails |
Não deixe de configurar o locale do seu sistema para UTF-8. Inicie adicionando as seguintes linhas ao seu /etc/bash.bashrc:
export LANGUAGE=en_US.UTF-8 export LANG=en_US.UTF-8 export LC_ALL=en_US.UTF-8 |
Então execute os seguintes comandos:
sudo locale-gen en_US.UTF-8 sudo dpkg-reconfigure locales |
Serviços Básicos Importantes
O que acabamos de instalar é o básico. Mas uma aplicação de verdade precisa de um pouco mais como bancos de dados e outros componentes. A maioria das aplicações Rails utilizar PostgreSQL, MySQL ou Redis (ou uma combinação de alguns deles). Além disso é recomendado aprender a utilizar Memcache.
Lembrando que precisamos instalar tanto os pacotes binários quanto os códigos-fonte/headers para as Rubygems conseguirem compilar suas extensões nativas.
Para começar, o melhor banco de dados relacional que você precisa instalar é o PostgreSQL:
sudo apt-get install postgresql postgresql-contrib postgresql-server-dev-9.3 |
Como estamos falando de uma máquina de desenvolvimento, vamos criar um superuser:
sudo su postgres createuser -P -s -e vagrant |
Você deve editar o arquivo pg_hba.conf com sudo vim /etc/postgresql/9.3/main/pg_hba.conf e faça o final dele estar assim:
[codesyntax lang="bash"] # Database administrative login by Unix domain socket local all postgres trust # TYPE DATABASE USER ADDRESS METHOD # "local" is for Unix domain socket connections only local all all trust # IPv4 local connections: host all all 127.0.0.1/32 trust # IPv6 local connections: host all all ::1/128 trust # Allow replication connections from localhost, by a user with the # replication privilege. #local replication postgres peer #host replication postgres 127.0.0.1/32 md5 #host replication postgres ::1/128 md5 [/codesyntax] |
Se vai desenvolver Rails eventualmente você vai precisar do Sidekiq ou Resque, e eles precisam do banco de dados Redis, então instale assim:
sudo apt-get install redis-server libhiredis-dev |
Você pode tirar muita vantagem de um bom cache em suas aplicações, então já deixe o Memcache preparado assim:
sudo apt-get install memcached libmemcached-dev |
Muitas aplicações precisam manipular imagens, e para isso você vai precisar do Imagemagick, então instale assim:
sudo apt-get install imagemagick libmagickwand-dev |
Instalando Vim
E um bom ambiente não estaria completo sem um bom editor de textos para começar a trabalhar. Existem muitas opções como o Sublime Text 2, mas minha preferência pessoal ainda é o Vim. Para quem nunca usou Vim, não deixe de assistir meu screencast Começando com Vim e para a discussão sobre qual melhor editor para você, não deixe de ler meu artigo IDEs e Editores, como escolher?. Para instalar neste novo Ubuntu é muito simples:
sudo apt-get install zsh vim vim-gnome exuberant-ctags ncurses-term ack-grep sudo dpkg-divert --local --divert /usr/bin/ack --rename --add /usr/bin/ack-grep sh -c "`curl -fsSL https://raw.githubusercontent.com/skwp/dotfiles/master/install.sh`" |
Isso vai instalar o excelente conjunto de dotfiles que configura ZSH e Vim pra ficarem perfeitos, o YADR. Pode ser que o ZSH não tenha sido instalado então para garantir faça o seguinte:
chsh -s $(which zsh) |
Toda vez que quiser atualizar o YADR, faça assim:
cd ~/.yadr git pull --rebase rake update |
Isso deve instalar todos os submódulos para tornar seu Vim um editor bastante avançado. Assista ao screencast para aprender mais e visite a página do projeto no Github. Muitas coisas mudaram desde que gravei o screencast, por exemplo, em vez do módulo Command-T agora uso o módulo Ctrl-P, dentre outras mudanças.
Se no meio da execução do comando git submodule ele parar por alguma razão, sem terminar, não tem problema apenas reexecute o mesmo comando. A partir do terminal, no diretório do seu projeto, execute gvim para iniciar o Vim integrado ao ambiente gráfico Gnome (há quem prefira usar dentro do Terminal, mas isso seria mais preferência pessoal mesmo).
Finalização do Ambiente
Se ainda não instalou, existem mais algumas ferramentas que você vai precisar:
sudo apt-get install git git-svn gitk ssh libssh-dev |
Novamente, se não sabe usar Git, assista meu screencast Começando com Gitpois é absolutamente obrigatório conhecer Git para programar no ecossistema Ruby e Rails.
Instalando Phusion Passenger
Com tudo instalado, podemos instalar o último componente: NGINX + Passenger:
Para instalar o Passenger com Nginx faça:
sudo apt-get install libcurl4-openssl-dev gem install passenger sudo chown -R `whoami` /opt passenger-install-nginx-module --auto-download --auto |
Quando ele terminar de instalar, você lembre-se que no arquivo/opt/nginx/conf/nginx.conf haverá o seguinte:
http { ... passenger_root /home/akitaonrails/.rvm/gems/ruby-2.2.0/gems/passenger-4.0.58; passenger_ruby /home/akitaonrails/.rvm/wrappers/ruby-2.2.2.0/ruby; ... } |
Sempre que atualizar o passenger, atualize este trecho com a versão mais recente. Além disso, para configurar novas aplicações Rails, no mesmo arquivo configure da seguinte forma:
server { listen 80; server_name www.yourhost.com; root /somewhere/public; # <--- be sure to point to 'public'! passenger_enabled on; } |
Onde /somewhere é onde está o código da aplicação Rails, sempre completando com /public para o Passenger saber o que fazer.
Na instalação eu trapeceei um pouco: como instalei o RVM em single-mode não dá para instalar o nginx usando o script do Passenger via sudo. Por isso mudei o dono do diretório /opt. Precisamos mudar de volta:
sudo chown -R root /opt |
Agora queremos que o NGINX inicie automaticamente sempre que o servidor reiniciar, para isso podemos usar da ajuda do script de inicialização feito pelo Linode:
wget -O init-deb.sh http://library.linode.com/assets/660-init-deb.sh sudo mv init-deb.sh /etc/init.d/nginx sudo chmod +x /etc/init.d/nginx sudo /usr/sbin/update-rc.d -f nginx defaults |
obs: dica retirada deste blog post
Inicie ou pare o NGINX como qualquer outro serviço no Ubuntu:
sudo service nginx start sudo service nginx stop sudo service nginx restart |
Ambiente configurado, bom aprendizado!
Artigo publicado originalmente em www.akitaonrails.com