1. 交互模式shell
$ hbase shell
2. 非交互模式bash
$ echo "describe 'test'" | hbase shell -n
$ echo $?
# 返回0成功,返回其餘失敗
# 結果輸出到文件 $ echo "describe 'test'" | hbase shell -n > tmp.log # 不打印輸出結果 $ echo "describe 'test" | hbase shell -n > /dev/null 2>&1
3. 使用Bash腳本spa
3.1)單命令執行debug
#!/bin/bash echo "describe 'test:t'" | hbase shell -n > tmp.log status=$? echo "status:" $status if [ $status == 0 ]; then echo "succee" else echo "fail" fi
3.2) 交互界面執行code
#!/bin/bash arr=('test:t1' 'test:t2') for table in ${arr[@]} do echo \'$table\' hbase shell << EOF disable '$table' drop '$table' exit EOF done
4.讀取文本文件blog
執行rem
$ hbase shell ./commands.txt
commands.txt內容以下:
create 'test', 'cf' list 'test' put 'test', 'row1', 'cf:a', 'value1' put 'test', 'row2', 'cf:b', 'value2' put 'test', 'row3', 'cf:c', 'value3' put 'test', 'row4', 'cf:d', 'value4' scan 'test' get 'test', 'row1' disable 'test' enable 'test' exit
5. 傳遞VM參數get
$ HBASE_SHELL_OPTS="-verbose:gc -XX:+PrintGCApplicationStoppedTime -XX:+PrintGCDateStamps \ -XX:+PrintGCDetails -Xloggc:$HBASE_HOME/logs/gc-hbase.log" hbase shell
6. 配置覆蓋it
$ hbase shell -Dhbase.zookeeper.quorum=ZK0.remote.cluster.example.org,ZK1.remote.cluster.example.org,ZK2.remote.cluster.example.org -Draining=false
7. 開啓debug模式io
hbase(main):007:0> debug Debug mode is ON hbase(main):008:0> debug Debug mode is OFF
$ ./bin/hbase shell -d