Elasticsearch Marvel 2.x はプロダクションでも無料で使えるので入れておこう。

2016.02.03

この記事は公開されてから1年以上経過しています。情報が古い可能性がありますので、ご注意ください。

入社3日目の木戸です。入りみだれるチャットコミュニケーションにあたふたしつつも、社内のドキュメントなどを読みあさりながら、少しづつ会社にも慣れてきたかな?といった感じです。

そのうち「Elasticsearch 入門シリーズ」でも連載しようかと考えているのですが、今回記念すべき1本目のブログは、

なぜか、Marvel です!ニッチですw

Marvel

Marvel 2.x は、Kibana 4 をベースにUIが再設計され、Elasticsearch 2.x を効率的に管理するための主要なメトリクスにフォーカスされていて、より監視しやすいUIになっています。

Marvel 1.x では有償の製品として提供されていましたが、Marvel 2.x は、Basic License を申請することで、開発でもプロダクションでも無料で使い続けることができますので是非導入しておきましょう。

注意 マルチクラスター 対応などの無料範囲外の機能が使いたい場合は、有償のサポートが必要になります。

今回ご紹介するのは、Basic License の導入方法です。主にシングルクラスター構成の開発環境やプロダクション環境で、Marvel を使用し続けるための手順となります。

参考 無料範囲はシングルクラスターなので、1つのクラスターで複数ノード構成はOKなのです!

導入手順

1. Marvel agent plugin のインストール

以下の手順で、Elasticsearch の ノード毎に Marvel agent をインストールします。

# 1. License plugin のインストール
bin/plugin install license

# 2. Marvel agent のインストール
bin/plugin install marvel-agent

# 3. Elasticsearch の起動
bin/elasticsearch

2. Marvel app のインストール

以下の手順で、Marvel app を Kibana のプラグインとしてインストールします。

# 1. Marvel app のインストール
bin/kibana plugin --install elasticsearch/marvel/latest

# 2. Kibana の起動
bin/kibana

3. Marvel のインストールの確認

ブラウザで、http://0.0.0.0:5601/app/marvel へアクセスして、Marvel が正しくインストールされているか確認してください。正しくインストールされていれば、Elasticsearch の Cluster が認識され、以下のような画面が表示されます。

20160203-1

よく見ると、Cluster 一覧の License が Trial になっています!

20160203-2

このままでは、30日で使えなくなってしまいますので、次の手順でライセンスの申請と更新をします。

4. Basic license の入手

Elastic 社のホームページの以下のページのフォームから必要事項を入力し、申請するとライセンスをダウンロードするためのURLがメールで送られてきますので、手順に従ってライセンスファイルをダウンロードしてください。

Marvel » Free License Registration

5. ライセンスの更新

入手したライセンスファイルを使って、以下の手順でMarvel のライセンスを更新します。

# 1. ライセンスの更新
curl -XPUT 'http://localhost:9200/_license?acknowledge=true' -d @license.json

以下のようにレスポンスが帰って来れば成功です。

{
  "acknowledged": true,
  "license_status": "valid"
}

6. ライセンス更新の確認

ライセンスの更新が完了したら、ブラウザで http://0.0.0.0:5601/app/marvel へアクセスして、ライセンスが更新されたか確認してください。

Basic License では、マルチクラスター をサポートしていないため、Cluster 一覧ではなく 以下のように Overview のページが表示されます。

20160203-3

これでめでたくMarvelを使い続けられます。

また、APIを使用して、ライセンスの情報を取得するには、以下のようにリクエストします。

# 1. インストールされているライセンスの表示
curl -XGET 'http://localhost:9200/_license?pretty'

ライセンスの情報は、こんな感じです。license.type が、basic になっていますね。

{
  "license" : {
    "status" : "active",
    "uid" : "9fa6a1d9-ddb1-49f9-824d-e2eee5840d49",
    "type" : "basic",
    "issue_date" : "2016-01-28T00:00:00.000Z",
    "issue_date_in_millis" : 1453939200000,
    "expiry_date" : "2017-02-03T23:59:59.999Z",
    "expiry_date_in_millis" : 1486166399999,
    "max_nodes" : 100,
    "issued_to" : "Kunihiko Kido (Classmethod, Inc.)",
    "issuer" : "Web Form"
  }
}

これを見ると、最大ノード数は100で制限されているのかな?

まとめ

Marvel はサーバーのCPUやメモリ、Diskの使用率以外にも、Search や Indexing などのパフォーマンスの状態、JVM Heap の状態、Shard の状態(初期化中、再配置中、etc)など、運用中の Elasticsearch の状態を把握するためには必須の製品です。 シングルクラスターであれば、無料で使い続けることができますので、ぜひ導入しましょう!