mirror of
https://github.com/MariaDB/server.git
synced 2025-01-31 11:01:52 +01:00
92e68d49d7
Changed header to GPL version 2 only client/mysqlslap.c: Changed header to GPL version 2 only include/atomic/nolock.h: Changed header to GPL version 2 only include/atomic/rwlock.h: Changed header to GPL version 2 only include/atomic/x86-gcc.h: Changed header to GPL version 2 only include/atomic/x86-msvc.h: Changed header to GPL version 2 only include/my_atomic.h: Changed header to GPL version 2 only include/my_trie.h: Changed header to GPL version 2 only include/my_vle.h: Changed header to GPL version 2 only include/mysql/plugin.h: Changed header to GPL version 2 only mysys/my_atomic.c: Changed header to GPL version 2 only mysys/my_getncpus.c: Changed header to GPL version 2 only mysys/my_memmem.c: Changed header to GPL version 2 only mysys/my_vle.c: Changed header to GPL version 2 only mysys/trie.c: Changed header to GPL version 2 only plugin/Makefile.am: Changed header to GPL version 2 only server-tools/instance-manager/IMService.h: Changed header to GPL version 2 only server-tools/instance-manager/WindowsService.h: Changed header to GPL version 2 only server-tools/instance-manager/exit_codes.h: Changed header to GPL version 2 only server-tools/instance-manager/user_management_commands.h: Changed header to GPL version 2 only sql/authors.h: Changed header to GPL version 2 only sql/contributors.h: Changed header to GPL version 2 only sql/event_data_objects.cc: Changed header to GPL version 2 only sql/event_data_objects.h: Changed header to GPL version 2 only sql/event_db_repository.cc: Changed header to GPL version 2 only sql/event_db_repository.h: Changed header to GPL version 2 only sql/event_queue.cc: Changed header to GPL version 2 only sql/event_queue.h: Changed header to GPL version 2 only sql/event_scheduler.cc: Changed header to GPL version 2 only sql/event_scheduler.h: Changed header to GPL version 2 only sql/events.cc: Changed header to GPL version 2 only sql/events.h: Changed header to GPL version 2 only sql/ha_ndbcluster_binlog.cc: Changed header to GPL version 2 only sql/ha_ndbcluster_binlog.h: Changed header to GPL version 2 only sql/ha_ndbcluster_tables.h: Changed header to GPL version 2 only sql/ha_partition.cc: Changed header to GPL version 2 only sql/ha_partition.h: Changed header to GPL version 2 only sql/item_xmlfunc.cc: Changed header to GPL version 2 only sql/item_xmlfunc.h: Changed header to GPL version 2 only sql/log.h: Changed header to GPL version 2 only sql/partition_element.h: Changed header to GPL version 2 only sql/partition_info.cc: Changed header to GPL version 2 only sql/partition_info.h: Changed header to GPL version 2 only sql/rpl_filter.cc: Changed header to GPL version 2 only sql/rpl_filter.h: Changed header to GPL version 2 only sql/rpl_injector.cc: Changed header to GPL version 2 only sql/rpl_injector.h: Changed header to GPL version 2 only sql/rpl_mi.cc: Changed header to GPL version 2 only sql/rpl_mi.h: Changed header to GPL version 2 only sql/rpl_rli.cc: Changed header to GPL version 2 only sql/rpl_rli.h: Changed header to GPL version 2 only sql/rpl_tblmap.cc: Changed header to GPL version 2 only sql/rpl_tblmap.h: Changed header to GPL version 2 only sql/rpl_utility.cc: Changed header to GPL version 2 only sql/rpl_utility.h: Changed header to GPL version 2 only sql/sql_binlog.cc: Changed header to GPL version 2 only sql/sql_partition.cc: Changed header to GPL version 2 only sql/sql_partition.h: Changed header to GPL version 2 only sql/sql_plugin.cc: Changed header to GPL version 2 only sql/sql_plugin.h: Changed header to GPL version 2 only sql/sql_servers.cc: Changed header to GPL version 2 only sql/sql_servers.h: Changed header to GPL version 2 only sql/sql_tablespace.cc: Changed header to GPL version 2 only sql/sql_yacc.yy.bak: Changed header to GPL version 2 only storage/Makefile.am: Changed header to GPL version 2 only storage/archive/Makefile.am: Changed header to GPL version 2 only storage/blackhole/Makefile.am: Changed header to GPL version 2 only storage/csv/Makefile.am: Changed header to GPL version 2 only storage/example/Makefile.am: Changed header to GPL version 2 only storage/federated/Makefile.am: Changed header to GPL version 2 only storage/innobase/handler/Makefile.am: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/AllocNodeId.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/CreateFilegroup.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/CreateFilegroupImpl.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/CreateObj.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/DictObjOp.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/DihFragCount.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/DropFilegroup.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/DropFilegroupImpl.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/DropObj.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/Extent.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/LgmanContinueB.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/PgmanContinueB.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/RestoreContinueB.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/RestoreImpl.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/RouteOrd.hpp: Changed header to GPL version 2 only storage/ndb/include/kernel/signaldata/TsmanContinueB.hpp: Changed header to GPL version 2 only storage/ndb/include/ndbapi/NdbIndexStat.hpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/mgmapi_logevent/mgmapi_logevent.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/mgmapi_logevent_dual/mgmapi_logevent_dual.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_async/ndbapi_async.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_async1/ndbapi_async1.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_event/ndbapi_event.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_retries/ndbapi_retries.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_scan/ndbapi_scan.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_simple/ndbapi_simple.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_simple_dual/ndbapi_simple_dual.cpp: Changed header to GPL version 2 only storage/ndb/ndbapi-examples/ndbapi_simple_index/ndbapi_simple_index.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbdih/printSysfile.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtup/DbtupDiskAlloc.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtup/DbtupVarAlloc.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtup/Undo_buffer.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtup/Undo_buffer.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtup/tuppage.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtup/tuppage.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/dbtux/DbtuxStat.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/diskpage.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/lgman.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/lgman.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/pgman.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/pgman.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/print_file.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/record_types.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/restore.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/restore.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/tsman.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/blocks/tsman.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/DLCFifoList.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/DLCHashTable.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/DynArr256.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/DynArr256.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/KeyTable2Ref.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/LinearPool.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/NdbdSuperPool.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/NdbdSuperPool.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/Pool.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/Pool.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/RWPool.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/RWPool.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/Rope.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/SLFifoList.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/WOPool.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/WOPool.hpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/bench_pool.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/ndbd_malloc_impl.cpp: Changed header to GPL version 2 only storage/ndb/src/kernel/vm/ndbd_malloc_impl.hpp: Changed header to GPL version 2 only storage/ndb/src/mgmsrv/ParamInfo.cpp: Changed header to GPL version 2 only storage/ndb/src/ndbapi/NdbIndexStat.cpp: Changed header to GPL version 2 only storage/ndb/test/ndbapi/testIndexStat.cpp: Changed header to GPL version 2 only storage/ndb/test/tools/listen.cpp: Changed header to GPL version 2 only storage/ndb/tools/restore/ndb_nodegroup_map.h: Changed header to GPL version 2 only strings/my_strchr.c: Changed header to GPL version 2 only unittest/mysys/base64-t.c: Changed header to GPL version 2 only unittest/mysys/bitmap-t.c: Changed header to GPL version 2 only unittest/mysys/my_atomic-t.c: Changed header to GPL version 2 only unittest/mytap/tap.c: Changed header to GPL version 2 only unittest/mytap/tap.h: Changed header to GPL version 2 only win/Makefile.am: Changed header to GPL version 2 only
290 lines
8.9 KiB
C++
290 lines
8.9 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; version 2 of the License.
|
|
|
|
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 */
|
|
|
|
//
|
|
// ndbapi_retries.cpp: Error handling and transaction retries
|
|
//
|
|
// There are many ways to program using the NDB API. In this example
|
|
// we execute two inserts in the same transaction using
|
|
// NdbConnection::execute(NoCommit).
|
|
//
|
|
// Transaction failing is handled by re-executing the transaction
|
|
// in case of non-permanent transaction errors.
|
|
// Application errors (i.e. errors at points marked with APIERROR)
|
|
// should be handled by the application programmer.
|
|
|
|
#include <mysql.h>
|
|
#include <NdbApi.hpp>
|
|
|
|
// Used for cout
|
|
#include <iostream>
|
|
|
|
// Used for sleep (use your own version of sleep)
|
|
#include <unistd.h>
|
|
#define TIME_TO_SLEEP_BETWEEN_TRANSACTION_RETRIES 1
|
|
|
|
#define PRINT_ERROR(code,msg) \
|
|
std::cout << "Error in " << __FILE__ << ", line: " << __LINE__ \
|
|
<< ", code: " << code \
|
|
<< ", msg: " << msg << "." << std::endl
|
|
#define MYSQLERROR(mysql) { \
|
|
PRINT_ERROR(mysql_errno(&mysql),mysql_error(&mysql)); \
|
|
exit(-1); }
|
|
|
|
//
|
|
// APIERROR prints an NdbError object
|
|
//
|
|
#define APIERROR(error) \
|
|
{ std::cout << "API ERROR: " << error.code << " " << error.message \
|
|
<< std::endl \
|
|
<< " " << "Status: " << error.status \
|
|
<< ", Classification: " << error.classification << std::endl\
|
|
<< " " << "File: " << __FILE__ \
|
|
<< " (Line: " << __LINE__ << ")" << std::endl \
|
|
; \
|
|
}
|
|
|
|
//
|
|
// TRANSERROR prints all error info regarding an NdbTransaction
|
|
//
|
|
#define TRANSERROR(ndbTransaction) \
|
|
{ NdbError error = ndbTransaction->getNdbError(); \
|
|
std::cout << "TRANS ERROR: " << error.code << " " << error.message \
|
|
<< std::endl \
|
|
<< " " << "Status: " << error.status \
|
|
<< ", Classification: " << error.classification << std::endl \
|
|
<< " " << "File: " << __FILE__ \
|
|
<< " (Line: " << __LINE__ << ")" << std::endl \
|
|
; \
|
|
printTransactionError(ndbTransaction); \
|
|
}
|
|
|
|
void printTransactionError(NdbTransaction *ndbTransaction) {
|
|
const NdbOperation *ndbOp = NULL;
|
|
int i=0;
|
|
|
|
/****************************************************************
|
|
* Print NdbError object of every operations in the transaction *
|
|
****************************************************************/
|
|
while ((ndbOp = ndbTransaction->getNextCompletedOperation(ndbOp)) != NULL) {
|
|
NdbError error = ndbOp->getNdbError();
|
|
std::cout << " OPERATION " << i+1 << ": "
|
|
<< error.code << " " << error.message << std::endl
|
|
<< " Status: " << error.status
|
|
<< ", Classification: " << error.classification << std::endl;
|
|
i++;
|
|
}
|
|
}
|
|
|
|
|
|
//
|
|
// Example insert
|
|
// @param myNdb Ndb object representing NDB Cluster
|
|
// @param myTransaction NdbTransaction used for transaction
|
|
// @param myTable Table to insert into
|
|
// @param error NdbError object returned in case of errors
|
|
// @return -1 in case of failures, 0 otherwise
|
|
//
|
|
int insert(int transactionId, NdbTransaction* myTransaction,
|
|
const NdbDictionary::Table *myTable) {
|
|
NdbOperation *myOperation; // For other operations
|
|
|
|
myOperation = myTransaction->getNdbOperation(myTable);
|
|
if (myOperation == NULL) return -1;
|
|
|
|
if (myOperation->insertTuple() ||
|
|
myOperation->equal("ATTR1", transactionId) ||
|
|
myOperation->setValue("ATTR2", transactionId)) {
|
|
APIERROR(myOperation->getNdbError());
|
|
exit(-1);
|
|
}
|
|
|
|
return myTransaction->execute(NdbTransaction::NoCommit);
|
|
}
|
|
|
|
|
|
//
|
|
// Execute function which re-executes (tries 10 times) the transaction
|
|
// if there are temporary errors (e.g. the NDB Cluster is overloaded).
|
|
// @return -1 failure, 1 success
|
|
//
|
|
int executeInsertTransaction(int transactionId, Ndb* myNdb,
|
|
const NdbDictionary::Table *myTable) {
|
|
int result = 0; // No result yet
|
|
int noOfRetriesLeft = 10;
|
|
NdbTransaction *myTransaction; // For other transactions
|
|
NdbError ndberror;
|
|
|
|
while (noOfRetriesLeft > 0 && !result) {
|
|
|
|
/*********************************
|
|
* Start and execute transaction *
|
|
*********************************/
|
|
myTransaction = myNdb->startTransaction();
|
|
if (myTransaction == NULL) {
|
|
APIERROR(myNdb->getNdbError());
|
|
ndberror = myNdb->getNdbError();
|
|
result = -1; // Failure
|
|
} else if (insert(transactionId, myTransaction, myTable) ||
|
|
insert(10000+transactionId, myTransaction, myTable) ||
|
|
myTransaction->execute(NdbTransaction::Commit)) {
|
|
TRANSERROR(myTransaction);
|
|
ndberror = myTransaction->getNdbError();
|
|
result = -1; // Failure
|
|
} else {
|
|
result = 1; // Success
|
|
}
|
|
|
|
/**********************************
|
|
* If failure, then analyze error *
|
|
**********************************/
|
|
if (result == -1) {
|
|
switch (ndberror.status) {
|
|
case NdbError::Success:
|
|
break;
|
|
case NdbError::TemporaryError:
|
|
std::cout << "Retrying transaction..." << std::endl;
|
|
sleep(TIME_TO_SLEEP_BETWEEN_TRANSACTION_RETRIES);
|
|
--noOfRetriesLeft;
|
|
result = 0; // No completed transaction yet
|
|
break;
|
|
|
|
case NdbError::UnknownResult:
|
|
case NdbError::PermanentError:
|
|
std::cout << "No retry of transaction..." << std::endl;
|
|
result = -1; // Permanent failure
|
|
break;
|
|
}
|
|
}
|
|
|
|
/*********************
|
|
* Close transaction *
|
|
*********************/
|
|
if (myTransaction != NULL) {
|
|
myNdb->closeTransaction(myTransaction);
|
|
}
|
|
}
|
|
|
|
if (result != 1) exit(-1);
|
|
return result;
|
|
}
|
|
|
|
/*********************************************************
|
|
* Create a table named MYTABLENAME if it does not exist *
|
|
*********************************************************/
|
|
static void create_table(MYSQL &mysql)
|
|
{
|
|
if (mysql_query(&mysql,
|
|
"CREATE TABLE"
|
|
" MYTABLENAME"
|
|
" (ATTR1 INT UNSIGNED NOT NULL PRIMARY KEY,"
|
|
" ATTR2 INT UNSIGNED NOT NULL)"
|
|
" ENGINE=NDB"))
|
|
MYSQLERROR(mysql);
|
|
}
|
|
|
|
/***********************************
|
|
* Drop a table named MYTABLENAME
|
|
***********************************/
|
|
static void drop_table(MYSQL &mysql)
|
|
{
|
|
if (mysql_query(&mysql,
|
|
"DROP TABLE"
|
|
" MYTABLENAME"))
|
|
MYSQLERROR(mysql);
|
|
}
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
if (argc != 3)
|
|
{
|
|
std::cout << "Arguments are <socket mysqld> <connect_string cluster>.\n";
|
|
exit(-1);
|
|
}
|
|
char * mysqld_sock = argv[1];
|
|
const char *connectstring = argv[2];
|
|
ndb_init();
|
|
|
|
Ndb_cluster_connection *cluster_connection=
|
|
new Ndb_cluster_connection(connectstring); // Object representing the cluster
|
|
|
|
int r= cluster_connection->connect(5 /* retries */,
|
|
3 /* delay between retries */,
|
|
1 /* verbose */);
|
|
if (r > 0)
|
|
{
|
|
std::cout
|
|
<< "Cluster connect failed, possibly resolved with more retries.\n";
|
|
exit(-1);
|
|
}
|
|
else if (r < 0)
|
|
{
|
|
std::cout
|
|
<< "Cluster connect failed.\n";
|
|
exit(-1);
|
|
}
|
|
|
|
if (cluster_connection->wait_until_ready(30,30))
|
|
{
|
|
std::cout << "Cluster was not ready within 30 secs." << std::endl;
|
|
exit(-1);
|
|
}
|
|
// connect to mysql server
|
|
MYSQL mysql;
|
|
if ( !mysql_init(&mysql) ) {
|
|
std::cout << "mysql_init failed\n";
|
|
exit(-1);
|
|
}
|
|
if ( !mysql_real_connect(&mysql, "localhost", "root", "", "",
|
|
0, mysqld_sock, 0) )
|
|
MYSQLERROR(mysql);
|
|
|
|
/********************************************
|
|
* Connect to database via mysql-c *
|
|
********************************************/
|
|
mysql_query(&mysql, "CREATE DATABASE TEST_DB_1");
|
|
if (mysql_query(&mysql, "USE TEST_DB_1") != 0) MYSQLERROR(mysql);
|
|
create_table(mysql);
|
|
|
|
Ndb* myNdb= new Ndb( cluster_connection,
|
|
"TEST_DB_1" ); // Object representing the database
|
|
|
|
if (myNdb->init() == -1) {
|
|
APIERROR(myNdb->getNdbError());
|
|
exit(-1);
|
|
}
|
|
|
|
const NdbDictionary::Dictionary* myDict= myNdb->getDictionary();
|
|
const NdbDictionary::Table *myTable= myDict->getTable("MYTABLENAME");
|
|
if (myTable == NULL)
|
|
{
|
|
APIERROR(myDict->getNdbError());
|
|
return -1;
|
|
}
|
|
/************************************
|
|
* Execute some insert transactions *
|
|
************************************/
|
|
for (int i = 10000; i < 20000; i++) {
|
|
executeInsertTransaction(i, myNdb, myTable);
|
|
}
|
|
|
|
delete myNdb;
|
|
delete cluster_connection;
|
|
|
|
drop_table(mysql);
|
|
|
|
ndb_end(0);
|
|
return 0;
|
|
}
|