温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》
  • 首页 > 
  • 教程 > 
  • 数据库 > 
  • 手把手系列:(一)用Benchmarksql测试Oracle数据库性能

手把手系列:(一)用Benchmarksql测试Oracle数据库性能

发布时间:2020-05-30 06:28:22 来源:网络 阅读:7198 作者:kciuq 栏目:数据库

os 环境: Oracle linux /Oracle 12C RAC(搭建rac集群请参考这里),oracle12c数据库

  1. 从 sourceforge 下载Benchmarksql 5.0: https://sourceforge.net/projects/benchmarksql/

  2. 到写这篇文章为止,Benchmarksql 支持Firebird,Oracle和PostgreSQL

编译BenchMarksql:

网上关于benchmarksql5.0适用的jdk推荐1.7,笔者经过验证1.7,1.8版本都可以,只要编译和运行时的java版本匹配即可。

1.设置环境变量: export JAVA_HOME=/path/to/jdk  export PATH=$JAVA_HOME/bin:$PATH

2.用ant编译,在build.xml那个目录下面执行ant命令,在ant编译时遇到下面的错误:
Error: Could not find or load main class org.apache.tools.ant.launch.Launcher
解决办法:export CLASSPATH=.:${JAVA_HOME}/lib:/usr/share/ant/lib/ant-launcher.jar

运行Benchmarksql之前需要做下准备:

  1. cp $ORACLE_HOME/jdbc/lib/ojdbc8.jar $BENCHMARKSQLPATH/run

  2. export CLASSPATH=$BENCHMARKSQLPATH/run/ojdbc8.jar$CLASSPATH

  3. cp $ORACLE_HOME/jdbc/lib/ojdbc8.jar $BENCHMARKSQLPATH/lib/oracle(若没有这一步也会出现找不到oracle class的错误

修改 props.ora:

conn=jdbc:oracle:thin:@//scanip:1521/yourdb

通过Oracle RAC的scanip可以访问整个oracle rac集群,yourdb部分是创建数据库时指定的数据库名称,注意不要配置某个数据库local instance的名字,这样scan ip listene在接收到连接请求时,才会根据特定算法将请求发送到集群中的某个节点。

测试conn正确与否:sqlplus username/password@//scanip:1521/yourdb

user和password即在oracle 数据库中配置的用户名和密码。

terminals=100(配置100个并发用户),可以根据需要来自己配置。

warehouses=1000 (1000个warehouse 大约需要120多G空间,在数据库中需要提前规划好数据文件)

loadworkers=10

运行BenchMarksql:

cd run

./runSQL.sh props.ora ./sql.common/tableCreates.sql

nohup ./runLoader.sh props.ora >./load.log 2>&1 &

./runSQL.sh props.ora ./sql.common/indexCreates.sql

./runBenchmark.sh props.ora | tee 100.out


Benchmarksql 遵循Benchmark规范,结果文件中的TPMC即为我们最关注的指标。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI