iT邦幫忙

2017 iT 邦幫忙鐵人賽
DAY 3
1
Modern Web

為你自己學 Ruby on Rails系列 第 3

第 02 章 - 環境設定

  • 分享至 

  • xImage
  •  

本系列文章內容同步發佈於這裡,若有任何問題或錯誤,都歡迎直接到 GitHub 上發 PR 修正,或是在這裡留言討論。


http://ithelp.ithome.com.tw/upload/images/20161218/20065770kjvJGXkD7D.jpg
photo by SilentMode

環境設定

要開始用 Ruby 或 Rails 來開發網站之前,第一件事(其實可能也是最難的事?)就是要先搞定開發環境。

安裝 Ruby

Unix/Linux 作業系統

如果您使用的是 Ubuntu 之類的系統,可以直接使用 apt-get 來安裝 Ruby:

$ sudo apt-get install ruby

如果是 CentOS 之類的系統,則是使用 yum 來安裝:

$ sudo yum install ruby

因為使用了 sudo 指令,所以你應該會被提示需要輸入目前的登入密碼。

Mac 作業系統

如果是 Mac 作業系統,比較新的版本均已內建 Ruby 2.0 版本,如果沒有的話,建議可使用 Homebrew 這個套件管理工具來安裝 Ruby:

$ brew install ruby

Windows 作業系統

在 Windows 平台可根據您的需求,選擇安裝 Ruby InstallerRails Installer,基本上 Rails Installer 跟 Ruby Installer 沒太大的差別,只是後者多加入了 Rails 開發的相關工具(例如 Git、Bundler 等):

其它系統

更多其它平台的安裝方式,或是想要直接下載原始碼自行編譯,請參閱 Ruby 官方網站的安裝說明。

用 RVM 來管理 Ruby 版本

Ruby 有許多的版本(1.8/1.9/2.0/2.1/2.2/2.3)以及眾多的分支實作品(例如 JRuby/IronRuby/Rubinius/Macruby/mruby 等),算一算有不少排列組合,如果想要在自己機器上安裝不同版本會有點麻煩,而且萬一亂裝把工作環境弄壞了還得花時間重建。如果是要裝在伺服器上,如果你不是系統管理員,還不一定有足夠的權限可以安裝。使用 VirtualBox 的軟體可以來模擬作業環境,玩壞了隨時都可以很快的還原或重建一個新的,即使這樣還是有點麻煩。

如果各位跟我一樣都喜歡玩些新玩具,但又擔心環境被弄髒弄壞,推薦大家可以試試 RVM (Ruby Version Manager)。有 RVM 的幫忙,你可以安心的在你的電腦裡同時安裝多個不同版本的 Ruby/Rails 而不會搞混,隨時都可以輕鬆的切換。

RVM 是把程式安裝在你的的個人帳號目錄下,不需要的時候就整個 ~/.rvm 資料夾刪除就行了,不會影響原來系統的設定。也就是因為 RVM 是安裝在你的個人帳號底下,所以你在安裝過程中不需要管理者(root)的權限就可以安裝其它相關的套件。

安裝 RVM

RVM 的安裝滿簡單的,只要二行指令即可完成。安裝步驟請直接參閱 RVM 官網的安裝說明。

使用 RVM

接著我們來看一些在 RVM 裡常用的指令。在終端機下輸入 rvm list known 會列出目前有哪些可以安裝的列表:

$ rvm list known
# MRI Rubies
[ruby-]1.8.6[-p420]
[ruby-]1.8.7[-head] # security released on head
[ruby-]1.9.1[-p431]
[ruby-]1.9.2[-p330]
[ruby-]1.9.3[-p551]
[ruby-]2.0.0[-p648]
[ruby-]2.1[.10]
[ruby-]2.2[.6]
[ruby-]2.3[.3]
[ruby-]2.4[.0-rc1]
ruby-head

[...略...]

macruby[-0.12]
macruby-nightly
macruby-head

# IronRuby
ironruby[-1.1.3]
ironruby-head

幾乎目前常見的 Ruby 分支實作品都有。列表裡的中括號表示那些是可以省略的,所以如果你這樣輸入:

$ rvm install 2.3

RVM 會自動找 [ruby-]2.3[.3] 這個版本的 Ruby 來安裝。前面提到可以安裝多個不同的版本,所以如果你喜歡,也可以再裝個 1.9.3 的版本:

$ rvm install 1.9.3

安裝完成後,我們可以使用 rvm list 來查看目前電腦裡已經安裝哪些版本的 Ruby:

$ rvm list

   ruby-1.9.3-p551 [ x86_64 ]
   ruby-2.3.0 [ x86_64 ]
   ruby-2.3.1 [ x86_64 ]
