參考文章:?[https://www.yiibai.com/hbase/](https://www.yiibai.com/hbase/)
結構描述: 表是行的集合。 行是列族的集合。 列族是列的集合。 列是鍵值對的集合。
1.特定的前綴或尾綴格式構成表名,可以成為命名空間,如
amz\_jp:tb\_seller 其中amz\_jp:可以當命名空間
2.Hbase的緯度
表 =>列族 =>列 =>值?\[列族是必須的,列不是必須的,列族是列的統一抽象\]
3.hbase shell 常用命令
status? 查看hbase服務器狀態
list? 列出所有的表
exists "table\_name"? 檢查某表是否存在
describe "table\_name"? 描述表結構
create "table\_name"?, "column\_family1" , "column\_family2"? ?創建某表 并確定列族
4.habse以row\_key作為主鍵存儲列信息? 其中row\_key具有字典序和自然序的特征排列存儲。所以設計時要考慮該特性將關聯數組構造成同結構row\_key的數據在一起
shell 命令參數 最好都用單引號
??
shell
進入hbase shell console
$HBASE\_HOME/bin/hbase shell
如果有kerberos認證,需要事先使用相應的keytab進行一下認證(使用kinit命令),認證成功之后再使用hbase shell進入可以使用whoami命令可查看當前用戶
hbase(main)> whoami
表的管理
1)查看有哪些表
hbase(main)> list
使用exists 命令驗證表是否被刪除。
hbase(main)> exists 'test'
Table test does not exist
2)創建表
\# 語法:create , {NAME => , VERSIONS => }
\# 例如:創建表t1,有兩個column family:f1,f2,且版本數均為2
hbase(main)> create 't1',{NAME => 'f1', VERSIONS => 2},{NAME => 'f2', VERSIONS => 2}
3)刪除表
分兩步:首先disable,然后drop
例如:刪除表t1
hbase(main)> disable 't1'
hbase(main)> drop 't1'
4)查看表的結構
\# 語法:describe
\# 例如:查看表t1的結構
hbase(main)> describe 't1'
5)修改表結構
修改表結構必須先disable
添加列族
\# 語法:alter 't1', {NAME => 'f1'}, {NAME => 'f2', METHOD => 'delete'}
\# 例如:修改表t1的cf的TTL為180天
hbase(main)> disable 't1'
hbase(main)> alter 't1',{NAME=>'body',TTL=>'15552000'},{NAME=>'meta', TTL=>'15552000'}
hbase(main)> alter 't1','body1','meta1'
hbase(main)> enable 't1'
刪除列族
hbase> alter 'table name', 'delete' => 'column family'?
權限管理
1)分配權限
\# 語法 : grant 參數后面用逗號分隔
\# 權限用五個字母表示: "RWXCA".
\# READ('R'), WRITE('W'), EXEC('X'), CREATE('C'), ADMIN('A')
\# 例如,給用戶'luanpeng'分配對表t1有讀寫的權限,
hbase(main)> grant 'luanpeng','RW','t1'
2)查看權限
\# 語法:user\_permission
\# 例如,查看表t1的權限列表
hbase(main)> user\_permission 't1'
3)收回權限
\# 與分配權限類似,語法:revoke
\# 例如,收回luanpeng用戶在表t1上的權限
hbase(main)> revoke 'luanpeng','t1'
表數據的增刪改查
1)添加數據
\# 語法:put ,,,,
\# 例如:給表t1的添加一行記錄:rowkey是rowkey001,family name是f1,column name是col1,value是value01,timestamp:系統默認
hbase(main)> put 't1','rowkey001','f1:col1','value01'
用法比較單一。
2)查詢數據
a)查詢某行記錄
\# 語法:get ,,\[,....\]
\# 例如:查詢表t1,rowkey001中的f1下的col1的值
hbase(main)> get 't1','rowkey001', 'f1:col1'
\# 或者:
hbase(main)> get 't1','rowkey001', {COLUMN=>'f1:col1'}
\# 查詢表t1,rowke002中的f1下的所有列值
hbase(main)> get 't1','rowkey001'
b)掃描表
\# 語法:scan , {COLUMNS => \[ ,.... \], LIMIT => num}
\# 另外,還可以添加STARTROW、TIMERANGE和FITLER等高級功能
\# 例如:掃描表t1的前5條數據
hbase(main)> scan 't1',{LIMIT=>5}
c)查詢表中的數據行數
\# 語法:count , {INTERVAL => intervalNum, CACHE => cacheNum}
\# INTERVAL設置多少行顯示一次及對應的rowkey,默認1000;CACHE每次去取的緩存區大小,默認是10,調整該參數可提高查詢速度
\# 例如,查詢表t1中的行數,每100條顯示一次,緩存區為500
hbase(main)> count 't1', {INTERVAL => 100, CACHE => 500}
3)刪除數據
a )刪除行中的某個列值
\# 語法:delete , ,? , ,必須指定列名
\# 例如:刪除表t1,rowkey001中的f1:col1的數據
hbase(main)> delete 't1','rowkey001','f1:col1'
注:將刪除改行f1:col1列所有版本的數據
b )刪除行
\# 語法:deleteall , ,? , ,可以不指定列名,刪除整行數據
\# 例如:刪除表t1,rowk001的數據
hbase(main)> deleteall 't1','rowkey001'
c)刪除表中的所有數據
\# 語法: truncate
\# 其具體過程是:disable table -> drop table -> create table
\# 例如:刪除表t1的所有數據
hbase(main)> truncate 't1'
Region管理
1)移動region
\# 語法:move 'encodeRegionName', 'ServerName'
\# encodeRegionName指的regioName后面的編碼,ServerName指的是master-status的Region Servers列表
\# 示例
hbase(main)>move '4343995a58be8e5bbc739af1e91cd72d', 'db-41.xxx.xxx.org,60020,1390274516739'
2)開啟/關閉region
\# 語法:balance\_switch true|false
hbase(main)> balance\_switch
3)手動split
\# 語法:split 'regionName', 'splitKey'
4)手動觸發major compaction
#語法:
#Compact all regions in a table:
#hbase> major\_compact 't1'
#Compact an entire region:
#hbase> major\_compact 'r1'
#Compact a single column family within a region:
#hbase> major\_compact 'r1', 'c1'
#Compact a single column family within a table:
#hbase> major\_compact 't1', 'c1'
配置管理及節點重啟
1)修改hdfs配置
hdfs配置位置:/etc/hadoop/conf
\# 同步hdfs配置
cat /home/hadoop/slaves|xargs -i -t scp /etc/hadoop/conf/hdfs-site.xml hadoop@{}:/etc/hadoop/conf/hdfs-site.xml
#關閉:
cat /home/hadoop/slaves|xargs -i -t ssh hadoop@{} "sudo /home/hadoop/cdh4/hadoop-2.0.0-cdh4.2.1/sbin/hadoop-daemon.sh --config /etc/hadoop/conf stop datanode"
#啟動:
cat /home/hadoop/slaves|xargs -i -t ssh hadoop@{} "sudo /home/hadoop/cdh4/hadoop-2.0.0-cdh4.2.1/sbin/hadoop-daemon.sh --config /etc/hadoop/conf start datanode"
1
2
3
4
5
6
2)修改hbase配置
hbase配置位置:/home/hadoop/hbase
\# 同步hbase配置
cat /home/hadoop/hbase/conf/regionservers|xargs -i -t scp /home/hadoop/hbase/conf/hbase-site.xml hadoop@{}:/home/hadoop/hbase/conf/hbase-site.xml
\# graceful重啟
cd ~/hbase
bin/graceful\_stop.sh --restart --reload --debug inspurXXX.xxx.xxx.org
hbase shell 腳本
編寫一個文本文件hbasedemo.txt:
disable 'table1'
drop 'table1'
create 'table1', 'column\_family1','column\_family2'??
list 'table1'??
put 'table1', 'row\_key1', 'column\_family1:col1', 'value1'??
put 'table1', 'row\_key2', 'column\_family1:col2', 'value2'??
put 'table1', 'row\_key3', 'column\_family2:col3', 'value3'??
put 'table1', 'row\_key4', 'column\_family2:col4', 'value4'??
scan 'table1'??
scan 'table1',{LIMIT=>5}
get 'table1', 'row\_key1'??
get 'table1','row\_key1', 'column\_family1:col1'
count 'table1'
disable 'table1'??
alter 'table1',NAME=>'column\_family3'
alter 'table1','delete'=>'column\_family3'
enable 'table1'?
describe 'table1'?
grant 'root','RW','table1'
user\_permission 'table1'
delete 'table1','row\_key1','column\_family1:col1'
deleteall 'table1','row\_key1'
truncate 'table1'
在HBase shell中運行這個腳本
hbase shell hbasedemo.txt
- 常見功能
- 第三方授權登錄
- 郵件發送
- 簡易聊天室
- 獲取各國匯率
- PHP獲取服務器硬件指標
- 數據上報之
- web開發
- 開發規范
- 前端
- 踩坑
- 將footer固定在底部
- bootstrap
- Metronic
- 用到的jquery插件
- bootstrap-hover-dropdown
- jquery.slimscroll
- jquery.blockui
- bootstrap-switch
- js.cookie
- moment
- bootstrap-daterangepicker
- morris
- raphael
- jquery.waypoints
- jquery.counterup
- select2
- 取值和設置默認值
- vue
- axios
- 瀏覽器
- 谷歌瀏覽器
- 谷歌插件
- layui
- layui-表格
- layui-表單
- layui-彈窗
- layui-分頁
- 后端
- 操作系統
- linux
- 用戶管理
- 文件管理
- 目錄管理
- 壓縮和解壓縮
- 進程查看
- 端口查看
- 開機自啟動服務
- 定時任務
- shell腳本
- 殺掉運行超過指定時長指定服務的進程
- 獲取服務器使用狀態
- bash-shell連接socket
- 自定義快捷命令
- centos-踩坑
- 防火墻
- 軟件
- yum
- vim
- screen
- window
- 語言
- PHP
- 配置優化
- 框架
- thinkphp5.1+
- think命令行
- laravel6.+
- 維護模式
- 根據環境讀取不同配置
- laravel6.+采坑
- laravel坑位
- 數據庫事務
- 任務調度
- 文件權限問題
- 增強框架
- larvel:elastic-search
- 圖形驗證碼
- laravel獲取ip
- 函數
- strtotime
- 正則匹配
- 類
- 接口類與抽象類
- 類相關的關鍵字 - abstract
- 類相關的關鍵字 - interface
- PHP有關類的調用方式"->"與"::"的區別
- 擴展
- 問題歸納
- json_encode和json_decode
- 字符串的運算
- curl
- 優化php效率
- 數組相加合并與array_merge
- 時區轉換
- 不常用特性
- php反射
- 包管理器-composer
- GuzzleHttp
- Python
- Go
- 數據庫
- Redis
- 安裝
- 本地化-數據備份
- php-redis操作
- Mysql
- mysql-命令集合
- 設置終端可訪問
- 數據庫設計
- 用戶基礎信息表
- 踩坑集合
- mysql-2002
- mysql-2054
- 優化策略
- mysql-密碼驗證插件
- 一些牛逼的sql查詢
- topN
- 無限級分類
- Memcache
- MongoDb
- 安裝mongo-server
- 安裝php-mongodb擴展
- 在laravel中使用mongoDB
- 客戶端軟件
- Hbase
- Elasticsearch
- elastic-search
- restfulApi操作es
- web服務器
- 1.nginx
- 配置語法規則
- 配置詳解
- rewrite規則
- request_filename
- 2.apache
- 功能設計
- 加密解密
- Base64
- 對亞馬遜SKU加密
- 兼職項目中的加解密
- 騰訊外包時的加密
- 接口設計
- 接口限流設計
- 分庫分表
- 遍歷展示文件目錄結構
- 時區換算
- 文件切割
- 解析xml字符串
- 項目
- 博客后臺管理
- 亞馬遜廣告API
- 官方指引文檔
- 開發人員中心
- 應用商店
- 第三方庫
- 申請API郵件記錄
- 亞馬遜MWS
- 付款報告
- 亂碼
- 亞馬遜管理庫存報告
- 報告
- 商品
- 入庫
- 履行
- 出庫
- 財務
- 訂單
- 異步任務處理
- 集群如何同步代碼
- 基本開發流程
- 文檔管理
- showdoc
- 運行環境
- 開發環境
- vagrant
- windows上配置安裝
- vagrant安裝插件緩慢
- 更換ssh默認端口映射
- 設置x-shell密碼登錄
- 使用市場的box-homestead
- homestead-7: Box 'lc/homestead'
- 常見問題
- 虛擬環境reboot
- 突然無法使用
- phpStudy
- wamp
- 壓測性能
- VPN
- vultr
- 凌空圖床
- 寶塔
- 自動化部署
- 版本管理軟件鉤子
- 線上環境-LNMP
- centos7
- nginx
- mysql
- mysql開機自啟
- mysql-更換默認端口
- datetime字段類型默認值
- php
- php擴展安裝
- redis
- swoole
- gd
- BCMath
- igbinary
- zstd
- 包管理器:composer
- 優化性能
- nodejs
- 更新gcc版本
- 版本控制
- git
- 常用命令
- gitlab
- 版本管理規范
- 使用阿里云創建遠程倉庫
- git自動化部署
- svn
- 忽略指定文件
- 拉取代碼
- 自動化運維
- jekins
- 容器
- 集群
- 架構設計
- 設計原則
- 閱讀參考
- 代碼規劃
- 架構實戰
- 服務治理
- 權限控制設計
- 具體設計
- 計劃
- 疑問知識點
- 讀書筆記
- 高性能Mysql
- TCP-IP詳解-卷一:協議
- 思考
- php如何實現并發執行
- 對接調用設計
- 如何在瀏覽器上實現插件
- 如何設計一個app結合業務告警
- mysql的where查詢沒有用到索引
- 為啥in查詢比循環嵌套sql的查詢還要慢
- 使用git來創建屬于自己的composer包
- 翻頁獲取數據的時候又新增了數據
- 安全思路
- 月報
- PHP ?? 和 ?: 的區別
- PHP異步執行
- redis集群的目標是什么
- 大文件數據處理
- 性能瓶頸分析
- 命令行里輸出帶顏色的字體
- 面試問題合集
- 基礎
- 安全
- 算法
- 冒泡排序
- 快速排序
- 二分法查詢數組指定成員
- 字符查找匹配
- 令牌桶
- 漏桶
- 計數器
- 代理
- 協議
- http
- 狀態碼
- tcp
- udp
- Oauth2.0
- 設計模式
- 單例模式
- 適配器模式
- 工廠模式
- 觀察者模式
- 流程化
- 地址欄輸入網址到返回網頁的流程
- 題目收集
- 工具
- rabbitMq
- rabbitMQ用戶管理
- 生產者
- 消費者
- 支持TP5.*的think-queue
- 消息丟失
- 消費者報錯
- rabbitMQ配置優化
- 磁盤滿載導致服務掛掉
- PHP類庫
- rabbitMQ踩坑
- navicat
- vscode
- phpstorm
- 激活碼
- markdown
- PHP自定義類庫
- 工具類
- 領導力
- 任務分配
- 代碼組織
- 不要重復
- 避免污染
- 接口定義規范
- 小業務需求
- 獲取充值面額組成
- 監控服務器CPU和內存
- shell腳本版本