扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
os 环境: Oracle linux /Oracle 12C RAC(搭建rac集群请参考这里),oracle12c数据库
目前成都创新互联已为超过千家的企业提供了网站建设、域名、网页空间、成都网站托管、企业网站设计、宁江网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
从 sourceforge 下载Benchmarksql 5.0: https://sourceforge.net/projects/benchmarksql/
到写这篇文章为止,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之前需要做下准备:
cp $ORACLE_HOME/jdbc/lib/ojdbc8.jar $BENCHMARKSQLPATH/run
export CLASSPATH=$BENCHMARKSQLPATH/run/ojdbc8.jar$CLASSPATH
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即为我们最关注的指标。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流