写点什么

使用 Athena 替换 Hbase 实现对历史数据的查询分析

  • 2019-11-27
  • 本文字数:3677 字

    阅读完需:约 12 分钟

使用 Athena 替换 Hbase 实现对历史数据的查询分析

Apache HBase 是一种构建在 HDFS 之上的分布式、面向列的存储系统。在需要实时读写、随机访问超大规模数据集时,作为用户的首选分布式数据库;但 HBase 也有其局限性,譬如说不支持 SQL 语句查询,随着数据规模的变大,造成用户成本的大幅增加,其稳定性和故障恢复能力会变差,也给运维人员带来很大的挑战;我们在拜访客户时也发现有些用户将大量的历史数据和在线数据全部存储在 HBase 中也遇到了上述问题。因而本文将介绍一种帮助用户从 HBase 数据库中剥离出历史数据,减小 HBase 数据库的规模,提高其稳定性并大幅降低客户的成本,实现对历史数据的查询的方案。

Apache HBase 特点及应用场景

Apache HBase 是一个分布式,版本化,面向列的开源数据库,构建在 Aapche Hadoop 和 Aapche ZooKeeper 之上。它特别适合千万级的高并发海量数据的瞬间写入,而相对读数据量小的应用,支持存储结构化和非结构化数据和数据的多版本化。但它不适合大范围的扫描查询和支持多条件的查询,不支持基于 SQL 语句的查询。

Amazon Athena 特点及应用场景

Amazon Athena 是一种交互式查询服务,让您能够轻松使用标准 SQL 直接分析 Amazon S3 中的数据。只需在 AWS 管理控制台中单击几下,客户即可将 Athena 指向自己在 S3 中存储的数据,然后开始使用标准 SQL 执行临时查询并在数秒内获取结果。Athena 是 Serverless 服务,因此没有需要设置或管理的基础设施,客户只需为其执行的查询付费。它特别适合使用 Athena 处理日志、执行即席分析以及运行交互式查询。Athena 可以自动扩展并执行并行查询,因此可快速获取结果,对于大型数据集和复杂查询也不例外。


本次实验演示的 Demo 数据来自于纽约出租车公司公布的公开数据源 2017 年 1 月到 6 月份 Green Taxi trip 数据,下载链接:https://www1.nyc.gov/site/tlc/about/tlc-trip-record-data.page。

准备模拟数据并上传到 S3 Bucket

登陆 AWS 管理控制台,创建 S3 bucket 命名为 nytaxisdata,然后创建三个文件夹分别命名为 green,hbasedata,hbaseexport 如下图所示:



处理数据


清理掉原始数据中的空格列,运行如下命令:


Bash


awk 'BEGIN{FS=OFS=","}{gsub(/ /,"-",$2);gsub(/ /,"-",$3);print $0}' green_tripdata_2017-01.csv |more
[hadoop@ip-172-31-28-170 ~]$ awk 'BEGIN{FS=OFS=","}{gsub(/ /,"-",$2);gsub(/ /,"-",$3);print $2,$3,$1,$6,$7}' green_tripdata_2017-01.csv >>greentrip01.csv
复制代码


如下图所示:



分别依次处理完对应的 6 个 excel 文件。然后将处理完的 2017 年 1 月到 6 月份的数据文件上传到 green 文件夹内,如下图所示:


创建 EMR 集群

登陆到 AWS 管理控制台,选择 EMR 服务,点击创建集群,如下图所示:



点击 Go to Advanced options,选择 Hadoop 和 HBase 服务如下图所示:



在 Storage Mode 中选择 S3,并设置上面刚创建的 bucket 路径 s3://nytaxisdata/hbasedata,如下图所示:



在 Hardware Configuration 设置中选择 Uniform instance groups,并设置网络,子网组及根卷大小,此处设置为 100G,如下图所示:



点击下一步,设置 EMR 集群的节点类型和实例数,如下图所示:



点击下一步输入集群名称 hbasecluster,其他默认即可,如下图所示:



点击 Next,设置 EC2 key pair,如下图所示:



点击 Create cluster,等待集群创建完成。

登陆 HBase 集群

创建一个表名为 taxiinfo 的表,指定列簇为 userinfo 和 Others,运行如下命令:


Bash


hbase(main):001:0> create 'taxiinfo','dropofftime','comno','others'
复制代码


如下图所示:


导入数据到 HBase 集群

运行如下命令:


Bash


