HBase shell 命令。

HBase shell 命令。

 

    1. 进入hbase shell console
      $HBASE_HOME/bin/hbase shell
      如果有kerberos认证,需要事先使用相应的keytab进行一下认证(使用kinit命令),认证成功之后再使用hbase shell进入可以使用whoami命令可查看当前用户
      hbase(main)> whoami
    2. 表的管理
      1)查看有哪些表
      hbase(main)> list

      2)创建表

      # 语法:create <table>, {NAME => <family>, VERSIONS => <VERSIONS>}
      # 例如:创建表t1,有两个family name: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 <table>
      # 例如:查看表t1的结构
      hbase(main)> describe 't1'

      5)修改表结构
      修改表结构必须先disable

      # 语法:alter 't1', {NAME => 'f1'}, {NAME => 'f2', METHOD => 'delete'}
      # 例如:修改表test1的cf的TTL为180天
      hbase(main)> disable 'test1'
      hbase(main)> alter 'test1',{NAME=>'body',TTL=>'15552000'},{NAME=>'meta', TTL=>'15552000'}
      hbase(main)> enable 'test1'
    3. 权限管理
      1)分配权限
      # 语法 : grant <user> <permissions> <table> <column family> <column qualifier> 参数后面用逗号分隔
      # 权限用五个字母表示: "RWXCA".
      # READ('R'), WRITE('W'), EXEC('X'), CREATE('C'), ADMIN('A')
      # 例如,给用户‘test'分配对表t1有读写的权限,
      hbase(main)> grant 'test','RW','t1'

      2)查看权限

      # 语法:user_permission <table>
      # 例如,查看表t1的权限列表
      hbase(main)> user_permission 't1'

      3)收回权限

      # 与分配权限类似,语法:revoke <user> <table> <column family> <column qualifier>
      # 例如,收回test用户在表t1上的权限
      hbase(main)> revoke 'test','t1'
    4. 表数据的增删改查
      1)添加数据
      # 语法:put <table>,<rowkey>,<family:column>,<value>,<timestamp>
      # 例如:给表t1的添加一行记录:rowkey是rowkey001,family name:f1,column name:col1,value:value01,timestamp:系统默认
      hbase(main)> put 't1','rowkey001','f1:col1','value01'
      用法比较单一。

      2)查询数据
      a)查询某行记录

      # 语法:get <table>,<rowkey>,[<family:column>,....]
      # 例如:查询表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 <table>, {COLUMNS => [ <family:column>,.... ], LIMIT => num}
      # 另外,还可以添加STARTROW、TIMERANGE和FITLER等高级功能
      # 例如:扫描表t1的前5条数据
      hbase(main)> scan 't1',{LIMIT=>5}

      c)查询表中的数据行数

      # 语法:count <table>, {INTERVAL => intervalNum, CACHE => cacheNum}
      # INTERVAL设置多少行显示一次及对应的rowkey,默认1000;CACHE每次去取的缓存区大小,默认是10,调整该参数可提高查询速度
      # 例如,查询表t1中的行数,每100条显示一次,缓存区为500
      hbase(main)> count 't1', {INTERVAL => 100, CACHE => 500}

      3)删除数据
      a )删除行中的某个列值

      # 语法:delete <table>, <rowkey>,  <family:column> , <timestamp>,必须指定列名
      # 例如:删除表t1,rowkey001中的f1:col1的数据
      hbase(main)> delete 't1','rowkey001','f1:col1'

      注:将删除改行f1:col1列所有版本的数据
      b )删除行

      # 语法:deleteall <table>, <rowkey>,  <family:column> , <timestamp>,可以不指定列名,删除整行数据
      # 例如:删除表t1,rowk001的数据
      hbase(main)> deleteall 't1','rowkey001'

      c)删除表中的所有数据

      # 语法: truncate <table>
      # 其具体过程是:disable table -> drop table -> create table
      # 例如:删除表t1的所有数据
      hbase(main)> truncate 't1'
    5. 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'
    6. 配置管理及节点重启
      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"

      2)修改hbase配置
      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

 

