このクイックチュートリアルでは、Elasticsearch、特にElasticsearchエンジンでインデックスを作成する方法について説明します。このチュートリアルに従うためにELKスタックに関する包括的な知識は必要ありませんが、次のトピックの基本を理解していると有利な場合があります。
- ターミナル、具体的にはcURLを使用する
- APIとJSONの基本的な知識
- HTTPリクエストの作成
ノート: このチュートリアルでは、Elasticsearchがシステムにインストールされて実行されていることも前提としています。
Elasticsearchインデックスとは何ですか?
Elasticsearchインデックスは、物事を過度に単純化または過度に複雑化することなく、関連するJSONドキュメントのコレクションです。
以前の投稿で述べたように、ElasticsearchインデックスはJSONオブジェクトであり、Elasticsearchのストレージの基本単位と見なされます。これらの関連するJSONドキュメントは、インデックスを構成する単一のユニットに保存されます。 Elasticsearchドキュメントをリレーショナルデータベースのテーブルと考えてください。
ElasticsearchインデックスをSQLの世界のデータベースとして関連付けましょう。
- MySQL =>データベース=>テーブル=>列/行
- Elasticsearch =>インデックス=>タイプ=>プロパティを持つJSONドキュメント
Elasticsearchインデックスを作成する方法
Elasticsearchは、強力で直感的なRESTAPIを使用してサービスを公開します。この機能を使用すると、HTTPリクエストを使用してElasticsearchクラスターで操作を実行できます。したがって、create indexAPIを使用して新しいインデックスを作成します。
このガイドでは、cURLを使用してリクエストを送信し、すべてのユーザーの整合性と使いやすさを維持します。ただし、cURLでエラーが発生した場合は、Kibanaコンソールの使用を検討してください。
Elasticsearchクラスターで新しいインデックスを作成するための構文は次のとおりです。
置く /インデックスを作成するには、他のパラメータなしでインデックス名を渡すだけです。これにより、デフォルト設定を使用してインデックスが作成されます。
インデックス本体など、インデックスのさまざまな機能を指定することもできます。
- インデックスの設定
- インデックスエイリアス
- インデックスフィールドのマッピング
インデックス名は必須パラメーターです。そうしないと、URIL(/)のエラーが発生します
curl -X PUT localhost:9200{'エラー': 'URI [/]およびメソッド[PUT]のHTTPメソッドが正しくありません。許可されています:[DELETE、HEAD、GET]'、 'status':405}
single_indexという名前の新しいインデックスを作成するには、次のリクエストを渡します。
PUT / single_indexcURLの場合は、次のコマンドを使用します。
curl -X PUT'localhost:9200 / single_index?pretty 'このコマンドにより、HTTPステータス200 OKが表示され、次のように確認されたメッセージが表示されます。
{{認められた:本当、
'shards_acknowledged':true、
'インデックス': 'single_index'
}
上記のリクエストでは、構成を指定しなかったため、デフォルト設定でインデックスsingle_indexが作成されます。
インデックスの命名規則
Elasticsearchインデックスの名前を作成するときは、次の命名基準に従う必要があります。
- インデックス名は小文字のみにする必要があります。
- インデックス名は、ダッシュ(-)、アンダースコア(_)、または加算記号(+)で始めることはできません。
- 名前を。にすることはできません。また ..
- インデックス名に次のような特殊文字を含めることはできません:、/、*、?、、、 |、 ``(スペース文字)、、、#
- インデックス名の長さは255バイト未満である必要があります。マルチバイト文字は、インデックス名の全長に含まれます。たとえば、1文字の長さが8バイトの場合、名前の残りの合計の長さは255〜8です。
- Elasticsearchの最新バージョンでは、。で始まる名前。 Elasticsearchプラグインで使用される非表示のインデックスと内部インデックス用に予約されています。
インデックス本文の作成方法
PUTリクエストを使用してインデックスを作成する場合、作成するインデックスの設定を定義するさまざまな引数を渡すことができます。本文で指定できる値は次のとおりです。
- エイリアス: 作成するインデックスのエイリアス名を指定します。このパラメーターはオプションです。
- 設定: これにより、作成するインデックスの構成オプションが定義されます。パラメータを指定しなかった場合、インデックスはデフォルト設定を使用して作成されます。
- マッピング: これにより、インデックス内のフィールドのマッピングが定義されます。マッピングに含めることができる仕様は次のとおりです。
- フィールド名
- データ型
- マッピングパラメータ
本体構成でインデックスを作成する例については、以下のリクエストを検討してください。
PUT / single_index_with_body{{
'設定': {
'number_of_shards':2、
'number_of_replicas':2
}、
マッピング:{
'プロパティ': {
'field1':{'タイプ': 'オブジェクト'}
}
}
}
cURLと同等のリクエストの場合:
curl -XPUT'http:// localhost:9200 / single_index_with_body '-H'Content-Type:application / json' -d '{' settings ':{' number_of_shards ':2、' number_of_replicas ':2}、' mappings ' :{'プロパティ':{'field1':{'タイプ': 'オブジェクト'}}}} '上記のリクエストは、2つの数のシャードと2つのレプリカを持つsingle_index_with_bodyという名前の新しいインデックスを作成します。また、field1という名前のフィールドとJSONオブジェクトとしての型を使用してマッピングを作成します。
リクエストを送信すると、リクエストのステータスが次のような応答が返されます。
{{認められた:本当、
'shards_acknowledged':true、
'インデックス': 'single_index_with_body'
}
Acknowledgedは、インデックスがクラスター内で正常に作成されたかどうかを示し、shards_acknowledgedは、タイムアウトする前に、指定されたインデックス内のすべてのシャードに対して必要な数のシャードコピーが開始されたかどうかを示します。
Elasticsearchインデックスを表示する方法
作成したインデックスに関する情報を表示するには、インデックスの作成と同様のリクエストを使用しますが、次のようにPUTの代わりにHTTPメソッドを使用します。
GET / single_index_with_bodycURLの場合、
curl -XGET http:// localhost:9200 / single_index_with_bodyこのコマンドは、要求されたインデックスに関する詳細情報を次のように提供します。
{{'single_index_with_body':{
'エイリアス':{}、
'マッピング':{
'プロパティ' : {
'field1':{
'タイプ': 'オブジェクト'
}
}
}、
'設定' : {
'索引' : {
'ルーティング' : {
'割り当て':{
'含む' : {
'_tier_preference': 'data_content'
}
}
}、
'number_of_shards': '2'、
'provided_name': 'single_index_with_body'、
'creation_date': '1611045687208'、
'number_of_replicas': '2'、
'uuid': '3TRkO7xmQcSUOOGtb6pXVA'、
'バージョン' : {
'作成済み': '7100299'
}
}
}
}
}
結論
このガイドでは、Elasticsearchを使用してインデックスAPIを作成し、新しいインデックスを作成する方法について説明しました。また、インデックスと構成設定に適した名前を作成する方法についても説明しました。
このガイドを使用すると、ElasticsearchAPIを使用してインデックスを作成および表示できるようになります。