메뉴 건너뛰기

Bigdata, Semantic IoT, Hadoop, NoSQL

Bigdata, Hadoop ecosystem, Semantic IoT등의 프로젝트를 진행중에 습득한 내용을 정리하는 곳입니다.
필요한 분을 위해서 공개하고 있습니다. 문의사항은 gooper@gooper.com로 메일을 보내주세요.


hbase HBase, BigTable, Cassandra Schema Design

구퍼 2013.03.15 17:56 조회 수 : 2509

대용량 서비스 분야에서 RDBMS의 대안이라고 하는 NoSQL 계열을 들여다 보고 있는 중이다. 아키텍쳐나 설정 방법 등은 대충 알겠는데, 막상 구체적인 응용으로 넘어가보려고 하면, 덜컥 막히는 부분이 바로, 스키마 설계다. 기존의 RDBMS와는 관점과 방법이 완전 다르다. 너무 낯설고 막막해진다.

다음은, 테이블 설계 방법에 대한 설명 문서들이다.

http://www.slideshare.net/hmisty/20090713-hbase-schema-design-case-studies

  • Hbase Schema Design Case Studies
  • 간략한 비교 발표 자료
  • RDBMS에서의 사례와 HBase에서의 사례를 비교
  • 설명이 너무 없어서, 다소 막막함

http://data-tactics.com/techtips/cloud_data_structure_diagramming.pdf

  • Cloud Data Structure Diagramming Techniques and Design Patterns
  • DDI (Denormalization, Duplication, Intelligent keys) methodology
  • 꽤 상세한 사례 설명. UML 사용해서 설명.
  • 너무 일반적인 규칙을 뽑아내려고 시도(?)하는 바람에 다소 설명이 복잡해짐
  • Employee와 Department 테이블을 사례로 설명.

 

  • 다음은, 전통적인(?) RDB 모델
  •  
  • 다음은, RDB 스타일로 구성한 BigTable
  •  
  • 다음은, Denormalization 원리를 적용해서, 테이블을 하나로 만들고, 보조 인덱스 테이블을 하나 만듬.
  •  
  • 다음은, Denormalization과 Duplication을 적용한 경우
  •  
  • 다음은, Employee hasMany Department 인 경우,
  •  
  • Many-to-many relationship between Department and Employee 는 아래와 같이 구현도 가능.
  •  

http://isabel-drost.de/hadoop/slides/ecircle.pdf

  • 간만에 건진, 좋은 문서
  • 테이블 설계에 있어, 일종의 패턴을 보여준다.
  • Credid-Card Processing 사례를 중심으로 설명
  • 다음은, RDB 모델.
  •  
  • 다음은, HBase 모델
  •  
  • 위의 테이블에 더해서, email로 해당 카드번호를 찾을 수 있도록 Email to Card Mapping 테이블 준비
  •  
  • 실제 데이터를 쿼리하는 사례는, 너무 많아서, 여기서는 요약을 생략함. 원문 참조 요망.

http://devblog.streamy.com/2009/04/23/hbase-row-key-design-for-paging-limit-offset-queries/

  • HBase 101: Row key design for paging (LIMIT, OFFSET) queries
  • SELECT id, name, stamp FROM actions WHERE userid = 1 ORDER BY stamp DESC LIMIT 10 OFFSET 20;
  • 위와 비슷한 동작을 하도록 만드는 방법을 설명.
  • useraction 테이블을 만드는 데, row key는 복합키. <userid><reverse_order_stamp><actionid> 4바이트 + 8바이트 + 4바이트. 컬럼은 그냥 name 필드 하나만.
  • 자세한 자바 코드는, 원문 참조. 이해하기 어렵지 않음.

http://www.yes24.com/24/goods/3858447

  • Hadoop 완벽 가이드 : 클라우드 컴퓨팅 구축을 위한 실전 안내서
  • 12장 HBase 예제 p. 461 스키마
  • stations 테이블: stationid 가 rowkey, info:name, info:location, info:description 칼럼
  • observations 테이블: stationid + reversed_timestamp 가 rowkey, data:airtemp 칼럼
  • 관측치 테이블인 observations의 로우키를 복합키로 만든 이유는, 이 테이블에서 해당 stationid의 가장 최신 관측값을 10개 가져오려 하기 때문임. reserved_tmestamp = LONG.MAX_VALUE – observationTime 으로 계산.
  • rowkey의 접두사가 stationid 이므로, 같은 stationid를 가지는 row들이 차례대로 정렬됨. 따라서, Scanner로 시작점을 설정하고, s.next()로 읽어내면서 maxCount(=10)까지만 읽으면 됨.

대략, 느낌을 몇 가지 정리해보면, 아래와 같다.

RDB와는 다르게, 컬럼 필드에 대해서는 인덱스 생성이 자동으로 안된다. 오로지 RowKey에 대해서만 자동으로 인덱스 된다. 따라서, 컬럼 필드를 where 조건에서 지정해서 뽑아내는 식은 안된다. 무조건 RowKey로만 찾을 수 있다. 따라서, RowKey를 아주 영리하게 잘 설계해야 한다.

JOIN 같은 건 아예 지원 안된다. 테이블을 겹치지 않게 쪼개놓고 그걸 나중에 JOIN하겠다는 생각 자체를 하지 말아야 한다. 그 대신, 그냥, 한 테이블에 관련 정보를 컬럼 패밀리로 나눠서 때려 넣고, 필요한 걸 뽑아내는 방식이 더 낫다.

번호 제목 글쓴이 날짜 조회 수
741 [CDP7.1.7] oozie sqoop action으로 import혹은 export수행시 발생한 오류에 대한 자세한 로그 확인 하는 방법 gooper 2024.04.19 0
740 [Impala] alter table구문수행시 "WARNINGS: Impala does not have READ_WRITE access to path 'hdfs://nameservice1/DATA/Temp/DB/source/table01_ccd'" 발생시 조치 gooper 2024.04.26 0
739 [CDP7.1.7]Hive Replication수행시 Target Cluster에서 Specified catalog.database.table does not exist 오류 gooper 2024.05.08 0
738 [CDP7.1.7, Replication]Encryption Zone내 HDFS파일을 비Encryption Zone으로 HDFS Replication시 User hdfs가 아닌 hadoop으로 수행하는 방법 gooper 2024.01.15 1
737 [CDP7.1.7]Hive Replication수행중 Specified catalog.database.table does not exist : hive.db명.table명 오류 발생시 조치방법 gooper 2024.04.05 1
736 [CDP7.1.7][Replication]Table does not match version in getMetastore(). Table view original text mismatch gooper 2024.01.02 2
735 ./gradlew :composeDown 및 ./gradlew :composeUp 를 성공했을때의 메세지 gooper 2023.02.20 6
734 호출 url현황 gooper 2023.02.21 6
733 [vue storefrontui]외부 API통합하기 참고 문서 총관리자 2022.02.09 7
732 [Cloudera Agent] Metadata-Plugin throttling_logger INFO (713 skipped) Unable to send data to nav server. Will try again. gooper 2022.05.16 7
731 [CDP7.1.7, Hive Replication]Hive Replication진행중 "The following columns have types incompatible with the existing columns in their respective positions " 오류 gooper 2023.12.27 7
730 [CDP7.1.7]Oozie job에서 ERROR: Kudu error(s) reported, first error: Timed out: Failed to write batch of 774 ops to tablet 8003f9a064bf4be5890a178439b2ba91가 발생하면서 쿼리가 실패하는 경우 gooper 2024.01.05 7
729 eclipse editor 설정방법 총관리자 2022.02.01 10
728 oozie의 sqoop action수행시 ooize:launcher의 applicationId를 이용하여 oozie:action의 applicationId및 관련 로그를 찾는 방법 gooper 2023.07.26 10
727 주문 생성 데이터 예시 총관리자 2022.04.30 11
726 주문히스토리 조회 총관리자 2022.04.30 11
725 [bitbucket] 2022년 3월 2일 부터 git 작업시 기존에 사용하던 비빌번호를 사용할 수 없도록 변경되었다. 총관리자 2022.04.30 11
724 [EncryptionZone]User:testuser not allowed to do "DECRYPT_EEK" on 'testkey' gooper 2023.06.29 11
723 [CDP7.1.7]Encryption Zone내부/외부 간 데이터 이동(mv,cp)및 CTAS, INSERT SQL시 오류(can't be moved into an encryption zone, can't be moved from an encryption zone) gooper 2023.11.14 11
722 [CDP7.1.7]impala-shell수행시 간헐적으로 "-k requires a valid kerberos ticket but no valid kerberos ticket found." 오류 gooper 2023.11.16 11

A personal place to organize information learned during the development of such Hadoop, Hive, Hbase, Semantic IoT, etc.
We are open to the required minutes. Please send inquiries to gooper@gooper.com.

위로