Elasticsearch-인덱스 API
이러한 API는 설정, 별칭, 매핑, 색인 템플릿과 같은 색인의 모든 측면을 관리합니다.
색인 생성
이 API는 색인을 만드는 데 도움이됩니다. 사용자가 JSON 객체를 인덱스에 전달할 때 인덱스가 자동으로 생성되거나 그 전에 생성 될 수 있습니다. 인덱스를 생성하려면 설정, 매핑 및 별칭이 포함 된 PUT 요청을 보내거나 본문이없는 간단한 요청 만 보내면됩니다.
PUT colleges
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
{
"acknowledged" : true,
"shards_acknowledged" : true,
"index" : "colleges"
}
위의 명령에 몇 가지 설정을 추가 할 수도 있습니다.
PUT colleges
{
"settings" : {
"index" : {
"number_of_shards" : 3,
"number_of_replicas" : 2
}
}
}
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
{
"acknowledged" : true,
"shards_acknowledged" : true,
"index" : "colleges"
}
색인 삭제
이 API는 색인을 삭제하는 데 도움이됩니다. 특정 인덱스의 이름으로 삭제 요청을 전달하기 만하면됩니다.
DELETE /colleges
_all 또는 *를 사용하여 모든 인덱스를 삭제할 수 있습니다.
색인 얻기
이 API는 하나 이상의 인덱스에 get 요청을 전송하여 호출 할 수 있습니다. 인덱스에 대한 정보를 반환합니다.
GET colleges
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
{
"colleges" : {
"aliases" : {
"alias_1" : { },
"alias_2" : {
"filter" : {
"term" : {
"user" : "pkay"
}
},
"index_routing" : "pkay",
"search_routing" : "pkay"
}
},
"mappings" : { },
"settings" : {
"index" : {
"creation_date" : "1556245406616",
"number_of_shards" : "1",
"number_of_replicas" : "1",
"uuid" : "3ExJbdl2R1qDLssIkwDAug",
"version" : {
"created" : "7000099"
},
"provided_name" : "colleges"
}
}
}
}
_all 또는 *를 사용하여 모든 인덱스의 정보를 얻을 수 있습니다.
인덱스가 있음
인덱스의 존재 여부는 해당 인덱스에 가져 오기 요청을 전송하여 확인할 수 있습니다. HTTP 응답이 200이면 존재합니다. 404이면 존재하지 않습니다.
HEAD colleges
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
200-OK
색인 설정
URL 끝에 _settings 키워드를 추가하면 색인 설정을 얻을 수 있습니다.
GET /colleges/_settings
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
{
"colleges" : {
"settings" : {
"index" : {
"creation_date" : "1556245406616",
"number_of_shards" : "1",
"number_of_replicas" : "1",
"uuid" : "3ExJbdl2R1qDLssIkwDAug",
"version" : {
"created" : "7000099"
},
"provided_name" : "colleges"
}
}
}
}
인덱스 통계
이 API는 특정 인덱스에 대한 통계를 추출하는 데 도움이됩니다. 끝에 색인 URL과 _stats 키워드가있는 get 요청을 보내면됩니다.
GET /_stats
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
………………………………………………
},
"request_cache" : {
"memory_size_in_bytes" : 849,
"evictions" : 0,
"hit_count" : 1171,
"miss_count" : 4
},
"recovery" : {
"current_as_source" : 0,
"current_as_target" : 0,
"throttle_time_in_millis" : 0
}
} ………………………………………………
플러시
인덱스의 플러시 프로세스는 현재 트랜잭션 로그에만 유지되는 모든 데이터가 Lucene에서도 영구적으로 유지되도록합니다. 이렇게하면 인덱싱 된 Lucene이 열린 후 트랜잭션 로그에서 데이터를 다시 인덱싱 할 필요가 없으므로 복구 시간이 줄어 듭니다.
POST colleges/_flush
위의 코드를 실행하면 아래와 같은 출력이 나타납니다.
{
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
}
}