반응형
** OS 환경: ubuntu 16.04
** Elasticsearch Version: 7.10.0
1. Elasticsearch / RDB 비교
A. 구조
Elasticsearch | RDB |
index | database |
type | table |
document | row |
field | column |
mapping | schema |
B. Query문
Elasticsearch | RDB |
GET | SELECT |
PUT | UPDATE |
POST | INSERT |
DELETE | DELETE |
2. Elasticsearch 데이터 입력 및 조회
- 데이터 확인
# curl -X GET http://localhost:9200/classes?pretty
- 인덱스 생성
# curl -X PUT http://localhost:9200/classes
- 인덱스 삭제
# curl -X DELETE http://localhost:9200/classes
- 데이터 생성
# curl -X POST http://localhost:9200/classes/class/1/ -d '{"title":"Algorithm", "professor":"John"}'
* 오류 발생 *
{"error":"Content-Type header [application/x-www-form-urlencoded] is not supported","status":406}
* 해결 방안 *
- POST 요청 Header에 Contet-Type Json 방식으로 변경
# curl -X POST http://localhost:9200/classes/class/1/ -H 'Content-Type: application/json' -d '{"title":"Algorithm", "professor":"John"}'
- 파일로 생성
# curl -X POST http://localhost:9200/classes/class/1/ -H 'Content-Type: application/json' -d @oneclass.json
- 데이터 업데이트
# curl -X POST http://localhost:9200/classes/class/1/_update?pretty -H 'Content-type: application/json' -d '{"doc": {"unit": 1}}'
# curl -X PUT http://localhost:9200/classes/class/1/_update?pretty -H 'Content-type: application/json' -d '{"doc": {"unit": 1}}'
- 데이터 업데이트(Script)
#curl -X POST http://localhost:9200/classes/class/1/_update?pretty -H 'Content-type: application/json' -d
'{"script": "ctx._source.unit += 5"}'
3. Elasticsearch 데이터 Mapping
- 데이터 타입과 데이터 매칭을 시켜줍니다. (ex. text, int..)
- 데이터 분석이나 시각화를 할 때 데이터 Mapping이 되어있는 데이터가 가공에 용이합니다.
- 아래와 같이 초기 데이터 생성 시 mapping을 별도로 지정해주지 않으면 비어 있습니다.
- Mapping 생성
# curl -X PUT 'http://localhost:9200/classes/class/_mapping?pretty' -H 'Content-Type: application/json' -d @classesRating_mapping.json
* 오류 발생 *
Types cannot be provided in put mapping requests, unless the include_type_name parameter is set to true
* 해결 방안 *
- 아래와 같이 include_type_name=true 옵션 추가
# curl -X PUT 'http://localhost:9200/classes/class/_mapping?include_type_name=true&pretty' -H 'Content-Type: application/json' -d @classesRating_mapping.json
* 오류 발생 *
"No handler for type [string] declared on field [professor]"
* 해결 방안 *
- 아래와 같이 string type을 text로 변경해줍니다.
- 버전이 바뀌면서 type_name이 변경된 걸로 확인됩니다.
# sed -i 's/string/text/g' classesRating_mapping.json
- Mapping이 생성되었습니다.
** 참고 사이트
인프런 ELK 스택으로 데이터 분석 강의 자료 내용을 바탕으로 작성하였습니다.
반응형
'ELK' 카테고리의 다른 글
ELK - 01 (CSV 파일 입력 및 데이터 시각화) (0) | 2020.12.10 |
---|---|
Elasticsearch + Kibana - 2 (Elasticsearch 데이터 입력 및 활용) (0) | 2020.12.10 |
Elasticsearch + Kibana - 1 (Kibana 설치 및 기본 설정) (0) | 2020.12.07 |
Elasticsearch 시작하기 - 3 (Aggregation) (0) | 2020.12.07 |
Elasticsearch 시작하기 - 1(사전 준비 및 개념) (0) | 2020.12.06 |