GuideDevEnv » 履歴 » バージョン 3
Mitsuyoshi Yoshida, 2011/06/25 23:59
1 | 2 | Mitsuyoshi Yoshida | h1. プラグインの開発環境の準備 |
---|---|---|---|
2 | 1 | Mitsuyoshi Yoshida | |
3 | 2 | Mitsuyoshi Yoshida | プラグインの開発をしようとした場合、実際に稼動している Redmine でプラグインを作って試すのは危険が大きいです。まずはプラグイン開発のための環境を準備しましょう。 |
4 | 1 | Mitsuyoshi Yoshida | |
5 | 2 | Mitsuyoshi Yoshida | 実際の Redmine の運用は Linux などで行うことが多いと思いますが、 Redmine は Windows 環境でも動作します。やはり、簡単に用意できるは Windows の PC ですし、自分で使うだけなら Windows の Redmine でも十分です。私もプラグインを作る時は自分の PC で行い、確認してから実際の Redmine にインストールしています。 |
6 | そこで、開発環境には Windows 上の Redmine を使うことにして、その構築方法を説明をしていきたいと思います。ただし、 Redmine を立ち上げる方法はすでにいろんなサイトで紹介されているので、開発用の環境にポイントを絞っています。 |
||
7 | 1 | Mitsuyoshi Yoshida | |
8 | 2 | Mitsuyoshi Yoshida | 通常の Redmine のインストール方法の説明については他のサイトを参考にしてください。以下のサイトなどがお勧めです。 |
9 | 1 | Mitsuyoshi Yoshida | |
10 | 2 | Mitsuyoshi Yoshida | * Redmine の本家 |
11 | ** http://www.redmine.org/projects/redmine/wiki/RedmineInstall |
||
12 | * 本家の日本語訳 |
||
13 | ** http://redmine.jp/guide/RedmineInstall/ |
||
14 | * Windows 版のインストール |
||
15 | ** http://www012.upp.so-net.ne.jp/tanuki-project/install_redmine.html |
||
16 | 1 | Mitsuyoshi Yoshida | |
17 | |||
18 | |||
19 | 2 | Mitsuyoshi Yoshida | h2. 開発用 Redmine のポイント |
20 | 1 | Mitsuyoshi Yoshida | |
21 | 2 | Mitsuyoshi Yoshida | 開発用の Redmine のポイントは 2 つです。 |
22 | 3 | Mitsuyoshi Yoshida | |
23 | 2 | Mitsuyoshi Yoshida | # development モードで起動する |
24 | # サーバ には WEBrick を使う |
||
25 | 1 | Mitsuyoshi Yoshida | |
26 | 2 | Mitsuyoshi Yoshida | Rails では動作モードとして、 *production* モードと *development* モードが用意されています。実際に稼動する場合は production モードで動作させますが、開発に使う場合は development モードの方がちょっと便利です。 |
27 | production モードでは動作を早くするため、一度読み込んだコードは覚えておいて、再度表示する場合はそれを使います。それに対して development モードの場合は、表示するたびに毎回読み込んでくれるので、変更を Redmine の再起動なしで確認することが出来ます。ただ、 *ちょっと* 便利と書いたのは後で説明しますが、全部即座に変更が適用されるわけではないので、意外と再起動は必要です。 |
||
28 | ちなみに動作モードには test モードというのもあります。これはテストに使うものですが、このプラグインガイドでは test については書いてないので、説明については省略します。 Rails ではテストも簡単にできるのらしいですが、私は使ったことがありません。 |
||
29 | 1 | Mitsuyoshi Yoshida | |
30 | 2 | Mitsuyoshi Yoshida | 実際に運用する場合はサーバには Apache などを使うと思います。しかし、これらのサーバの場合、エラーが発生したとき、ページに *Internal Error* とでるだけですが、 *WEBrick* を使っていると *詳細なエラーページ* が出てきてデバッグにかなり役に立ちます。 |
31 | 1 | Mitsuyoshi Yoshida | |
32 | 2 | Mitsuyoshi Yoshida | !webrick_err.png! |
33 | 1 | Mitsuyoshi Yoshida | |
34 | |||
35 | 2 | Mitsuyoshi Yoshida | h2. 使用ソフト |
36 | 1 | Mitsuyoshi Yoshida | |
37 | 2 | Mitsuyoshi Yoshida | |_. Redmine | | http://rubyforge.org/frs/?group_id=1850 | |
38 | |_. Ruby | Rumix | http://ruby.morphball.net/rumix/ | |
||
39 | |_. データベース | SQLite | http://www.sqlite.org/download.html | |
||
40 | 1 | Mitsuyoshi Yoshida | |
41 | 2 | Mitsuyoshi Yoshida | まず、Redmine の最新版をダウロードします。作成したプラグインを公開する場合にはなるべく最新版で確認する方がいいでしょう。 |
42 | 1 | Mitsuyoshi Yoshida | |
43 | 2 | Mitsuyoshi Yoshida | Ruby には、 ruby 本体と一緒にいろいろインストールしてくれる Rumix を使用します。 |
44 | プラグイン開発ではコマンドラインで実行しなければならないことが多いので、特に nyacus というコマンドラインの実行をやりやすくするプログラムが役に立ちます。 |
||
45 | インストールした ruby の gem を使って、 rails などの必要なライブラリなどをインストールすることになりますが、この ruby 自身や gem を使ってインストールするものはなるべく "本家のインストールページ":http://www.redmine.org/projects/redmine/wiki/RedmineInstall で確認して Redmine のバージョンにあわせたものにして下さい。 |
||
46 | 1 | Mitsuyoshi Yoshida | |
47 | 2 | Mitsuyoshi Yoshida | データベースは SQLite にしました。多分、 Redmine が対応するデータベースの中では Windows 上で一番簡単に動作させられると思います。 |
48 | 1 | Mitsuyoshi Yoshida | |
49 | |||
50 | 2 | Mitsuyoshi Yoshida | h2. データベース設定 |
51 | |||
52 | Rails では 1 つの Rails プログラムをモードを切り替えて動作させたとしても、他のモードに影響を与えないようになっています。そのため、データベースもモードごとに別々に設定するようになっています。 |
||
53 | データベース設定は config/database.example.yml をもとに config/database.yml を作成します。開発は development モードで起動するので、 このとき development 用の設定を環境に合わせて記述します。 |
||
54 | <pre><code class="yaml"> |
||
55 | development: |
||
56 | adapter: sqlite3 |
||
57 | dbfile: db/redmine.db |
||
58 | timeout: 5000 |
||
59 | </code></pre> |
||
60 | |||
61 | |||
62 | h2. データベースの作成 |
||
63 | |||
64 | データベースの作成コマンドなども development 用にする必要があります。 |
||
65 | Rails の起動モードの変更は RAILS_ENV という環境変数で行います。ただし、環境変数の設定されていないデフォルトの起動モードが development モードなので、 *"RAILS_ENV=production"* といった環境変数の設定を省略するだけです。 |
||
66 | <pre> |
||
67 | $ rake generate_session_store |
||
68 | $ rake db:migrate |
||
69 | $ rake redmine:load_default_data |
||
70 | </pre> |
||
71 | |||
72 | この 1 行目のセッションストアを作る作業は Redmine の途中のバージョンから必要になった機能なので、たまに説明が書かれていないサイトもあったりするので忘れないように注意してください。 |
||
73 | |||
74 | |||
75 | h2. サーバの起動 |
||
76 | |||
77 | WEBrick で Redmine を起動します。 |
||
78 | こちらも *"-e production"* の環境変数の設定を省略します。 |
||
79 | <pre> |
||
80 | $ ruby script/server |
||
81 | </pre> |
||
82 | |||
83 | 起動後 <notextile>http://127.0.0.1:3000/</notextile> にアクセスしてください。Windows の場合、 <notextile>http://localhost:3000/</notextile> だとアクセスできないことがあります。 |
||
84 | |||
85 | |||
86 | 上手くアクセスできたら、開発環境の準備は完了です。これで自分の PC で Redmine が動くようになりました。 |
||
87 | ただし、 development モードでかつ WEBrick を使っているとなるとかなり遅いですが、そこは我慢しましょう。 |
||
88 | |||
89 | 1 | Mitsuyoshi Yoshida | ---- |
90 | 2 | Mitsuyoshi Yoshida | |
91 | | [[プラグイン開発ガイド|^]] | [[GuideIntro|<<]] | [[GuideRails|>>]] | |