=* ruby-2.3.3 [ x86_64 ]

# => - current
# =* - current && default
#  * - default

因為業務的需求,所以在我的電腦上裝了好幾個版本的 Ruby。在 2.3.3 版前面的 =* 符號則是表示我目前正在使用這個版本。

我們可以在終端機下輸入這個指令,看看目前 Ruby 的版本:

$ ruby -v
ruby 2.3.3p222 (2016-11-21 revision 56859) [x86_64-darwin15]

如果要切換到其它版本的 Ruby,例如想要切換到 1.9.3 版本:

$ rvm use 1.9.3

想少打幾個字的話,use 也可以省略:

$ rvm 1.9.3

再來看一下Ruby的版本:

$ ruby -v
ruby 1.9.3p551 (2014-11-13 revision 48407) [x86_64-darwin13.4.0]

這樣就切換到 Ruby 1.9.3 了,相當便利!

不過有個小問題是,RVM 會在每次重新開啟終端機視窗的時候回到預設值(也就是系統內建的 Ruby 版本),所以如果你希望每次開終端機視窗的時候都會自動切到 2.3.3 版的話:

$ rvm 2.3.3 --default

這樣你每次開終端機視窗就會自動幫你切換到 2.3.3 版了。如果你想切回到原來系統內建的版本,只要執行這個指令:

$ rvm system

不要了,想砍掉它?

$ rvm uninstall 1.9.2

這樣就可以把指定的版本移除掉了。如果你整個 RVM 都不想要了,只要把個人帳號 home 資料夾底下的 .rvm 資料夾整個移除,就會整個清潔溜溜了,完全不會動到系統內建的 Ruby。

運作原理

你也許會好奇為什麼 RVM 可以這麼神奇的切換 Ruby 的環境。讓我們來把系統的 PATH 變數印出來看看:

$ echo $PATH
/Users/user/.rvm/gems/ruby-2.3.3/bin:/Users/user/.rvm/gems/ruby...[略]...

然後查看一下 Ruby 的位置:

$ which ruby
/Users/user/.rvm/rubies/ruby-2.3.3/bin/ruby

再查一下 Ruby 版本:

$ ruby -v
ruby 2.3.3p222 (2016-11-21 revision 56859) [x86_64-darwin15]

(以上內容是我自己電腦裡的設定,應該跟各位的環境不同)

接下來把 RVM 切換到 1.9.3 版本:

$ rvm 1.9.3

再重複把剛剛的那些資訊印出來:

$ echo $PATH
/Users/user/.rvm/gems/ruby-1.9.3-p551/bin:/Users/user/.rvm/gems...[略]...

$ which ruby
/Users/user/.rvm/rubies/ruby-1.9.3-p551/bin/ruby

$ ruby -v
ruby 1.9.3p551 (2014-11-13 revision 48407) [x86_64-darwin13.4.0]

仔細看上面的輸出結果,就可以發現其實 RVM 是把不同版本的 Ruby 安裝在你的個人帳號底下的 .rvm 目錄裡。當你切換不同版本的 Ruby 的時候,RVM 會幫你把系統預設的 PATH 的最前面加上這個 .rvm 的資料夾,當你在終端機底下輸入 ruby 指令時,系統原本的 /usr/bin/ruby 因為在 PATH 的比較後面的位置,所以系統只會先找到 RVM 版本的 Ruby(也就是原來系統的 Ruby 被鬼摭眼啦)。如果各位有興趣,也可以試著輸入 rvm info 指令來看看 RVM 幫你做了哪些設定。

除了 RVM 之外...

我自己個人習慣使用 RVM,除了 RVM 之外還有其它的選擇,例如 rbenvchruby,這些 Ruby 版本管理工具各有其優、缺點,還請大家自己去試用看看,然後選一套自己覺得順手的來用吧。

安裝 Rails

完成 Ruby 安裝後,接下來就準備來安裝 Rails。在開放原始碼的圈子,有非常多的善心人士開發好了功能強大又可免費取用的套件,在 Ruby 的世界我們稱它叫 gem。Rails 本身也是一個 gem (更準確的說,應該是一群 gem 的集合體),要安裝 rails 的話,只要使用 gem install 指令加上套件名稱即可,像這樣:

