热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HBase系列2HBase快速入门

@此处略过安装。二.HbaseShell操作2.1基本操作1.进入Hbase客户端[root@hp1]hbaseshellHBaseShellUsehelptogetlisto

Table of Contents

  • 一. Hbase安装
  • 二. Hbase Shell 操作
    • 2.1 基本操作
    • 2.2 表的操作


一. Hbase安装

本地已经安装CDH 6.3.1版本,已安装Hbase,如下截图:

image.png

此处略过安装。


二. Hbase Shell 操作

2.1 基本操作



  1. 进入Hbase客户端

[root@hp1 ~]# hbase shell
HBase Shell
Use "help" to get list of supported commands.
Use "exit" to quit this interactive shell.
For Reference, please visit: http://hbase.apache.org/2.0/book.html#shell
Version 2.1.0-cdh6.3.1, rUnknown, Thu Sep 26 02:56:37 PDT 2019
Took 0.0010 seconds
Ignoring executable-hooks-1.6.0 because its extensions are not built. Try: gem pristine executable-hooks --version 1.6.0
Ignoring gem-wrappers-1.4.0 because its extensions are not built. Try: gem pristine gem-wrappers --version 1.4.0
2.5.1 :001 >


  1. 查看帮助命令

2.5.1 :001 > help
HBase Shell, version 2.1.0-cdh6.3.1, rUnknown, Thu Sep 26 02:56:37 PDT 2019
Type 'help "COMMAND"', (e.g. 'help "get"' -- the quotes are necessary) for help on a specific command.
Commands are grouped. Type 'help "COMMAND_GROUP"', (e.g. 'help "general"') for help on a command group.
COMMAND GROUPS:
Group name: general
Commands: processlist, status, table_help, version, whoami
......
......

2.2 表的操作



  1. 创建表

2.5.1 :004 > create 'student','info'
Created table student
Took 1.7550 seconds
=> Hbase::Table - student
2.5.1 :005 >


  1. 插入数据到表

2.5.1 :006 > put 'student','1001','info:sex','male'
Took 0.2356 seconds
2.5.1 :007 > put 'student','1001','info:age','18'
Took 0.0093 seconds
2.5.1 :008 > put 'student','1002','info:name','Janna'
Took 0.0126 seconds
2.5.1 :009 > put 'student','1002','info:sex','female'
Took 0.0063 seconds
2.5.1 :010 > put 'student','1002','info:age','20'
Took 0.0074 seconds
2.5.1 :011 >


  1. 扫描查看表的数据

2.5.1 :015 > scan 'student'
ROW COLUMN+CELL
1001 column=info:age, timestamp=1640657568508, value=18
1001 column=info:sex, timestamp=1640657563443, value=male
1002 column=info:age, timestamp=1640657582172, value=20
1002 column=info:name, timestamp=1640657573111, value=Janna
1002 column=info:sex, timestamp=1640657577458, value=female
2 row(s)
Took 0.0271 seconds
2.5.1 :016 > scan 'student',{STARTROW => '1001', STOPROW => '1001'}
ROW COLUMN+CELL
1001 column=info:age, timestamp=1640657568508, value=18
1001 column=info:sex, timestamp=1640657563443, value=male
1 row(s)
Took 0.0177 seconds
2.5.1 :017 > scan 'student',{STARTROW => '1001'}
ROW COLUMN+CELL
1001 column=info:age, timestamp=1640657568508, value=18
1001 column=info:sex, timestamp=1640657563443, value=male
1002 column=info:age, timestamp=1640657582172, value=20
1002 column=info:name, timestamp=1640657573111, value=Janna
1002 column=info:sex, timestamp=1640657577458, value=female
2 row(s)
Took 0.0104 seconds
2.5.1 :018 >


  1. 查看表结构