转载于:https://www.cnblogs.com/yjd_hycf_space/p/6930737.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355475.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python常用库有哪些餐厅_Python常用库整理

前两天有个同学问我关于Tkinter库的问题&#xff0c;但是我连Tkinter库是干啥的都不清楚&#xff0c;有点尴尬。Python库博大精深&#xff0c;涉及各个领域&#xff0c;多了解一些著名的库总比不知道的好。GUI图形界面TkinterwxPythonPyGTKPyQtPySideWeb框架Djangoweb2pyflaskb…

减少Java垃圾收集开销的5条提示

保持较低的GC开销的一些最有用的技巧是什么&#xff1f; 随着Java 9的一次再次延迟发布&#xff0c;G1&#xff08;“ Garbage First”&#xff09;垃圾收集器将设置为HotSpot JVM的默认收集器。 从串行垃圾收集器一直到CMS收集器&#xff0c;JVM在其整个生命周期中都见证了许…

关于collectionview布局的坑

不知道写了多少次collectionview&#xff0c;步了很多坑&#xff0c;现在看来虽然达到了自己想要的结果&#xff0c;却不知道其中所以然。还是总结一下&#xff0c;免得再走弯路&#xff1b; 场景是这样的&#xff0c;我要定制一个显示选择图片的排列&#xff0c;想要实现横向排…

python可以用来编写计算机网络程序吗_计算机网络(基于python做的笔记 )

计算机网络(UDP 和 TCP)概述为了让在不同的电脑上运行的软件&#xff0c;之间能够互相传递数据&#xff0c;就需要借助网络的功能使用网络能够把多方链接在一起&#xff0c;然后可以进行数据传递所谓的网络编程就是&#xff0c;让在不同的电脑上的软件能够进行数据传递&#xf…

git冲突Please move or remove them before you can merge

解决Git冲突造成的Please move or remove them before you can merge git clean -d -fx ""其中x -----删除忽略文件已经对git来说不识别的文件d -----删除未被添加到git的路径中的文件f -----强制运行 转载于:https://www.cnblogs.com/wicub/p/6934597.html

linux不重启换root密码是什么原因,在Linux下修改和重置root密码的方法(超简单)

刚开始接触linux的人&#xff0c;忘记了root密码可能会不知所措。想找回自己的root密码&#xff0c;但是又不知道方法。其实&#xff0c;只需要简单的几步就可以重置自己的root密码了(找回密码我也不会)1.开机HcQBEm上敲击e&#xff0c;然后编辑选项2.在linux16这一行&#xff…

python命令行参数作用_Python命令行参数解析模块argparse

前言更多内容&#xff0c;请访问我的 个人博客。以前 optparse 比较火&#xff0c;但是在python2.7版本后&#xff0c;官方不再维护这个模块&#xff0c;转而大力支持 argparse 。argparse 模块可以让人轻松编写用户友好的命令行接口。她可以从 sys.argv 中解析出参数&#xff…

SCP-bzoj-1019

项目编号&#xff1a;bzoj-1019 项目等级&#xff1a;Safe 项目描述&#xff1a; 戳这里 特殊收容措施&#xff1a; 对于一个hanoi&#xff0c;知道了各种移动操作的优先级&#xff0c;也就确定了方案。可以证明对于盘子数为N的hanoi&#xff0c;任意移动方案都等价于将数目为N…

shell编程入门 linux解释器原理,Shell编程入门Linux解释器原理详细介绍 使用Shell进行工作的人们对.doc...

Shell编程入门Linux解释器原理详细介绍 使用Shell进行工作的人们对Shell编程入门&#xff1a;Linux解释器原理详细介绍使用Shell进行工作的人们对Unix/Linux下的Shell编程都很熟悉&#xff0c;在所有的Shell编程的书中都会提到#!/bin/bash,而这里到底包含了些什么&#xff1f;对…

一键分享手机代码_通过广告路由器指定手机浏览器自动认证WIFI上网 附代码

说说应用过程&#xff0c;下面用手机QQ浏览器为例。在路由器搭建免费WIFI&#xff0c;用户连接免费WIFI后&#xff0c;使用手机QQ浏览器点击打开任意网页即可自动通过认证并上网&#xff0c;有的手机会自动打开认证网页&#xff0c;如果使用其他手机浏览器则自动跳转到引导认证…

netbeans7.4_NetBeans 7.1:创建自定义提示

netbeans7.4我已经在帖子中对我最喜欢的NetBeans提示进行了讨论&#xff0c;这些帖子中包含用于现代化Java代码的七个NetBeans提示和七个不可或缺的NetBeans Java提示 。 这两个帖子中涉及的十四个提示仅占NetBeans支持的“即开即用”提示总数的一小部分。 但是&#xff0c;由于…

linux uboot启动流程分析,uboot启动流程分析

uboot版本为NXP维护的2016.03版本下载地址为http://git.freescale.com/git/...分析uboot的启动流程&#xff0c;需要编译一下uboot&#xff0c;然后打开链接脚本u-boot.lds在u-boot.lds中1 OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf…

matlab求解线性方程组

模电题现在看来是不用matlab解方程不可做了orz 绝望&#xff0c;各种绝望&#xff0c;平时不努力到了期末季就焦虑得不行。 左除法就好 xA/b; 如果有符号变量&#xff0c;用syms声明一下就好。 越来越懒了orz好吧&#xff0c;解线性方程组这种毫无技术含量的东西用matlab倒是没…

魔术命令python_Python前10个魔术命令可以帮助您提高生产率

注意&#xff1a;Python不仅是最常用的编程语言&#xff0c;而且在集成新函数时也是最灵活的。例如&#xff0c;magic命令是Python shell的重要功能之一。让我们来看看10个简单的魔法命令来帮助工程师提高生产率。Python中的magic命令是什么&#xff1f;Magic命令是对常规Pytho…

JavaOne 2015 –第二十版十大收获

我们刚刚在旧金山有了JavaOne的第二十版。 这将是我自2004年以来第十二次参加不间断的系列活动。最大的教训是什么&#xff0c;可以揭示Java的未来。 模块化斗争 自从Java 2007首次提到模块以来&#xff0c;已经花费了将近9年的时间&#xff0c;或者说&#xff0c;直到2016年9…

linux can接口不使用过滤,linux can 总线socket接口测试使用

最近调试一个sja1000的can驱动&#xff0c;发现到了2.6.36&#xff0c;linux把can总线封装成了网络接口。内核文档里给出了这么修改的原因。1. Overview / What is Socket CAN--------------------------------The socketcan package is an implementation of CAN protocols (C…

IOS--文件管理NSFileManager

iOS的沙盒机制。应用仅仅能訪问自己应用文件夹下的文件。iOS不像android。没有SD 卡概念。不能直接訪问图像、视频等内容。iOS应用产生的内容&#xff0c;如图像、文件、缓存内容等都必须存储在自己的沙盒内。默认情况下&#xff0c;每一个沙盒含有3个文件 夹&#xff1a;Docum…

linux修改文件内容_详解5种实用方法---Linux系统清空或删除大文件内容

概述有时我们在处理Linux终端中的文件时&#xff0c;可能要去清除文件的内容&#xff0c;而无需使用任何Linux命令行编辑器打开它。怎么才能实现呢&#xff1f;下面通过几种不同的方式教大家清空文件内容。1.通过重定向到空来清空文件内容使用shell重定向null(不存在的对象)清空…

c语言include不起作用,c语言中include的使用方法

c语言中include的使用方法发布时间&#xff1a;2020-06-16 09:09:37来源&#xff1a;亿速云阅读&#xff1a;185作者&#xff1a;Leah这篇文章将为大家详细讲解有关c语言中include的使用方法&#xff0c;小编觉得挺实用的&#xff0c;因此分享给大家做个参考&#xff0c;希望大…

linux下如何安装配置redis及主从配置

redis是一种非关系型数据存储工具&#xff0c;这区别于传统的关系型数据库(像MySQL等)&#xff0c;类似于memcache&#xff0c;并且其内部集成了对list(链表)、set(集合)的操作&#xff0c;可以很方便快速的处理数据(像插入、删除list取交集 并集 差集等)&#xff0c;这极大的减…