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即为我们最关注的指标。