mariadb/ndb/test/ndbapi/initronja.cpp
unknown 47c877bdf8 ndb_init() to all ndb programs
ndb/examples/ndbapi_async_example/ndbapi_async.cpp:
  ndb_init()
ndb/examples/ndbapi_example1/ndbapi_example1.cpp:
  ndb_init()
ndb/examples/ndbapi_example2/ndbapi_example2.cpp:
  ndb_init()
ndb/examples/ndbapi_example3/ndbapi_example3.cpp:
  ndb_init()
ndb/examples/ndbapi_example4/ndbapi_example4.cpp:
  ndb_init()
ndb/examples/ndbapi_example5/ndbapi_example5.cpp:
  ndb_init()
ndb/examples/ndbapi_scan_example/ndbapi_scan.cpp:
  ndb_init()
ndb/examples/select_all/select_all.cpp:
  ndb_init()
ndb/include/ndb_global.h:
  ndb_init()
ndb/src/common/util/Makefile.am:
  ndb_init()
ndb/src/kernel/blocks/backup/read.cpp:
  ndb_init()
ndb/src/kernel/blocks/backup/restore/main.cpp:
  ndb_init()
ndb/src/kernel/main.cpp:
  ndb_init()
ndb/src/kernel/vm/Configuration.cpp:
  ndb_init()
ndb/src/mgmclient/main.cpp:
  ndb_init()
ndb/src/mgmsrv/main.cpp:
  ndb_init()
ndb/src/mgmsrv/mkconfig/mkconfig.cpp:
  ndb_init()
ndb/src/ndbapi/Ndbinit.cpp:
  ndb_init()
ndb/test/ndbapi/acid.cpp:
  ndb_init()
ndb/test/ndbapi/acid2.cpp:
  ndb_init()
ndb/test/ndbapi/benchronja.cpp:
  ndb_init()
ndb/test/ndbapi/bulk_copy.cpp:
  ndb_init()
ndb/test/ndbapi/cdrserver.cpp:
  ndb_init()
ndb/test/ndbapi/celloDb.cpp:
  ndb_init()
ndb/test/ndbapi/create_all_tabs.cpp:
  ndb_init()
ndb/test/ndbapi/create_tab.cpp:
  ndb_init()
ndb/test/ndbapi/drop_all_tabs.cpp:
  ndb_init()
ndb/test/ndbapi/flexAsynch.cpp:
  ndb_init()
ndb/test/ndbapi/flexBench.cpp:
  ndb_init()
ndb/test/ndbapi/flexHammer.cpp:
  ndb_init()
ndb/test/ndbapi/flexScan.cpp:
  ndb_init()
ndb/test/ndbapi/flexTT.cpp:
  ndb_init()
ndb/test/ndbapi/flexTimedAsynch.cpp:
  ndb_init()
ndb/test/ndbapi/flex_bench_mysql.cpp:
  ndb_init()
ndb/test/ndbapi/index.cpp:
  ndb_init()
ndb/test/ndbapi/index2.cpp:
  ndb_init()
ndb/test/ndbapi/initronja.cpp:
  ndb_init()
ndb/test/ndbapi/interpreterInTup.cpp:
  ndb_init()
ndb/test/ndbapi/mainAsyncGenerator.cpp:
  ndb_init()
ndb/test/ndbapi/msa.cpp:
  ndb_init()
ndb/test/ndbapi/restarter.cpp:
  ndb_init()
ndb/test/ndbapi/restarter2.cpp:
  ndb_init()
ndb/test/ndbapi/restarts.cpp:
  ndb_init()
ndb/test/ndbapi/size.cpp:
  ndb_init()
ndb/test/ndbapi/slow_select.cpp:
  ndb_init()
ndb/test/ndbapi/testBackup.cpp:
  ndb_init()
ndb/test/ndbapi/testBasic.cpp:
  ndb_init()
ndb/test/ndbapi/testBasicAsynch.cpp:
  ndb_init()
ndb/test/ndbapi/testBlobs.cpp:
  ndb_init()
ndb/test/ndbapi/testDataBuffers.cpp:
  ndb_init()
ndb/test/ndbapi/testDeadlock.cpp:
  ndb_init()
ndb/test/ndbapi/testDict.cpp:
  ndb_init()
ndb/test/ndbapi/testGrep.cpp:
  ndb_init()
ndb/test/ndbapi/testGrepVerify.cpp:
  ndb_init()
ndb/test/ndbapi/testIndex.cpp:
  ndb_init()
ndb/test/ndbapi/testInterpreter.cpp:
  ndb_init()
ndb/test/ndbapi/testMgm.cpp:
  ndb_init()
ndb/test/ndbapi/bank/bankCreator.cpp:
  ndb_init()
ndb/test/ndbapi/bank/bankMakeGL.cpp:
  ndb_init()
ndb/test/ndbapi/bank/bankSumAccounts.cpp:
  ndb_init()
ndb/test/ndbapi/bank/bankTimer.cpp:
  ndb_init()
ndb/test/ndbapi/bank/bankTransactionMaker.cpp:
  ndb_init()
ndb/test/ndbapi/bank/bankValidateAllGLs.cpp:
  ndb_init()
ndb/test/ndbapi/bank/testBank.cpp:
  ndb_init()
ndb/test/ndbapi/testNdbApi.cpp:
  ndb_init()
ndb/test/ndbapi/testNodeRestart.cpp:
  ndb_init()
ndb/test/ndbapi/testOIBasic.cpp:
  ndb_init()
ndb/test/ndbapi/testOperations.cpp:
  ndb_init()
ndb/test/ndbapi/testOrderedIndex.cpp:
  ndb_init()
ndb/test/ndbapi/testReadPerf.cpp:
  ndb_init()
ndb/test/ndbapi/testRestartGci.cpp:
  ndb_init()
ndb/test/ndbapi/testScan.cpp:
  ndb_init()
ndb/test/ndbapi/testScanInterpreter.cpp:
  ndb_init()
ndb/test/ndbapi/testScanPerf.cpp:
  ndb_init()
ndb/test/ndbapi/testSystemRestart.cpp:
  ndb_init()
ndb/test/ndbapi/testTimeout.cpp:
  ndb_init()
ndb/test/ndbapi/testTransactions.cpp:
  ndb_init()
ndb/test/ndbapi/test_event.cpp:
  ndb_init()
ndb/test/run-test/main.cpp:
  ndb_init()
ndb/test/src/NDBT_Test.cpp:
  ndb_init()
ndb/test/tools/copy_tab.cpp:
  ndb_init()
ndb/test/tools/cpcc.cpp:
  ndb_init()
ndb/test/tools/create_index.cpp:
  ndb_init()
ndb/test/tools/hugoCalculator.cpp:
  ndb_init()
ndb/test/tools/hugoFill.cpp:
  ndb_init()
ndb/test/tools/hugoLoad.cpp:
  ndb_init()
ndb/test/tools/hugoLockRecords.cpp:
  ndb_init()
ndb/test/tools/hugoPkDelete.cpp:
  ndb_init()
ndb/test/tools/hugoPkRead.cpp:
  ndb_init()
ndb/test/tools/hugoPkReadRecord.cpp:
  ndb_init()
ndb/test/tools/hugoPkUpdate.cpp:
  ndb_init()
ndb/test/tools/hugoScanRead.cpp:
  ndb_init()
ndb/test/tools/hugoScanUpdate.cpp:
  ndb_init()
ndb/test/tools/restart.cpp:
  ndb_init()
ndb/test/tools/transproxy.cpp:
  ndb_init()
ndb/test/tools/verify_index.cpp:
  ndb_init()
ndb/tools/delete_all.cpp:
  ndb_init()
ndb/tools/desc.cpp:
  ndb_init()
ndb/tools/drop_index.cpp:
  ndb_init()
ndb/tools/drop_tab.cpp:
  ndb_init()
ndb/tools/listTables.cpp:
  ndb_init()
ndb/tools/ndbsql.cpp:
  ndb_init()
ndb/tools/select_all.cpp:
  ndb_init()
ndb/tools/select_count.cpp:
  ndb_init()
ndb/tools/waiter.cpp:
  ndb_init()
2004-09-15 11:49:18 +02:00

351 lines
11 KiB
C++

