[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

+ Recent posts