[hive] ORC 파일 포맷

2016. 12. 28. 23:05·빅데이터/hive

ORC(Optimized Row Columnar) 파일 포맷


ORC 파일 포맷은 하이브의 처리 속도를 높이기 위하여 개발 되었다. 


하이브가 처음에 사용한 TextFile, SequenceFile 포맷의 처리속도를 높이기 위하여 RCFile 포맷이 개발 되었다. 

RCFile 포맷은 각 컬럼을 하나의 파일 묶음으로 만들었기 때문에 각 노드에 분산 처리된 데이터를 모으는 비용이 많이 들어가게 된다. 

이를 극복하기 위하여 제안된 것이 ORC 파일 포맷이다.

ORC 포맷은 칼럼 단위로 데이터를 기록하고, 인덱스를 기록하여 컬럼에 바로 접근할 수 있기 때문에 속도가 빨라진다. 

 

ORC 포맷은 호튼웍스의 부사장 오웬오말리가 제안한 것으로 하나의 파일에 칼럼을 json 처럼 중첩구조로 구성할 수 있고, 리스트, 맵과 같은 복합형태로 구조를 가져갈 수 있기 때문에 오픈 소스 진영에서 많은 관심을 받고 있다.

 

특징


- 각 태스크의 결과가 하나의 파일로 생성됨: 네임노드의 부하를 줄여줌

- datetime, decimal, complex type(struct, list, map, union)을 지원 

- 파일에 경량 인덱스가 저장됨

- 파일 경량 인덱스가 저장됨 

- 필터링 조건이 없는 로우 그룹은 스킵

- 특정 row 로 seek 가능

- 데이터 타입 기반의 block-mode 압축

- integer 컬럼은 run-length encoding 을 사용

- 문자열 컬럼은 dictionary enocding 을 사용 

- 하나의 파일을 여러개의 리더로 동시 읽기 가능

- 마커 스캐닝 없이 파일 분할 가능

- 파일 읽기 쓰기에 일정한 메모리 용량만 필요

- 필드의 추가나 제거가 가능한 메타 데이터는 Protocol Buffers 를 사용해서 저장





파일구조

 



 






ORC Files from Owen O'Malley



하둡 속도를 높여라... 파일 포맷 대권레이스

ORCFile - 오웬 오말리

Hadoop Hive ORCFileFormat

ORC 파일 리뷰 - http://blog.kthdaisy.com:8080/orcfile-review/


반응형
저작자표시 비영리 (새창열림)

'빅데이터 > hive' 카테고리의 다른 글

[hive][error] SemanticException Column "칼럼명" Found in more than One Tables/Subqueries  (0) 2017.01.06
[hive][hql] hive 2 의 hqlsql 사용해보기  (0) 2017.01.03
[hive][error] msck repair table 처리시 오류 수정  (0) 2016.12.20
[hive] Hive 2의 특징  (0) 2016.12.08
[hive][error] java.io.IOException: Not a file  (0) 2016.12.01
'빅데이터/hive' 카테고리의 다른 글
  • [hive][error] SemanticException Column "칼럼명" Found in more than One Tables/Subqueries
  • [hive][hql] hive 2 의 hqlsql 사용해보기
  • [hive][error] msck repair table 처리시 오류 수정
  • [hive] Hive 2의 특징
hs_seo
hs_seo
Hello World!
    반응형
  • hs_seo
    개발자로 살아남기
    hs_seo
  • 전체
    오늘
    어제
    • 전체 (1140)
      • 개발자 (21)
        • 개발에 유의할 점 (0)
        • 면접 (5)
      • IT 소식 (5)
        • 업계 (1)
      • java (51)
        • 디자인패턴 (3)
        • apache-common (1)
      • 개념 (47)
        • 자료구조 (4)
        • 함수형사고 (8)
        • 디자인패턴 (1)
      • 데이터분석 (1)
      • python (67)
        • 코드조각 (12)
        • 라이브러리 (2)
      • 빅데이터 (418)
        • zookeeper (5)
        • hadoop (78)
        • hdfs (12)
        • hive (127)
        • hbase (16)
        • spark (40)
        • scala (4)
        • trino (3)
        • oozie (41)
        • Hue (9)
        • R (5)
        • sqoop (6)
        • flume (3)
        • elasticsearch (2)
        • airflow (16)
        • kafka (3)
        • kubernetes (10)
        • openstack (3)
        • flink (2)
        • redis (2)
      • 빅데이터 강좌 (2)
      • 알고리즘 (131)
        • 알고리즘 (1)
        • 백준 (61)
        • 정올 (41)
        • 더블릿 (5)
        • 프로그래머스 (1)
      • 프로그래밍 언어 (30)
        • go (4)
        • js (9)
        • .Net (6)
        • Jsp (1)
        • ansible (3)
        • terraform (6)
      • Tools (56)
        • docker (2)
        • macbook (6)
        • maven (3)
        • sublime (1)
      • 프레임워크 (25)
        • [JS] angularjs (2)
        • [JS] node.js (19)
        • [Java] spring (2)
        • Android (2)
      • 데이타베이스 (43)
        • SQLD (5)
        • Oracle (1)
        • MySQL (8)
        • ADsP (2)
      • 리눅스 (25)
        • Bash (61)
      • GCP (5)
      • AWS (34)
        • EC2 (2)
        • EMR (14)
      • 정보보안기사 (4)
        • 네트워크 (1)
      • 개인 (80)
        • 업무실수 (0)
        • 책 (9)
        • 교육 (3)
        • 여행 (17)
        • 영화 (12)
        • 음악 (2)
        • 피규어 (4)
        • 게임 (3)
        • 생각 (7)
        • 기타 (10)
        • 좋은글 (5)
        • 좋은 사이트 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 미디어로그
    • 위치로그
    • 방명록
  • 링크

    • 빅데이터-하둡,하이브로 시작하기
    • 빅데이터-스칼라, 스파크로 시작하기
    • Kaggle에서 파이썬으로 데이터 분석 시작하기
    • 쉘스크립트 개발 시작하기
    • 개발자가 데이터 분석 준전문가 되기
    • 데브쿠마
  • 공지사항

  • 인기 글

  • 태그

    SPARK
    정올
    build
    emr
    bash
    oozie
    오류
    HDFS
    nodejs
    백준
    AWS
    알고리즘
    S3
    hbase
    ubuntu
    Hadoop
    k8s
    Python
    파이썬
    HIVE
    error
    airflow
    mysql
    yarn
    하둡
    Tez
    java
    Linux
    하이브
    다이나믹
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
hs_seo
[hive] ORC 파일 포맷
상단으로

티스토리툴바