Help us understand the problem. What is going on with this article?

WindowsにおけるRubyやRailsの環境構築方法をいろいろ調べてみた(2017年3月版)

More than 1 year has passed since last update.

はじめに

僕は普段MacでRailsの開発をやっているのですが、ひょんなことからWindows環境でRubyの動作確認をする必要が出てきたため、Windows上でのRuby開発環境について調べ始めました。

調べていくと「RubyInstallerを使いましょう」という記事や書籍が比較的多かったです。
しかし、RubyInstallerは2017年3月7日現在、メンテナンスが停滞しており、最新版のRuby 2.4.0ではなく、Ruby 2.3.3で更新が止まっています。

そこで、RubyInstaller以外の環境構築方法はないだろうか、とさらにいろいろ調べていきました。

というわけで、この記事では僕が調べたWindows上でのRuby開発環境方法をいくつかリストアップしていきます。

おことわり

この情報は2017年3月7日現在の情報です。
将来的にはまた状況が大きく変わる可能性もあります。
ですので、適宜、最新の情報もチェックするようにしてください。

また、冒頭で述べたとおり、僕は普段Macを使って開発しています。
Windowsをメインで使っているわけではないので、Windows上でのRuby開発に詳しい人が見ると、何かおかしなことを書いているかもしれません。
その場合はコメント欄や編集リクエスト等で優しく指摘してやってください。

それでは以下が本編です。

方法その1: RubyInstallerを使う

RubyInstallerはRuby環境を構築するための専用インストーラを提供します。
インストーラを使うことで簡単にRuby環境を構築できます。

提供サイトや環境構築方法

長所

  • Windows環境では比較的メジャーな構築方法だった(過去形)ので、ネットや書籍の情報が比較的多い。(つまり、トラブルが起きても解決しやすい)
  • 開発環境がWindows内で完結するので、Windowsに関する知識(コマンドプロンプトやエクスプローラの操作方法等)をそのまま活用できる。

短所

方法その2: RubyInstaller2を使う

RubyInstaller2はメンテナンスが停滞しているRubyInstallerの後継者を目指して開発されている比較的新しいインストーラです。
RubyInstaller2はRuby 2.4以降の正式なRubyInstallerに昇格しました。
ただし、名前が同じになっただけで、内部的にはRuby 2.3以前のRubyInstallerとRuby 2.4以降のRubyInstallerは別物になるので注意が必要です。(2017.5.26追記)

C言語ライブラリを使うgemをインストールする場合、RubyInstallerはDevKitを使いますが、RubyInstaller2はMSYS2を使います。

提供サイトや環境構築方法

長所

  • (本記事執筆時点の最新版である)Ruby 2.4.0がインストールできる。
  • 開発環境がWindows内で完結するので、Windowsに関する知識(コマンドプロンプトやエクスプローラの操作方法等)をそのまま活用できる。

短所

  • 登場して間もないので情報が少ない。特にCライブラリを使うgemのインストール方法がRubyInstallerと異なるので、インストール時にエラーが出ると解決に時間がかかるかもしれない。
  • 今後の先行きがよくわからない。(RubyInstallerに統合されるかもしれないし、されないかもしれない) 前述の通り、RubyInstaller2はRuby 2.4以降のRubyInstallerとして統合されました。
  • RubyInstallerと同様、コマンドプロンプト上でirbやrails consoleを動かすと、日本語の入力に苦労する。
  • RubyInstallerと同様、rbenvRVMを使って実行するRubyのバージョンを切り替えることができない。

コラム: RubyInstallerやRubyInstaller2でバージョンを切り替えるには?

(2019.1.5 追記)

RubyInstaller2でRuby 2.6をインストールすると、ridk useというコマンドを使って、Rubyのバージョンが切り替えられるようになりました。

以下はその実行例です。

C:\Users\JunichiIto>ruby -v
ruby 2.6.0p0 (2018-12-25 revision 66547) [x64-mingw32]

C:\Users\JunichiIto>ridk use
1 - C:/Ruby24-x64       ruby 2.4.1p111 (2017-03-22 revision 58053) [x64-mingw32]
2 - C:/Ruby26-x64       ruby 2.6.0p0 (2018-12-25 revision 66547) [x64-mingw32]
3 - C:/Ruby23-x64       ruby 2.3.3p222 (2016-11-21 revision 56859) [x64-mingw32]
Select ruby version to enable: 1
Disable C:/Ruby24-x64
Disable C:/Ruby26-x64
Disable C:/Ruby23-x64
Enable C:/Ruby24-x64

C:\Users\JunichiIto>ruby -v
ruby 2.4.1p111 (2017-03-22 revision 58053) [x64-mingw32]

(追記ここまで)

RubyではrbenvやRVMといったツールを使って、実行するRubyのバージョンを切り替えることができます。

しかし、これらのツールはMacやLinux向けなので、Windows上では動作しません。

というわけで、Windows向けのrbenvやRVMのようなツールを探してみました。
するとどうやら、uruというツールを使うとWindows上でもRubyのバージョン切替ができるようです。(ただし未検証)

pikというツールもあるみたいですが、こちらはメンテナンスが2014年から止まっているので、あまりオススメできません。

他にも環境変数のPATHを直接編集する、という方法もあるみたいですね。
(あまり直接編集したくないですが・・・)

また、このあとに紹介するBash on Ubuntu on WindowsやDocker/Vagrantのように、Linuxと同等の環境を用意すれば、rbenvやRVMが使えます。
Rubyのバージョンを切り替える必要があるなら、最初からこれらの環境で開発を進めるのも良いかもしれません。

