Elasticsearch-문서 API

Elasticsearch는 단일 문서 API와 다중 문서 API를 제공하며, API 호출은 각각 단일 문서와 여러 문서를 대상으로합니다.

Index API

특정 매핑을 사용하여 해당 인덱스에 요청이있을 때 인덱스에서 JSON 문서를 추가하거나 업데이트하는 데 도움이됩니다. 예를 들어, 다음 요청은 색인 학교 및 학교 매핑 아래에 JSON 객체를 추가합니다.

PUT schools/_doc/5
{
   name":"City School", "description":"ICSE", "street":"West End",
   "city":"Meerut",
   "state":"UP", "zip":"250002", "location":[28.9926174, 77.692485],
   "fees":3500,
   "tags":["fully computerized"], "rating":"4.5"
}

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 1,
   "result" : "created",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 2,
   "_primary_term" : 1
}

자동 인덱스 생성

특정 인덱스에 JSON 개체를 추가하라는 요청이 있고 해당 인덱스가 존재하지 않는 경우이 API는 해당 인덱스와 해당 특정 JSON 개체에 대한 기본 매핑도 자동으로 생성합니다. 이 기능은 elasticsearch.yml 파일에있는 다음 매개 변수의 값을 false로 변경하여 비활성화 할 수 있습니다.

action.auto_create_index:false
index.mapper.dynamic:false

다음 매개 변수의 값을 변경하여 특정 패턴의 색인 이름 만 허용되는 색인 자동 생성을 제한 할 수도 있습니다.

action.auto_create_index:+acc*,-bank*

Note − 여기서 +는 허용을 나타내고 –는 허용되지 않음을 나타냅니다.

버전 관리

Elasticsearch는 버전 제어 기능도 제공합니다. 버전 쿼리 매개 변수를 사용하여 특정 문서의 버전을 지정할 수 있습니다.

PUT schools/_doc/5?version=7&version_type=external
{
   "name":"Central School", "description":"CBSE Affiliation", "street":"Nagan",
   "city":"paprola", "state":"HP", "zip":"176115", "location":[31.8955385, 76.8380405],
   "fees":2200, "tags":["Senior Secondary", "beautiful campus"], "rating":"3.3"
}

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "result" : "updated",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 3,
   "_primary_term" : 1
}

버전 관리는 실시간 프로세스이며 실시간 검색 작업의 영향을받지 않습니다.

버전 관리에는 가장 중요한 두 가지 유형이 있습니다.

내부 버전 관리

내부 버전 관리는 1로 시작하고 업데이트 할 때마다 증가하는 기본 버전이며 삭제도 포함됩니다.

외부 버전 관리

문서의 버전 관리가 타사 버전 관리 시스템과 같은 외부 시스템에 저장 될 때 사용됩니다. 이 기능을 활성화하려면 version_type을 외부로 설정해야합니다. 여기서 Elasticsearch는 외부 시스템에서 지정한대로 버전 번호를 저장하고 자동으로 증가시키지 않습니다.

작업 유형

작업 유형은 만들기 작업을 강제하는 데 사용됩니다. 이렇게하면 기존 문서를 덮어 쓰는 것을 방지 할 수 있습니다.

PUT chapter/_doc/1?op_type=create
{
   "Text":"this is chapter one"
}

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "chapter",
   "_type" : "_doc",
   "_id" : "1",
   "_version" : 1,
   "result" : "created",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 0,
   "_primary_term" : 1
}

자동 ID 생성

인덱스 작업에서 ID가 지정되지 않은 경우 Elasticsearch는 해당 문서에 대한 ID를 자동으로 생성합니다.

POST chapter/_doc/
{
   "user" : "tpoint",
   "post_date" : "2018-12-25T14:12:12",
   "message" : "Elasticsearch Tutorial"
}

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "chapter",
   "_type" : "_doc",
   "_id" : "PVghWGoB7LiDTeV6LSGu",
   "_version" : 1,
   "result" : "created",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 1,
   "_primary_term" : 1
}

API 받기

API는 특정 문서에 대한 가져 오기 요청을 수행하여 유형 JSON 객체를 추출하는 데 도움이됩니다.

pre class="prettyprint notranslate" > GET schools/_doc/5

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "_seq_no" : 3,
   "_primary_term" : 1,
   "found" : true,
   "_source" : {
      "name" : "Central School",
      "description" : "CBSE Affiliation",
      "street" : "Nagan",
      "city" : "paprola",
      "state" : "HP",
      "zip" : "176115",
      "location" : [
         31.8955385,
         76.8380405
      ],
      "fees" : 2200,
      "tags" : [
         "Senior Secondary",
         "beautiful campus"
      ],
      "rating" : "3.3"
   }
}
  • 이 작업은 실시간이며 인덱스 새로 고침 빈도의 영향을받지 않습니다.

  • 버전을 지정할 수도 있습니다. 그러면 Elasticsearch가 해당 버전의 문서 만 가져옵니다.

  • 또한 요청에 _all을 지정하여 Elasticsearch가 모든 유형에서 해당 문서 ID를 검색 할 수 있고 일치하는 첫 번째 문서를 반환 할 수 있습니다.

  • 특정 문서의 결과에 원하는 필드를 지정할 수도 있습니다.

GET schools/_doc/5?_source_includes=name,fees

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "_seq_no" : 3,
   "_primary_term" : 1,
   "found" : true,
   "_source" : {
      "fees" : 2200,
      "name" : "Central School"
   }
}

get 요청에 _source 부분을 추가하기 만하면 결과에서 소스 부분을 가져올 수도 있습니다.

GET schools/_doc/5?_source

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "_seq_no" : 3,
   "_primary_term" : 1,
   "found" : true,
   "_source" : {
      "name" : "Central School",
      "description" : "CBSE Affiliation",
      "street" : "Nagan",
      "city" : "paprola",
      "state" : "HP",
      "zip" : "176115",
      "location" : [
         31.8955385,
         76.8380405
      ],
      "fees" : 2200,
      "tags" : [
         "Senior Secondary",
         "beautiful campus"
      ],
      "rating" : "3.3"
   }
}

새로 고침 매개 변수를 true로 설정하여 가져 오기 작업을 수행하기 전에 샤드를 새로 고칠 수도 있습니다.

API 삭제

Elasticsearch에 HTTP DELETE 요청을 전송하여 특정 인덱스, 매핑 또는 문서를 삭제할 수 있습니다.

DELETE schools/_doc/4

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "found":true, "_index":"schools", "_type":"school", "_id":"4", "_version":2,
   "_shards":{"total":2, "successful":1, "failed":0}
}

문서 버전을 지정하여 특정 버전을 삭제할 수 있습니다. 라우팅 매개 변수를 지정하여 특정 사용자의 문서를 삭제할 수 있으며 문서가 해당 특정 사용자에게 속하지 않으면 작업이 실패합니다. 이 작업에서는 GET API와 동일하게 새로 고침 및 제한 시간 옵션을 지정할 수 있습니다.

API 업데이트

스크립트는이 작업을 수행하는 데 사용되며 버전 관리는 가져 오기 및 재 인덱싱 중에 업데이트가 발생하지 않았는지 확인하는 데 사용됩니다. 예를 들어, 스크립트를 사용하여 학교 비용을 업데이트 할 수 있습니다.

POST schools/_update/4
{
   "script" : {
      "source": "ctx._source.name = params.sname",
      "lang": "painless",
      "params" : {
         "sname" : "City Wise School"
      }
   }
 }

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "4",
   "_version" : 3,
   "result" : "updated",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 4,
   "_primary_term" : 2
}

업데이트 된 문서에 가져 오기 요청을 보내 업데이트를 확인할 수 있습니다.