groonga - オープンソースのカラムストア機能付き全文検索エンジン

2.8. その他

このセクションではUNIX系の環境でgroongaをソースコードからインストールする方法を説明します。

インストール にある特定環境用のドキュメントに、その環境向けのより詳細な情報があります。特定環境用のドキュメントがある場合は、まずそちらを参照してください。

2.8.1. 依存関係

groongaは特別なライブラリを必要としませんが、いくつかビルドに必要なツールがあります。

2.8.1.1. ツール

以下が必要なツールです:

  • wgetcurl または Web ブラウザ(ソースアーカイブをダウンロードするため)

  • targzip (ソースアーカイブを展開するため)

  • シェル( dashbashzsh など、どのようなシェルでもたぶん大丈夫)

  • CコンパイラーとC++コンパイラー ( gccg++ がサポート対象だが、他のコンパイラーでもたぶん大丈夫)

  • make (GNU makeがサポート対象だが、BSD makeなど他のmakeでもたぶん大丈夫)

これらを用意してください。

シェルの代わりに CMake を使うこともできますが、このドキュメントではCMakeを使ってビルドする方法については説明しません。

以下はあるとよいツールです:

  • pkg-config (ライブラリを検出するため)

  • sudo (ビルドしたgroongaをインストールするため)

追加のライブラリを使いたい場合はこれらのツールを用意しておかなければいけません。

2.8.1.2. ライブラリ

どのライブラリも必須ではありません。以下はオプションとして使えるライブラリです:

これらのライブラリを使いたい場合は、groongaをインストールする前にライブラリをインストールしてください。

2.8.2. ソースからビルド

groongaはGNUビルドシステムを使っています。以下は一番簡単なビルド手順です:

% wget http://packages.groonga.org/source/groonga/groonga-3.0.9.tar.gz
% tar xvzf groonga-3.0.9.tar.gz
% cd groonga-3.0.9
% ./configure
% make
% sudo make install

上記の手順を実行すると /usr/local/bin/groongagroongaコマンド がインストールされます。

デフォルトのビルドでもうまく動くでしょうが、 configure のときにgroongaをカスタマイズすることができます。

以下、それぞれの手順の詳細を説明します。

2.8.2.1. configure

まず configure を実行します。重要な configure のオプションは以下の通りです:

2.8.2.1.1. --prefix=PATH

インストール先となるディレクトリを指定します。groonga関連のファイルは ${PATH}/ ディレクトリ以下にインストールされます。

デフォルトは /usr/local 。デフォルトの場合は groongaコマンド/usr/local/bin/groonga にインストールされます。

以下はシステム全体にgroongaをインストールするのではなく、ユーザーが個人で使う目的で ~/local にインストールする例です:

% ./configure --prefix=$HOME/local

2.8.2.1.2. --localstatedir=PATH

ログファイル、PIDファイル、データベースなど頻繁に変更されるファイルを置くディレクトリを指定します。たとえば、ログファイルは ${PATH}/log/groonga.log に置かれます。

デフォルトは /usr/local/var です。

以下は頻繁に変更されるファイルをシステム全体で使う領域である /var に置く例です:

% ./configure --localstatedir=/var

2.8.2.1.3. --with-log-path=PATH

ログファイルのデフォルトのパスを指定します。ログファイルのデフォルトのパスは groongaコマンド--log-path コマンドラインオプションで変更できます。そのため、このオプションはそんなに重要なビルドオプションではありません。少し便利にするためのオプションです。

デフォルトは /usr/local/var/log/groonga.log です。 /usr/local/var の部分は --localestatedir オプションで変更できます。

以下はログファイルを共有しているNFSディレクトリ /nfs/log/groonga.log に置く例です:

% ./configure --with-log-path=/nfs/log/groonga.log

2.8.2.1.4. --with-default-encoding=ENCODING

デフォルトのエンコーディングを指定します。有効なエンコーディングは euc_jpsjisutf8latin1koi8rnone です。

デフォルトは utf-8 です。

以下はデフォルトのエンコーディングとしてShift_JISを使う例です:

% ./configure --with-default-encoding=sjis

2.8.2.1.5. --with-match-escalation-threshold=NUMBER

マッチ演算でエスカレーションをするかどうかのデフォルトの閾値を指定します。この閾値については match_escalation_threshold を参照してください。-1はマッチ演算でエスカレーションしないという意味です。

デフォルトは0です。

以下はデフォルトではマッチエスカレーションをしないという例です:

% ./configure --with-match-escalation-threshold=-1

2.8.2.1.6. --with-zlib

zlibを使ってカラム値を圧縮する機能を有効にします。

デフォルトでは無効です。

以下はzlibを使ってカラム値を圧縮する機能を有効にする例です:

% ./configure --with-zlib

ノート

無効となっている理由は、カラムの値を参照するときにメモリリークするためです。これは既知の問題 GitHub#6 です。この問題はカラムの更新とは関係ありません。

2.8.2.1.7. --with-lzo

LZOを使ってカラム値を圧縮する機能を有効にします。

デフォルトでは無効です。

以下はLZOを使ってカラム値を圧縮する機能を有効にする例です:

% ./configure --with-lzo

ノート

無効となっている理由は、カラムの値を参照するときにメモリリークするためです。これは既知の問題 GitHub#6 です。この問題はカラムの更新とは関係ありません。

2.8.2.1.8. --with-message-pack=MESSAGE_PACK_INSTALL_PREFIX

MessagePackがどこにインストールされているかを指定します。MessagePackを --prefix=/usr という configure オプションでインストールしていない場合は、MessagePackをビルドするときに指定したパスをこのオプションで指定してください。

もし、MessagePackを --prefix=$HOME/local という configure オプションでインストールした場合は、groongaの configure では --with-message-pack=$HOME/local と指定してください。

デフォルトは /usr です。

以下はMessagePackが --prefix=$HOME/local という configure オプションでインストールされている場合の例です:

% ./configure --with-message-pack=$HOME/local

2.8.2.1.9. --with-munin-plugins

groonga用のMuninプラグインをインストールします。プラグインは ${PREFIX}/share/groonga/munin/plugins/ 以下にインストールされます。

デフォルトではプラグインはインストールされません。

以下はgroonga用のMuninプラグインをインストールする例です:

% ./configure --with-munin-plugins

2.8.2.1.10. --with-package-platform=PLATFORM

initスクリプトなどプラットフォーム依存のシステム管理ファイルをインストールします。利用可能なプラットフォームは redhatfedora です。 redhat はRed HatおよびCentOSなどのRed Hatクローンのディストリビューション用です。 fedora はFedora用です。

デフォルトではシステム管理ファイルはインストールされません。

以下はCentOS用のシステム管理ファイルをインストールする例です:

% ./configure --with-package-platform=redhat

2.8.2.1.11. --help

すべての configure オプションを表示します。

2.8.2.2. make

configure が成功したら make でgroongaをビルドします:

% make

マルチコアCPUを使っている場合は -j オプションを使うとより速くmakeを実行できます。もし、4コアのCPUを使っている場合は、 -j4 オプションを使うともっと速くビルドできます:

% make -j4

make で何かエラーが発生した場合は、そのエラーをレポートしてください: バグレポートの送り方

2.8.2.3. make install

これでビルドしたgroongaをインストールできます!:

% sudo make install

${PREFIX} への書き込み権限がある場合は sudo を使う必要はありません。例えば、 --prefix=$HOME/local と指定した場合です。この場合は make install を使ってください:

% make install