方法その3: Windows Subsystem for Linux(WSL)を使う

Windows Subsystem for Linux(旧名:Bash on Ubuntu on Windows)は、Windows上にLinux環境(Bashシェル)を構築できるWindows 10の新機能です。
なので、Linux向けの開発環境構築手順が(理論上は)そのまま使えます。

提供サイトや環境構築方法

長所

  • 開発環境構築をはじめ、様々なLinux向けのRubyに関するノウハウを活用できる(はず)。
  • rbenvRVMを使って実行するRubyのバージョンを切り替えることができる。
  • Bashシェルからirbやrails consoleを開くと、コピーアンドペーストで日本語が入力できる。(readlineの機能も有効にしたままでOK、エンコーディングもUTF-8で完結する)

Screen Shot 2017-03-07 at 7.07.27.png

  • wsl-terminalのように、サードパーティ製のターミナルを使うと、直接日本語を入力することも可能。

Screen Shot 2017-03-07 at 7.13.00.png

Screen Shot 2017-03-07 at 7.13.12.png

短所

  • 2017年3月現在、Bash on Ubuntu on Windowsはベータ版という位置づけなので、不具合があったり、将来的に仕様が変わったりする恐れがある。
  • 登場してからあまり時間が経っておらず、本家Linuxとの互換性もどこまで実現できているかわからないため、思わぬ落とし穴にハマる可能性もある。(注:個人的な推測です)
  • Windows 8以前のWindowsでは利用できない。
  • ターミナルを操作するために、Unix/Linux系のコマンド(lsrmなど)を新たに覚える必要がある。

方法その4: DockerやVagrant等の仮想環境を使う

DockerVagrantのようなツールを使ってLinux系の仮想環境を用意し、その中でRubyの開発環境を構築する方法です。
(ただし、僕個人はこの方法をMac上では試したことがありますが、Windows上では試したことがありません)

参考サイト

長所

  • 仮想環境内では本物のLinuxが動いているので、Linux向けのRubyに関するノウハウを活用できる。
  • 他の人が用意してくれたテンプレート(のようなもの)を利用すると、コマンド一発で開発環境が構築(再現)できる。
  • Windows 8以前のWindowsでも利用可能。
  • rbenvRVMを使って実行するRubyのバージョンを切り替えることができる。(そもそもプロジェクトごとに別の仮想環境を用意する、という方法でも良さそう)

短所

  • DockerやVagrantといったツールの使い方や用語を覚える必要がある。
  • 仮想環境を動作させるためのリソース(メモリやCPU)が必要になる。
  • ターミナルを操作するために、Unix/Linux系のコマンド(lsrmなど)を新たに覚える必要がある。

方法その5: クラウド上の開発環境を利用する

Cloud9のようなクラウド上の開発環境を利用し、ブラウザ内で開発を進める方法です。
実行に必要なのはブラウザだけなので、もはやローカルマシンのOSはほとんど関係なくなります。

最近のRailsチュートリアルがこの方式なので、「使ったことがある」という人も多いかもしれません。

参考サイト

長所

  • ブラウザを開いてアカウント登録さえすれば、すぐに開発を始められる。

短所

  • 学習用であれば十分かもしれないが、本格的なアプリケーション開発になると不便なところが出てきそう。(注:個人的な推測です。本格的な開発も全部クラウドでやってるよ!という人がいたら教えてください。)
  • 内部ではLinux系の仮想環境が動いているので、Unix/Linux系のコマンドに関する知識が多少必要になる。

まとめ

というわけで、この記事ではWindows用のRuby開発環境について、いろいろ調べた結果をまとめてみました。

どの方法も一長一短なので、これ!とひとつに決めるのは難しいですね。
ただ、「ちょっと試しにやってみる」ではなく、本格的な開発をやっていくつもりなのであれば、僕個人の意見としてはBash on Ubuntu on WindowsやDocker/Vagrantのように、Linuxベースの環境で開発を進める方がいいと思います。
(Rubyの機能やgemはMac/Linuxの使用を前提にしたものが多いのと、Linux系ならトラブルシューティングのノウハウとかもWindowsより豊富なので)

てか、「絶対にWindowsマシンを使いたい!」というこだわりがないのであれば、Macを1台買って環境構築した方が、トータルで見たときに一番時間を節約できる気がしま・・・って言ってしまうと、この記事を書いた意味がなくなっちゃいますね😅

とりあえず、これからWindowsマシンでRubyの開発環境を構築しようと思っている方は、本記事の内容を参考にしてもらえると幸いです。

また、WindowsマシンでバリバリRubyやRailsの開発をやっている方は、この記事で不足している知見や、もっと良い方法を教えてもらえると嬉しいです。

以上、「WindowsにおけるRubyやRailsの環境構築方法をいろいろ調べてみた」でした!

jnchito
SIer、社内SEを経て、ソニックガーデンに合流したプログラマ。 「プロを目指す人のためのRuby入門」の著者。 http://gihyo.jp/book/2017/978-4-7741-9397-7 および「Everyday Rails - RSpecによるRailsテスト入門」の翻訳者。 https://leanpub.com/everydayrailsrspec-jp
https://blog.jnito.com/
sonicgarden
「お客様に無駄遣いをさせない受託開発」と「習慣を変えるソフトウェアのサービス」に取り組んでいるソフトウェア企業
http://www.sonicgarden.jp
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした