메뉴 건너뛰기

Bigdata, Semantic IoT, Hadoop, NoSQL

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


hbase HBase shell로 작업하기

구퍼 2013.03.15 17:54 조회 수 : 5834

실행중인 HBase에는 쉘을 통해 접속할 수 있다.

$ ./bin/hbase shell
HBase Shell; enter 'help<RETURN>' for list of supported commands.
Type "exit<RETURN>" to leave the HBase Shell
Version: 0.90.0, r1001068, Fri Sep 24 13:55:42 PDT 2010

hbase(main):001:0>

help라고 입력한 뒤, 엔터 키를 누르면 쉘 명령어 목록과 옵션을 확인할 수 있다. 도움말 맨 마지막 문단을 보면, HBase에서 변수나 명령어 인자를 어떻게 입력해야 하는지 확인할 수 있다. 특히 테이블 이름, 행, 컬럼 등을 인용부호로 감싸고 있다는 점을 유심히 봐야 한다.

test라는 이름으로 테이블을 생성해보자. 컬럼 패밀리는 cf라는 이름을 주고, 하나의 컬럼 패밀리만을 만들자. 테이블의 내요을 조회한 후, 몇 가지 값을 입력하면 테이블이 제대로 생성되었는지 확인해 볼 수 있다.

hbase(main):003:0> create 'test', 'cf'
0 row(s) in 1.2200 seconds
hbase(main):003:0> list 'test'
..
1 row(s) in 0.0550 seconds
hbase(main):004:0> put 'test', 'row1', 'cf:a', 'value1'
0 row(s) in 0.0560 seconds
hbase(main):005:0> put 'test', 'row2', 'cf:b', 'value2'
0 row(s) in 0.0370 seconds
hbase(main):006:0> put 'test', 'row3', 'cf:c', 'value3'
0 row(s) in 0.0450 seconds

이 예제에서 값 3개를 차례대로 추가했다. 처음에는 row1의 컬럼 cf:a에, 값으로는 value1을 입력했다. HBase에서 컬럼은 컬럼 패밀리를 가리키는 접두사(이 예제에서는 cf)와, 콜론, 그리고 컬럼 이름에 대한 접미사(이 경우에는 a)로 구성된다.

이제 데이터가 제대로 입력되었는지 확인해 보자.

아래와 같이, 테이블에 대해 scan 명령어를 실행하자.

hbase(main):007:0> scan 'test'
ROW COLUMN+CELL
row1 column=cf:a, timestamp=1288380727188, value=value1
row2 column=cf:b, timestamp=1288380738440, value=value2
row3 column=cf:c, timestamp=1288380747365, value=value3
3 row(s) in 0.0590 seconds

아래와 같이 한 행을 조회해보자.

hbase(main):008:0> get 'test', 'row1'
COLUMN CELL
cf:a timestamp=1288380727188, value=value1
1 row(s) in 0.0400 seconds

이제 테이블을 비활성화한 후, 테이블을 삭제하자. 이렇게 하면 앞에서 한 작업들이 모두 초기화된다.

hbase(main):012:0> disable 'test'
0 row(s) in 1.0930 seconds
hbase(main):013:0> drop 'test'
0 row(s) in 0.0770 seconds

번호 제목 글쓴이 날짜 조회 수
40 column family삭제시 Column family 'delete' does not exist오류 발생하는 경우 총관리자 2014.04.14 932
39 hive에서 생성된 external table에서 hbase의 table에 값 insert하기 총관리자 2014.04.11 1748
38 Oozie 설치, 환경설정 및 테스트 총관리자 2014.04.08 1292
37 다수의 로그 에이전트로 부터 로그를 받아 각각의 파일로 저장하는 방법(interceptor및 multiplexing) 총관리자 2014.04.04 4089
36 external partition table생성및 data확인 총관리자 2014.04.03 1072
35 동일서버에서 LA와 LC동시에 기동하여 테스트 총관리자 2014.04.01 928
34 의사분산모드에서 presto설치하기 총관리자 2014.03.31 3050
33 Hive Query Examples from test code (2 of 2) 총관리자 2014.03.26 5005
32 Hive Query Examples from test code (1 of 2) 총관리자 2014.03.26 1050
31 hadoop설치시 오류 총관리자 2013.12.18 2313
30 centsOS vsftpd설치하기 총관리자 2013.12.17 1515
29 ubuntu에 hadoop 2.0.5설치하기 총관리자 2013.12.16 1879
28 centos 5.X에 hadoop 2.0.5 alpha 설치 총관리자 2013.12.16 1581
27 hbase에 필요한 jar들 구퍼 2013.04.01 2100
26 Hive java connection 설정 file 구퍼 2013.04.01 2013
25 Hbase Shell 명령 정리 구퍼 2013.04.01 3169
24 HBASE Client API : 기본 기능 정리 file 구퍼 2013.04.01 3554
23 하둡 분산 파일 시스템을 기반으로 색인하고 검색하기 구퍼 2013.03.15 5573
22 HBase, BigTable, Cassandra Schema Design file 구퍼 2013.03.15 2506
» HBase shell로 작업하기 구퍼 2013.03.15 5834

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.

위로