sudo hbase org.apache.hadoop.hbase.mapreduce.ImportTsv -Dimporttsv.separator="," -Dimporttsv.columns=HBASE_ROW_KEY,dropofftime,comno,others:distance,others:length taxiinfo s3://nytaxisdata/green/greentrip01.csv
复制代码


一次运行上面的命令将 greentrip01.csc 到 greentrip06.csv 文件全部导入到 hbase 数据库名为 taxiinfo 中。


统计表中的数据总行数,运行命令 count,如下所示:


Bash


hbase(main):002:0> count 'taxiinfo',INTERVAL=>100000
Current count: 100000, row: 2017-01-04-22:58:55
Current count: 200000, row: 2017-01-08-16:39:14
Current count: 300000, row: 2017-01-12-15:35:40
……
Current count: 4300000, row: 2017-06-04-03:39:03
Current count: 4400000, row: 2017-06-08-09:56:53
Current count: 4500000, row: 2017-06-11-18:32:27
Current count: 4600000, row: 2017-06-15-20:14:35
Current count: 4700000, row: 2017-06-19-13:37:54
Current count: 4800000, row: 2017-06-23-15:21:13
Current count: 4900000, row: 2017-06-27-14:46:20
4989642 row(s) in 257.1330 seconds
=> 4989642
复制代码


至此,验证 HBase 中的数据准备完毕。

剥离 HBase 数据库中的历史数据

根据需要用户可以将 HBase 数据库中的历史数据进行导出,HBase 数据库中的数据导出为 CSV 文件有多种方式,譬如自己编写 MapReduce 类实现,或者借助 Pig 应用等,本文采用 happybase 包实现。HappyBase 是方便开发人员通过 python 实现与 HBase 进行交互的开发库,通过编写 Python 脚本方式非常灵活的将任意条件的存储在 HBase 中的数据抽取处理转换成 CSV 文件。


安装 HappyBase


登陆到 EMR Master 节点,运行如下命令:


Bash


[hadoop@ip-172-31-36-88 ~]$ sudo pip install happybase
复制代码


如下图所示:



导出 HBase 数据


编写 Python 脚本如下所示:


Python


import happybase, sys, os, string
# 设置导出数据目录/mnt
# Output directory for CSV files
outputDir = "/mnt"
# HBase Thrift server to connect to. Leave blank for localhost
server = ""
# 连接到HBASE数据库
c = happybase.Connection(server)
# Get the full list of tables
tables = c.tables()
# 轮询数据库中的所有表
for table in tables:
# 写文件
file = open(outputDir + "/" + table + ".csv", "w")
t = c.table(table)
print table + ": ",
count = 0
for prefix in string.printable:
try:
for key, data in t.scan(row_prefix=prefix):
# 第一个key
if count == 0:
startRow = key
for col in data:
value = data[col]
column = col[col.index(":")+1:]
# 写行,列,值
file.write("%s, %s, %s\n" % (key, column, value))
count += 1
except:
os.system("hbase-daemon.sh restart thrift")
c = happybase.Connection(server)
t = c.table(table)
continue
# 最后一个key
endRow = key
print "%s => %s, " % (startRow, endRow),
print str(count)
复制代码


保存运行命令:


Bash


python hbase_export_csv.py
复制代码


如下图所示数据导出 4989642:



将导出的 csv 文件上传到 s3://nytaxisdata/exportdata 文件夹下,如下图所示:


使用 Amazon Athena 实现对历史数据的查询

打开 AWS Athena 管理控制台,运行如下命令:


Bash


CREATE EXTERNAL TABLE `hbaseexport`(
`col0` string,
`col1` string,
`col2` string)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
STORED AS INPUTFORMAT
'org.apache.hadoop.mapred.TextInputFormat'
OUTPUTFORMAT
'org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat'
LOCATION
's3://nytaxisdata/hbaseexport/'
复制代码


如下图所示:



数据查询


在 SQL 脚本编写区,运行如下查询:


Bash


SELECT * FROM "nymetadatastore"."hbaseexport" limit 10;
复制代码


如下图所示:


总结

通过本篇您将了解到如何使用使用 HappyBase 库编写 Python 脚本实现将 HBase 数据库中的历史数据的随意抽取并转换成 csv 文件,利用 Athena 实现对存储在 S3 上数据文件的访问。该方案可以帮助客户减小 HBase 集群,大幅降低数据的访问成本。


作者介绍:


!



