TPC-DS工具介绍及性能测试
一. Hive-testbench工具介绍
TPC-DS:https://www.cnblogs.com/webDepOfQWS/p/10544528.html
由于原生态工具生产测试数据表存在bug,后续引进hive-testbench,可参考:
https://bbs.huaweicloud.com/blogs/260840
可在WPS共享文档https://yundoc.fin-shine.com/drive/group/442074/3256599
或10.141.23.16 /home/appuser/hive-testbench下载 (配置项及脚本已修改)
1.1. 工具部署
执行tpcds-build.sh
(该工具需依赖包,执行后会提示,缺少什么安装什么依赖包)
一般需要这几个:yum -y install gcc gcc-c++
也可参考https://bbs.huaweicloud.com/blogs/260840
1.2. 脚本修改适配
修改脚本,直接使用hive(WSL环境没有配置beeline)
文件: tpcds-setup.sh
echo "TPC-DS text data generation complete." #HIVE="beeline -n hive -u 'jdbc:hive2://localhost:2181/;serviceDiscoveryMode=zooKeeper;zooKeeperNamespace=hiveserver2?tez.queue.name=default' "HIVE="hive" # Create the text/flat tables as external tables. These will be later be converted to ORCFile. |
修改不支持的参数,注释 hive.optimize.sort.dynamic.partition.threshold
vim settings/init.sql
vim settings/load-flat.sql
vim settings/load-partitioned.sql
-- set hive.optimize.sort.dynamic.partition.threshold=0;
(目前发现仅在Cloudera中提供该配置:
https://docs.cloudera.com/cdp-private-cloud-base/7.1.5/ozone-storing-data/topics/ozone-config-work-with-Hive.html)
1.3. 生成测试数据
例如# 生成大小100G的数据集# 生成文件放置于/tmp目录下
bash tpcds-setup.sh 100 /tmp/100
(可在HDFS上查看已生成的文件: sudo -u hdfs hadoop fs -du -h /tmp)
1.4. 执行99条SQL
路径:/hive-testbench-hdp3/sample-queries-tpcds
方法一:
执行hive命令进入数据库执行命令界面,然后执行:
hive> use tpcds_bin_partitioned_orc_100;
hive> source query12.sql;
方法二:
使用脚本批量执行,通过/tmp/tpcds_bin_partitioned_orc_100.Log查看所有执行SQL结果。
(/tmp/tpcds_calc.log便于统计每条SQL执行的耗时情况,实际以上述结果为准!)
命令:sh autoTpcDs.sh
脚本内容:(仅参考,根据实际内容修改)
#!/bin/bash base_dir='/home/appuser/hive-testbench/hive-testbench-hdp3/sample-queries-tpcds' DBbase=tpcds_bin_partitioned_orc_100 for sql_num in `seq 1 99` do if ((${sql_num}==18));then continue 1 else echo "=============sql_num: query${sql_num} ==============" hive -e "use ${DBbase};source ${base_dir}/query${sql_num}.sql" echo "=============sql_num: query${sql_num} ==============" >> /tmp/tpcds_calc.log grep 'Time taken' /tmp/${DBbase}.log|tail -1 >> /tmp/tpcds_calc.log 2>&1 fi done >> /tmp/${DBbase}.log 2>&1 |
二. TPC-DS
2.1. TPC-DS编译
yum install -y gcc gcc-c++ expect byacc flex bison
地址: git clone git@github.com:gregrahn/tpcds-kit.git
地址:git clone https://github.com/gregrahn/tpcds-kit.git
进入tool目录下
执行 make
2.2. 建表
在tools目录下 查看tpcds.sql文件,提供了基础的建表语句
2.3. 生成数据
2.3.1. 创建存放生成数据的目录
mkdir /root/tpcdsdata
2.3.2. 生成指定大小的数据到创建的目录
./tools/dsdgen -SCALE 100GB -DIR ./data_100G -SCALE:指定生成数据量大小如:100GB、200GB、1TB、100TB |
2.4. 根据模板生成查询语句
通过使用dsqgen命令根据TPC-DS提供的模板生成不同类型的SQL语句,TPC-DS默认支持以下模板:db2.tpl、netezza.tpl、oracle.tpl、sqlserver.tpl
for i in `seq 1 99` do ./dsqgen -DIRECTORY ../query_templates/ -TEMPLATE "query${i}.tpl" -DIALECT netezza -FILTER Y > ../sql/query${i}.sql done |
-DIRECTORY:SQL模板的路径。 这个是查询模板的文件目录位置 …/query_templates/注意:因为query_templates只有99个查询模板,所以最多一次只能生成99个查询语句,但是如果生成多次,生成的99个查询语句是一样
-TEMPLATE:SQL模板的名称
-DIALECT:include query dialect defintions found in < s >.tpl 。-DIALECT postgresql 是哪种数据库的查询语句
注意:DIALECT支持oracle,db2,sqlserver,netezza,ansi,但是没有postgresql。可以去query_templates文件目录下看是否有对应的模板文件,推荐netezza,pg可以解析。
-FILTER:重定向到标准输出,即…/sql/query${i}.sql 是输出路径和文件类型。
2.5. 所有表分别导入数据
举例:psql -h 172.0.0.1 -p 31000 -U zhouwh -d testdb_100g -c "\COPY catalog_returns FROM '/home/appuser/tpcds-kit/data_100g/catalog_returns.dat' with DELIMITER as '|' NULL '' SEGMENT REJECT LIMIT 10000 ROWS;" |
脚本:
#数据库名称 DB=testdb_100g #dat文件路径 addr='/home/appuser/tpcds-kit/data_100g' now=`date +%Y%m%d%H%M%S` cd $addr #编辑文件 total_cost1=0 for i in `ls *.dat|cut -d '.' -f 1` do echo "###${i}开始编辑dat文件..." begin_time1=`date +%s.%N` sed -i -r 's/(.)$//g' ${addr}/${i}.dat rcsed=$? end_time1=`date +%s.%N` cost1=`echo "$end_time-$begin_time"|bc` total_cost1=`echo "$total_cost+$cost"|bc` if [ $rcsed -ne 0 ] ; then printf "###!%s编辑失败\n" $i else printf "###%s编辑成功!cost耗时::%.2f秒,累计耗时::%.2f秒\n" $i $cost1 $total_cost1 fi done #导入数据 total_cost=0 for i in `ls *.dat|cut -d '.' -f 1` do echo "${i}开始导入数据..." begin_time=`date +%s.%N` psql -h 172.0.0.1 -p 31000 -U zhouwh -d ${DB} -c "\COPY ${i} FROM '${addr}/${i}.dat' with DELIMITER as '|' NULL '';" 2>/tmp/null rc=$? end_time=`date +%s.%N` cost=`echo "$end_time-$begin_time"|bc` total_cost=`echo "$total_cost+$cost"|bc` if [ $rc -ne 0 ] ; then printf "#####!%s导入数据失败\n" $i else printf "######%s导入数据成功!耗时:%.2f秒,累计耗时:%.2f秒\n" $i $cost $total_cost fi done |
执行命令:
nohup /home/appuser/tpcds-kit/exportdat.sh 2>/home/appuser/tpcds-kit/nohup.out &
2.6. 执行查询语句
#数据库名字 DB=testdb_100g total_cost=0 now=`date +%Y%m%d%H%M%S` for i in {1..99} do echo "begin run Q${i}, sql/query$i.sql , `date`" begin_time=`date +%s.%N` psql -h 172.0.0.1 -p 31000 -U zhouwh -d $DB -f ./query${i}.sql > ./log/log_query${i}.out 2>/tmp/null rc=$? end_time=`date +%s.%N` cost=`echo "$end_time-$begin_time"|bc` total_cost=`echo "$total_cost+$cost"|bc` if [ $rc -ne 0 ] ; then printf "run Q%s fail, cost: %.2f, totalCost: %.2f, `date`\n" $i $cost $total_cost else ROWS=`grep 'rows' ./log/log_query${i}.out|tail -1` printf "###run Q%s succ, cost: %.2f, totalCost: %.2f, ROWS%s%s%s, `date`\n" $i $cost $total_cost $ROWS fi done |
2.7. 统计
cost时间
awk -F "," '{print $2}' 文件名 |awk -F ":" '{print $2}'
TPC-DS工具介绍及性能测试的更多相关文章
- python模块介绍- multi-mechanize 性能测试工具
python模块介绍- multi-mechanize 性能测试工具 2013-09-13 磁针石 #承接软件自动化实施与培训等gtalk:ouyangchongwu#gmail.comqq 3739 ...
- [原创]H5前端性能测试工具介绍
[原创H5前端性能测试工具介绍 一 网络抓包工具 网络抓包工具选择原则,可以捕获网络请求,抓取具体请求信息流,同时可以针对网络请包进行修改或拦截: 1.Fiddler(推荐) 2.Charles(推荐 ...
- [原创]Linux下网络性能测试Netperf工具介绍及安装
[原创]Linux下网络性能测试Netperf工具介绍及安装 1 官方网站 http://www.netperf.org/netperf/ 2 Netperf介绍 Netperf是一种网络性能的测试工 ...
- Android系统性能调优工具介绍
http://blog.csdn.net/innost/article/details/9008691 经作者授权,发表Tieto某青年牛的一篇<程序员>大作. Android系统性能调优 ...
- Android性能分析工具介绍
1. Android系统性能调优工具介绍 http://blog.csdn.net/innost/article/details/9008691 TraceviewSystraceOprofile 2 ...
- python接口自动化(四)--接口测试工具介绍(详解)
简介 “工欲善其事必先利其器”,通过前边几篇文章的介绍,大家大致对接口有了进一步的认识.那么接下来让我们看看接口测试的工具有哪些. 目前,市场上有很多支持接口测试的工具.利用工具进行接口测试,能够提供 ...
- JMeter软件测试工具介绍及基本安装教程
一.工具介绍 (一)简介 Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域. 它可以用于测试 ...
- 常用的HTTP服务压测工具介绍
常用的HTTP服务压测工具介绍 在项目正式上线之前,我们通常需要通过压测来评估当前系统能够支撑的请求量.排查可能存在的隐藏bug,同时了解了程序的实际处理能力能够帮我们更好的匹配项目的实际需求,节约资 ...
- 《连载 | 物联网框架ServerSuperIO教程》- 14.配制工具介绍,以及设备驱动、视图驱动、服务实例的挂载
注:ServerSuperIO二次开发套件授权码申请---截止到:2016-12-09 1.C#跨平台物联网通讯框架ServerSuperIO(SSIO)介绍 <连载 | 物联网框架Server ...
- json、javaBean、xml互转的几种工具介绍
json.javaBean.xml互转的几种工具介绍 转载至:http://blog.csdn.net/sdyy321/article/details/7024236 工作中经常要用到Json.Jav ...
随机推荐
- PhotoShop Beta(爱国版)安装教程-内置AI绘画功能
PS beta版安装教程 Window和Mac版都有,里面内置AI绘画功能 ps Beta版真的太爽了,今天来和大家分享下安装教程. 很多人拿这资料卖5块 9.9 19.9,球友们直接用,建议赶紧装, ...
- 《SQL与数据库基础》20. 主从复制
目录 主从复制 原理 搭建 主库配置 从库配置 测试 本文以 MySQL 为例 主从复制 主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执 ...
- 如何实现一个数据库的 UDF?图数据库 NebulaGraph UDF 功能背后的设计与思考
大家好,我是来自 BOSS直聘的赵俊南,主要负责安全方面的图存储相关工作.作为一个从 v1.x 用到 v3.x 版本的忠实用户,在见证 NebulaGraph 发展的同时,也和它一起成长. BOSS直 ...
- modbus转profinet网关连接ABB变频器在博图程序案例
modbus转profinet网关连接ABB变频器在博图程序案例 在博图里PLC无需编程利用兴达易控modbus转Profinet网关将ABB变频器接入到西门子网络中,用到设备为西门子1200PLC, ...
- ORA-01008:并非所有变量都已绑定-解决办法
近期批量处理数据,后台用JAVA编写,连接Oracle数据库,程序运行报ORA-01008问题.解决这个问题时遇见的坑较多,下面复盘现象.问题提出解决办法,希望能帮到遇见同类问题的你. 调试问题: 后 ...
- Redis最常见的5种应用场景
Redis作为当今最流行的内存数据库,已经成为服务端加速的必备工具之一.对于Redis为什么那么快?以及Redis采用单线程,但为什么反而获得更高的性能的疑问,在之前的Redis为什么那么快?一文中, ...
- jdk-14.0.1环境搭建及cmd环境编译执行
1.安装包获取 https://www.oracle.com/java/technologies/javase/jdk14-archive-downloads.html 2.环境变量配置 最新版本的J ...
- PAI-DSW常见问题
PAI-DSW常见问题 更新时间:2023年6月5日 18:40:00 本文为您介绍PAI-DSW的相关问题. 什么是PAI-DSW? PAI-DSW实例如何挂载和使用自己的NAS文件系统? 如何在P ...
- 计算机三级网络技术备考复习资料zhuan
计算机三级网络技术备考复习资料 第一章 计算机基础 分析:考试形式:选择题和填空题,6个的选择题和2个填空题共10分,都是基本概念 1.计算机的四特点:有信息处理的特性,有广泛适应的特性,有 ...
- 原创基于Scrum框架产研团队运作20问
学习完了 Scrum,实际使用中,是否遇到/思考过下面的问题? Product Owner的老板是谁.谁来给 Product Owner打绩效.考核的标准是啥? Scrum Master 的老板是谁. ...