$ gem install rails
Fetching: i18n-0.7.0.gem (100%)
Successfully installed i18n-0.7.0
Fetching: thread_safe-0.3.5.gem (100%)
Successfully installed thread_safe-0.3.5
Fetching: tzinfo-1.2.2.gem (100%)
Successfully installed tzinfo-1.2.2
Fetching: concurrent-ruby-1.0.2.gem (100%)
Successfully installed concurrent-ruby-1.0.2
Fetching: activesupport-5.0.0.1.gem (100%)
Successfully installed activesupport-5.0.0.1
...[略]...
Installing ri documentation for bundler-1.13.6
Parsing documentation for sprockets-3.7.0
Installing ri documentation for sprockets-3.7.0
Parsing documentation for sprockets-rails-3.2.0
Installing ri documentation for sprockets-rails-3.2.0
Parsing documentation for rails-5.0.0.1
Installing ri documentation for rails-5.0.0.1
Done installing documentation for i18n, ...[略]... sprockets-rails, rails after 69 seconds
36 gems installed

從安裝過程的訊息可大概看到 5.0.0.1 的字眼。如果過程沒發生錯誤訊息的話,接下來可確認一下是不是正確的版本:

$ rails -v
Rails 5.0.0.1

接下來,我們就要用它來建立第一個 Rails 專案了。

建立 Rails 專案

Rails 安裝完成後,接下來就用它來產生一個名為 hello_rails 的 Rails 專案,建立新專案用的是 new 這個參數,它會產生很多檔案:

$ rails new hello_rails
      create
      create  README.md
      create  Rakefile
      create  config.ru
      create  .gitignore
      create  Gemfile
      create  app
      create  app/assets/config/manifest.js
      create  app/assets/javascripts/application.js
      create  app/assets/javascripts/cable.js
      ...[略]...
      create  app/assets/stylesheets/application.css
      create  app/channels/application_cable/channel.rb
      create  app/channels/application_cable/connection.rb
      create  vendor/assets/stylesheets/.keep
      remove  config/initializers/cors.rb
         run  bundle install
Fetching gem metadata from https://rubygems.org/..............
Fetching version metadata from https://rubygems.org/...
Fetching dependency metadata from https://rubygems.org/..
Resolving dependencies...
Installing rake 12.0.0
...[略]...
Using rails 5.0.0.1
Installing sass-rails 5.0.6
Bundle complete! 15 Gemfile dependencies, 62 gems now installed.
Use `bundle show [gemname]` to see where a bundled gem is installed.
         run  bundle exec spring binstub --all
* bin/rake: spring inserted
* bin/rails: spring inserted

接下來,使用 cd 指令進到剛剛產生的這個專案目錄:

$ cd hello_rails

進到這個專案之後,什麼事都不用做,直接啟動 Rails 附的 web server:

$ rails server
=> Booting Puma
=> Rails 5.0.0.1 application starting in development on http://localhost:3000
=> Run `rails server -h` for more startup options
Puma starting in single mode...
* Version 3.6.2 (ruby 2.3.3-p222), codename: Sleepy Sunday Serenity
* Min threads: 5, max threads: 5
* Environment: development
* Listening on tcp://localhost:3000
Use Ctrl-C to stop

打開瀏覽器,連上網址 http://localhost:3000/ ,你應該可以看到這個畫面:

http://ithelp.ithome.com.tw/upload/images/20161218/20065770JQkNJ2nINa.png

恭喜你,你已經順利把 Ruby 跟 Rails 安裝完成,而且建立了一個 Rails 專案並順利跑起來了。雖然環境安裝看起來只是一小步,但這一小步對第一次接觸終端機、要打一堆指令的人來說已經是不小的一步了。


本系列文章內容同步發佈於這裡,若有任何問題或錯誤,都歡迎直接到 GitHub 上發 PR 修正,或是在這裡留言討論。


上一篇
第 01 章 - Ruby 之生態圈及簡介
下一篇
第 03 章 - 開發工具與常用命令列指令
系列文
為你自己學 Ruby on Rails30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
凍仁翔
iT邦新手 3 級 ‧ 2016-12-22 10:48:05

請問這裡是得用 rvm rubies 還是 rvm rubies 呢?

$ rvm rubies
Unrecognized command line argument: 'rubies' ( see: 'rvm usage' )

小弟試了一下,得用 list 才可把 rvm 的環境給列出來。

$ rvm list

rvm rubies

=* ruby-2.2.1 [ x86_64 ]
   ruby-2.2.2 [ x86_64 ]

# => - current
# =* - current && default
#  * - default
高見龍 iT邦研究生 3 級 ‧ 2016-12-22 10:51:59 檢舉

rvm list 沒錯,我來改一下,感謝提醒 :)

凍仁翔 iT邦新手 3 級 ‧ 2016-12-22 11:10:42 檢舉

謝謝分享啊!等鐵人賽結束後,小弟會來好好入門 Rails 的。:P

我要留言

立即登入留言