/* Copyright (C) 2003 MySQL AB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
/* ***************************************************
INITRONJA
Initialise benchmark for Ronja Database
* *************************************************** */
#include "NdbApi.hpp"
#include "NdbSchemaCon.hpp"
#include <NdbOut.hpp>
#include <NdbMain.h>
#include <NdbTest.hpp>
#include <string.h>
#define MAXSTRLEN 16
#define MAXATTR 64
#define MAXTABLES 64
#define MAXTHREADS 256
#define MAXATTRSIZE 8000
static unsigned int tNoOfRecords;
static unsigned int tNoOfLoops;
static unsigned int tNoOfTables;
static int tAttributeSize;
static int tNodeId;
static unsigned int tValue;
static unsigned int tNoOfOperations;
static char tableName[MAXTABLES][MAXSTRLEN];
static char attrName[MAXATTR][MAXSTRLEN];
inline int InsertRecords(Ndb*, int) ;
NDB_COMMAND(initronja, "initronja", "initronja", "initronja", 65535){
ndb_init();
Ndb* pNdb = NULL ;
NdbSchemaCon *MySchemaTransaction = NULL ;
NdbSchemaOp *MySchemaOp = NULL ;
int check, status, i, j, cont ;
check = status = i = j = cont = 0 ;
tNoOfRecords = 500 ;
tNoOfLoops = tNoOfRecords / 10;
i = 1;
while (argc > 1){
if (strcmp(argv[i], "-r") == 0){
if( NULL == argv[i+1] ) goto error_input ;
tNoOfRecords = atoi(argv[i+1]);
tNoOfRecords = tNoOfRecords - (tNoOfRecords % 10);
tNoOfLoops = tNoOfRecords / 10;
if ((tNoOfRecords < 1) || (tNoOfRecords > 1000000000)) goto error_input;
}else{
goto error_input;
}
argc -= 2;
i = i + 2; //
}
pNdb = new Ndb( "TEST_DB" ) ;
ndbout << "Initialisation started. " << endl;
pNdb->init();
ndbout << "Initialisation completed. " << endl;
tNodeId = pNdb->getNodeId();
ndbout << endl << "Initial loading of Ronja Database" << endl;
ndbout << " NdbAPI node with id = " << tNodeId << endl;
if (pNdb->waitUntilReady(30) != 0) {
ndbout << "Benchmark failed - NDB is not ready" << endl;
delete pNdb ;
return NDBT_ProgramExit(NDBT_FAILED) ;
}//if
ndbout << endl << "Creating the table SHORT_REC" << "..." << endl;
MySchemaTransaction = NdbSchemaCon::startSchemaTrans(pNdb);
if(!MySchemaTransaction) goto error_handler;
MySchemaOp = MySchemaTransaction->getNdbSchemaOp();
if(!MySchemaOp) goto error_handler;
#if defined NDB_OSE || defined NDB_SOFTOSE
check = MySchemaOp->createTable( "SHORT_REC"
,8 // Table Size
,TupleKey // Key Type
,40 // Nr of Pages
,All
,6
,78
,80
,1
,false);
#else
check = MySchemaOp->createTable( "SHORT_REC"
,8 // Table Size
,TupleKey // Key Type
,40 // Nr of Pages
);
#endif
if (check == -1) goto error_handler;
ndbout << "Key attribute..." ;
check = MySchemaOp->createAttribute( (char*)"Key", TupleKey, 32, 1,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\t\tOK" << endl ;
ndbout << "Flip attribute..." ;
check = MySchemaOp->createAttribute("Flip", NoKey, 32, 1,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\t\tOK" << endl ;
ndbout << "Count attribute..." ;
check = MySchemaOp->createAttribute("Count", NoKey, 32, 1,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\t\tOK" << endl ;
ndbout << "Placeholder attribute..." ;
check = MySchemaOp->createAttribute("Placeholder", NoKey, 8, 90,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\tOK" << endl ;
if (MySchemaTransaction->execute() == -1) {
if(721 == MySchemaOp->getNdbError().code){
ndbout << "Table SHORT_REC already exists" << endl ;
}else{
ndbout << MySchemaTransaction->getNdbError() << endl;
}
}else{
ndbout << "SHORT_REC created " << endl;
}// if
NdbSchemaCon::closeSchemaTrans(MySchemaTransaction);
ndbout << endl << "Creating the table LONG_REC..." << endl;
MySchemaTransaction = NdbSchemaCon::startSchemaTrans(pNdb);
if(!MySchemaTransaction) goto error_handler;
MySchemaOp = MySchemaTransaction->getNdbSchemaOp();
if(!MySchemaOp) goto error_handler;
#if defined NDB_OSE || defined NDB_SOFTOSE
check = MySchemaOp->createTable( "LONG_REC"
,8 // Table Size
,TupleKey // Key Type
,40 // Nr of Pages
,All
,6
,78
,80
,1
,false);
#else
check = MySchemaOp->createTable( "LONG_REC"
,8 // Table Size
,TupleKey // Key Type
,40 // Nr of Pages
);
#endif
if (check == -1) goto error_handler;
ndbout << "Key attribute..." ;
check = MySchemaOp->createAttribute( (char*)"Key", TupleKey, 32, 1,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\t\tOK" << endl ;
ndbout << "Flip attribute..." ;
check = MySchemaOp->createAttribute("Flip", NoKey, 32, 1,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\t\tOK" << endl ;
ndbout << "Count attribute..." ;
check = MySchemaOp->createAttribute("Count", NoKey, 32, 1,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\t\tOK" << endl ;
ndbout << "Placeholder attribute..." ;
check = MySchemaOp->createAttribute("Placeholder", NoKey, 8, 1014,
UnSigned, MMBased, NotNullAttribute );
if (check == -1) goto error_handler;
ndbout << "\tOK" << endl ;
if (MySchemaTransaction->execute() == -1) {
if(721 == MySchemaOp->getNdbError().code){
ndbout << "Table LONG_REC already exists" << endl ;
}else{
ndbout << MySchemaTransaction->getNdbError() << endl;
}
}else{
ndbout << "LONG_REC created" << endl;
}// if
NdbSchemaCon::closeSchemaTrans(MySchemaTransaction);
check = InsertRecords(pNdb, tNoOfRecords);
delete pNdb ;
if(-1 == check){
ndbout << endl << "Initial loading of Ronja Database failed" << endl;
return NDBT_ProgramExit(NDBT_FAILED) ;
}else{
ndbout << endl << "Initial loading of Ronja Database completed" << endl;
return NDBT_ProgramExit(NDBT_OK) ;
}
error_handler:
ndbout << "SchemaTransaction returned error:" ;
ndbout << MySchemaTransaction->getNdbError() << endl;
NdbSchemaCon::closeSchemaTrans(MySchemaTransaction);
delete pNdb ;
NDBT_ProgramExit(NDBT_FAILED) ;
exit(-1);
error_input:
ndbout << endl << " Ivalid parameter(s)" << endl;
ndbout << " Usage: initronja [-r n] , where 'n' is the number of records to be inserted" << endl;
ndbout << " If omitted, 500 records will be created by default" << endl;
ndbout << " Note: use this number in combination with '-r' argument when running 'benchronja'" << endl << endl;
NDBT_ProgramExit(NDBT_WRONGARGS) ;
exit(1);
}
////////////////////////////////////////
inline int InsertRecords(Ndb* pNdb, int nNoRecords){
NdbConnection *MyTransaction = NULL ;
NdbOperation* MyOperation[10];
int Tsuccess = 0 ;
int loop_count_ops = 2 * tNoOfLoops;
int loop_count_tables = 10;
int loop_count_attributes = 0 ;
int check = 0;
int count = 0 ;
int count_tables = 0;
int count_attributes = 0 ;
int i = 0 ;
int tType = 0 ;
unsigned int attrValue[1000];
unsigned int setAttrValue = 0;
unsigned int keyValue[3];
for (i = 0; i < 1000; i ++) attrValue[i] = 1;
for (count=0 ; count < loop_count_ops ; count++){
if ((((count / 100)* 100) == count) && (count != 0)){
ndbout << "1000 records inserted again, " << (count/100) << "000 records now inserted" << endl;
}
MyTransaction = pNdb->startTransaction();
if(!MyTransaction){
ndbout << "startTransaction: " << pNdb->getNdbError();
ndbout << " count = " << count << endl;
return -1 ;
}
for (count_tables = 0; count_tables < loop_count_tables; count_tables++) {
if (count < tNoOfLoops) {
keyValue[0] = count*10 + count_tables ;
MyOperation[count_tables] = MyTransaction->getNdbOperation("SHORT_REC") ;
}else{
keyValue[0] = (count - tNoOfLoops)*10 + count_tables;
MyOperation[count_tables] = MyTransaction->getNdbOperation("LONG_REC");
}//if
if (!MyOperation[count_tables]) goto error_handler1;
check = MyOperation[count_tables]->insertTuple();
if (check == -1) goto error_handler2;
check = MyOperation[count_tables]->equal("Key",(char*)&keyValue[0]);
if (check == -1) goto error_handler4;
check = MyOperation[count_tables]->setValue("Flip",(char*)&setAttrValue);
if (check == -1) goto error_handler5;
check = MyOperation[count_tables]->setValue("Count",(char*)&setAttrValue);
if (check == -1) goto error_handler5;
check = MyOperation[count_tables]->setValue("Placeholder",(char*)&attrValue[0]);
if (check == -1) goto error_handler5;
}//for
if (MyTransaction->execute( Commit ) == -1){
ndbout << MyTransaction->getNdbError()<< endl ;
ndbout << "count = " << count << endl;
}//if
pNdb->closeTransaction(MyTransaction) ;
}//for
return 0;
error_handler1:
ndbout << "Error occured in getNdbOperation " << endl;
ndbout << MyTransaction->getNdbError() << endl;
pNdb->closeTransaction(MyTransaction);
return -1 ;
error_handler2:
ndbout << "Error occured in defining operation " << endl;
ndbout << MyOperation[count_tables]->getNdbError() << endl;
pNdb->closeTransaction(MyTransaction);
return -1 ;
error_handler3:
pNdb->closeTransaction(MyTransaction);
return -1 ;
error_handler4:
ndbout << "Error occured in equal " << endl;
ndbout << MyOperation[count_tables]->getNdbError() << endl;
pNdb->closeTransaction(MyTransaction);
return -1 ;
error_handler5:
ndbout << "Error occured in get/setValue " << endl;
ndbout << MyOperation[count_tables]->getNdbError() << endl;
pNdb->closeTransaction(MyTransaction);
return -1 ;
}