2.5.1 :019 > describe 'student'
Table student is ENABLED
student
COLUMN FAMILIES DESCRIPTION
{NAME => 'info', VERSIOnS=> '1', EVICT_BLOCKS_ON_CLOSE => 'false', NEW_VERSION_BEHAVIOR => 'false', KEEP_DELETED_CELLS => 'FALSE', CACHE_DATA_ON_WRITE => 'false', DATA_BLOCK_ENCODING => 'NONE', TTL
=> 'FOREVER', MIN_VERSIOnS=> '0', REPLICATION_SCOPE => '0', BLOOMFILTER => 'ROW', CACHE_INDEX_ON_WRITE => 'false', IN_MEMORY => 'false', CACHE_BLOOMS_ON_WRITE => 'false', PREFETCH_BLOCKS_ON_OPEN =>
'false', COMPRESSION => 'NONE', BLOCKCACHE => 'true', BLOCKSIZE => '65536'}
1 row(s)
Took 0.0583 seconds
2.5.1 :020 >


  1. 更新指定字段的数据

2.5.1 :023 > put 'student','1001','info:name','Nick'
Took 0.0124 seconds
2.5.1 :024 > put 'student','1001','info:age','100'
Took 0.0069 seconds
2.5.1 :025 >


  1. 查看"指定行"或"指定列族:列"的数据

2.5.1 :025 > get 'student','1001'
COLUMN CELL
info:age timestamp=1640658019973, value=100
info:name timestamp=1640658015683, value=Nick
info:sex timestamp=1640657563443, value=male
1 row(s)
Took 0.0438 seconds
2.5.1 :026 > get 'student','1001','info:name'
COLUMN CELL
info:name timestamp=1640658015683, value=Nick
1 row(s)
Took 0.0214 seconds


  1. 统计表的行数

2.5.1 :036 > count 'student'
2 row(s)
Took 0.0273 seconds
=> 2
2.5.1 :037 >


  1. 删除

    删除某 rowkey的全部数据:

2.5.1 :037 > deleteall 'student','1001'
Took 0.0148 seconds
2.5.1 :038 > deleteall 'student','1002','info:sex'
Took 0.0077 seconds


  1. 清空表数据

2.5.1 :043 > truncate 'student'
Truncating 'student' table (it may take a while):
Disabling table...
Truncating table...
Took 2.0864 seconds
2.5.1 :044 >


  1. 删除表

    首先需要先让表为disable状态:

2.5.1 :049 > disable 'student'
Took 0.4318 seconds
2.5.1 :050 > drop 'student'
Took 0.2503 seconds
2.5.1 :051 >


  1. 变更表信息

    将info列族中的数据存放3个版本:

2.5.1 :059 > create 'student','info'
Created table student
Took 0.7353 seconds
=> Hbase::Table - student
2.5.1 :060 > alter 'student',{NAME=>'info',VERSIOnS=>3}
Updating all regions with the new schema...
1/1 regions updated.
Done.
Took 1.9441 seconds
2.5.1 :061 >


推荐阅读
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 在CentOS/RHEL 7/6,Fedora 27/26/25上安装JAVA 9的步骤和方法
    本文介绍了在CentOS/RHEL 7/6,Fedora 27/26/25上安装JAVA 9的详细步骤和方法。首先需要下载最新的Java SE Development Kit 9发行版,然后按照给出的Shell命令行方式进行安装。详细的步骤和方法请参考正文内容。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • FineReport平台数据分析图表显示部分系列接口的应用场景和实现思路
    本文介绍了FineReport平台数据分析图表显示部分系列接口的应用场景和实现思路。当图表系列较多时,用户希望可以自己设置哪些系列显示,哪些系列不显示。通过调用FR.Chart.WebUtils.getChart("chartID").getChartWithIndex(chartIndex).setSeriesVisible()接口,可以获取需要显示的系列图表对象,并在表单中显示这些系列。本文以决策报表为例,详细介绍了实现方法,并给出了示例。 ... [详细]
  • 【shell】网络处理:判断IP是否在网段、两个ip是否同网段、IP地址范围、网段包含关系
    本文介绍了使用shell脚本判断IP是否在同一网段、判断IP地址是否在某个范围内、计算IP地址范围、判断网段之间的包含关系的方法和原理。通过对IP和掩码进行与计算,可以判断两个IP是否在同一网段。同时,还提供了一段用于验证IP地址的正则表达式和判断特殊IP地址的方法。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
author-avatar
唯爱WE创丶
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有