[Hadoop]
"시작하세요! 하둡 프로그래밍 - 위키북스"를 기준으로 작성된 글 입니다.
- 간략 목차
1. 하둡이란?
2. 왜 하둡인가?
3. 하둡 에코시스템
4. 하둡에 대한 오해
1. 하둡이란?
: 구글이 논문으로 발표한 GFS(Google File System)와 맵리듀스(MapReduce)를 2005년에 더그 커팅(Doug Cutting)이 구현한 결과물이다.
: 자바 기반의 오픈소스 프레임워크
: 분산 파일 시스템인 HDFS(Hadoop Distributed File System)에 데이터를 저장하고, 분산 처리 시스템인 맵리듀스를 이용해 처리한다.
2. 왜 하둡인가?
: 정형 데이터의 경우 기존의 관계형 데이터베이스(RDBMS)에 저장할 수 있지만 웹 로그 같은 비정형 데이터를 RDBMS에 저장하기에는 데이터 크기가 너무 크다.
상용 RDBMS가 설치되는 곳은 대부분 고가의 장비인데, 데이터를 감당하기 위해 무한정 스토리지를 늘릴 수도 없다.
: 이에 반해 하둡은 오픈소스 프로젝트이기에 소프트웨어 라이선스 비용에 대한 부담이 없다.
: 또한 값비싼 유닉스 장비를 사용하지 않고, 리눅스 서버면 얼마든지 하둡을 설치해서 운영할 수 있다. 데이터 저장 용량이 부족할 경우, 필요한 만큼 리눅스 서버만 추가 하면 된다.
: 하둡은 여러 대의 서버에 데이터의 복제본을 저장하고, 데이터가 저장된 각 서버에서 동시에 데이터를 처리하기 때문에
데이터의 유실이나 장애가 발생했을 때도 데이터 복구가 가능하다.
3. 하둡 에코시스템
- 코디네이터
: Zookeeper
- 리소스 관리
: YARN
: Mesos
- 데이터 저장
: HBase
: Kudu
- 데이터 수집
: Chukwa
: Flume
: Scribe
: Sqoop
: Hiho
: Kafka
- 데이터 처리
: Pig
: Mahout
: Spark
: Impala
: Presto
: Hive
: Tajo
- 워크플로우 관리
: Oozie
: Airflow
: Azkaban
: Nifi
- 데이터 시각화
: Zeppelin
- 데이터 직렬화
: Avro
: Thrift
4. 하둡에 대한 오해
- RDBMS를 대체 할 수 있다 !?
: 하둡은 기존 RDBMS를 대체하지 않는다. 오히려 RDBMS와 상호보완적인 특성을 띠고 있다.
: BI(Business Intelligence)나 OLAP(On-line Analytical Processing) 시스템을 사용하는 기업은 분석을 위한 데이터를 처리하기 위해 ETL 과정을 거치게 된다.
: ETL(Extraction, Transformation, Loading)이란 RDBMS나 로그 파일 등 다양한 데이터 소스로부터 필요한 데이터를 추출(Extraction)하고, 변환(Transformation)한 후 DW(Data Warehouse) 혹은 DM(Data Mart)에 전송과 적재(Loading)하는 과정을 의미한다.
: ETL은 자체적으로 셸 스크립트나 SQL 문을 이용해 진행하거나, DataStage 같은 상용 솔루션을 이용해 진행한다. 하둡은 이러한 ETL 과정에 도움을 줄 수 있다.
: 하지만 하둡은 트랜잭션이나 무결성이 반드시 보장돼야 하는 데이터를 처리하는 데 적합하지 않다.
그 이유는 하둡은 배치성으로 데이터를 저장하거나 처리하는 데 적합한 시스템으로 구성돼 있기 때문이다.
그래서 데이터 무결성이 중요한 데이터는 트랜잭션 별로 무결성을 보장하는 기존 RDBMS에서 처리하고, 하둡은 배치성으로 데이터를 저장하고, 처리해야 한다.
: 하둡이 실시간 처리가 절대로 불가능한 것은 아니다. 스크라이브나 플럼 같은 솔루션을 통해 데이터를 실시간으로 HDFS에 저장하고, H베이스를 이용해 HDFS에 저장된 데이터를 실시간으로 접근하면 된다.
- 하둡은 NoSQL이다 !?
: 하둡이 RDBMS에 속하는 것은 아니지만 NoSQL의 핵심 기능인 데이터베이스 시스템의 역할을 수행하는 것도 아니다.
'Hadoop - Infomation' 카테고리의 다른 글
[Hadoop] 하둡 실습 (0) | 2017.09.01 |
---|---|
[Hadoop] 빅데이터란? (0) | 2017.07.17 |