### [](https://amazonaws-china.com/cn/blogs/china/tag/%E7%8E%8B%E5%8F%8B%E5%8D%87/)
王友升拥有超过13年的IT从业经验,负责基于AWS的云计算方案架构咨询和设计,推广AWS云平台技术和各种解决方案。在加入AWS之前,王友升曾在中地数码,浪潮,惠普等公司担任软件开发工程师、DBA和解决方案架构师。他在服务器、存储、数据库优化方面拥有多年的经验,同时对大数据、Openstack及人工智能和机器学习方面也进行一定的研究和积累。
复制代码


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/using-athena-to-replace-hbase-to-query-analyze-historical-data/


2019-11-27 08:001019

评论

发布
暂无评论
发现更多内容

构建区块链质押挖矿系统:DApp质押挖矿系统开发需求详解

区块链软件开发推广运营

dapp开发 区块链开发 NFT开发 公链开发

鸿蒙HarmonyOS实战-ArkTS语言(基本语法)

蜀道山

typescript 鸿蒙 HarmonyOS 鸿蒙系统 ArkTS

一款基于AB32VG1的桌面智能坞

芯动大师

程序设计 开发板 12864 OLED液晶显示屏

对某个通用字段进行加解密或者是脱敏处理

想要飞的猪

数据脱敏 字段加密

2024-04-13:用go语言,给定一个整数数组 `nums`, 请编写一个函数,返回一个新的数组 `counts`。 满足以下条件:对于每个 `nums[i]`, `counts[i]` 表示在

福大大架构师每日一题

福大大架构师每日一题

放心使用!龙蜥全系产品均不受 XZ 后门影响

OpenAnolis小助手

操作系统 漏洞 龙蜥社区 龙蜥操作系统

浪潮信息-龙蜥技术认证上线!实战培训 10 个名额,限量报名

OpenAnolis小助手

开源 操作系统 龙蜥社区

《自动机理论、语言和计算导论》阅读笔记:p139-p171

codists

编译原理

构建多功能DApp项目:质押、私募、DeFi、分红等功能详解

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

Spring高手之路17——动态代理的艺术与实践

砖业洋__

spring aop JDK动态代理 CGLIB动态代理

最新软件测试技术-2024

Geek_e575df

大公司的Java面试题集

程序员李木子

Java Java 面试题

支付系统概述(六):收银台

agnostic

支付系统设计与实现

一座计算“立交桥”,让新质生产力从湘江水畔到中国大地

脑极体

算力

事业-最佳实践-编码-单元测试-提升代码可测试性

南山

最佳实践 测试 单元测试 代码质量 可测试性

一个“敏捷”项目复盘的思考

Bruce Talk

敏捷开发 Agile 回顾会 Retrospective

查看自动类型推导结果的方法

爱分享

编辑器 代码规范 C++11 C++ modern C++

手把手带你申请Sora内测资格,附申请提示词

蓉蓉

openai ChatGPT4 sora

鸿蒙原生应用《隐私协议静态共享库》

坚果

HarmonyOS HarmonyOS框架

鸿蒙原生应用三方库《日历转换器》

坚果

HarmonyOS 坚果派 HarmonyOS框架

事业-最佳实践-编码-命名规范

南山

最佳实践 代码质量 命名规范 类命名 方法命名

鸿蒙HarmonyOS实战-ArkTS语言(状态管理)

蜀道山

鸿蒙 HarmonyOS 鸿蒙系统 ArkTS

事业-最佳实践-编码-日志输出规范

南山

最佳实践 日志 代码质量 日志规范 编码基础

高性能网络SIG月度动态:virtio 动态中断调节优化、多项内核网络缺陷修复

OpenAnolis小助手

操作系统 高性能网络 龙蜥社区SIG

4 月15-18 日,龙蜥社区与你相约北美开源峰会

OpenAnolis小助手

开源 操作系统 EROFS 北美开源峰会

Amazon Q:对话智能赋能企业发展

亚马逊云科技 (Amazon Web Services)

#人工智能

探索社交App商机:视频直播App、语聊陪玩、1v1约会App必不可少

山东布谷科技胡月

短视频直播系统 1v1交友app开发 语聊平台 海外社交APP 短剧app开发

个人介绍-第一篇博文

Geek_e575df

事业-最佳实践-编码-类大小衡量方式

南山

最佳实践 代码质量 单一职责 类大小 编码最佳实践

使用 Athena 替换 Hbase 实现对历史数据的查询分析_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章