mariadb/ndb/include/ndbapi/NdbEventOperation.hpp

223 lines
7.5 KiB
C++
Raw Normal View History

2004-04-14 10:53:21 +02:00
/* 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 */
/*****************************************************************************
* Name: NdbEventOperation.hpp
* Include:
* Link:
* Author: Tomas Ulin MySQL AB
* Date: 2003-11-21
* Version: 0.1
* Description: Event support
* Documentation:
* Adjust: 2003-11-21 Tomas Ulin First version.
* Adjust: 2003-12-11 Tomas Ulin Alpha Release.
****************************************************************************/
#ifndef NdbEventOperation_H
#define NdbEventOperation_H
class NdbGlobalEventBuffer;
class NdbEventOperationImpl;
/**
* @class NdbEventOperation
* @brief Class of operations for getting change events from database.
*
* An NdbEventOperation object is instantiated by
2005-01-02 13:21:17 +01:00
* Ndb::createEventOperation
2004-04-14 10:53:21 +02:00
*
* Prior to that an event must have been created in the Database through
2005-01-02 13:21:17 +01:00
* NdbDictionary::createEvent
2004-04-14 10:53:21 +02:00
*
2005-01-02 13:21:17 +01:00
* The instance is removed by Ndb::dropEventOperation
2004-04-14 10:53:21 +02:00
*
* For more info see:
2005-01-02 13:21:17 +01:00
* @ref ndbapi_example5.cpp
2004-04-14 10:53:21 +02:00
*
* Known limitations:
*
* Maximum number of active NdbEventOperations are now set at compile time.
* Today 100. This will become a configuration parameter later.
*
* Maximum number of NdbEventOperations tied to same event are maximum 16
* per process.
*
* Known issues:
*
2004-12-21 17:16:39 +01:00
* When several NdbEventOperation's are tied to the same event in the same
2004-04-14 10:53:21 +02:00
* process they will share the circular buffer. The BufferLength will then
* be the same for all and decided by the first NdbEventOperation
* instantiation. Just make sure to instantiate the "largest" one first.
*
* Today all events INSERT/DELETE/UPDATE and all changed attributes are
* sent to the API, even if only specific attributes have been specified.
* These are however hidden from the user and only relevant data is shown
2005-01-02 13:21:17 +01:00
* after next().
* However false exits from Ndb::pollEvents() may occur and thus
* the subsequent next() will return zero,
* since there was no available data. Just do Ndb::pollEvents() again.
2004-04-14 10:53:21 +02:00
*
* Event code does not check table schema version. Make sure to drop events
* after table is dropped. Will be fixed in later
* versions.
*
2004-12-21 17:16:39 +01:00
* If a node failure has occured not all events will be recieved
2004-04-14 10:53:21 +02:00
* anymore. Drop NdbEventOperation and Create again after nodes are up
* again. Will be fixed in later versions.
*
* Test status:
* Tests have been run on 1-node and 2-node systems
*
* Known bugs:
*
2005-01-02 13:21:17 +01:00
* None, except if we can call some of the "issues" above bugs
2004-04-14 10:53:21 +02:00
*
* Useful API programs:
*
2004-12-21 17:16:39 +01:00
* ndb_select_all -d sys 'NDB$EVENTS_0'
2004-04-14 10:53:21 +02:00
* Will show contents in the system table containing created events.
*
*/
class NdbEventOperation {
public:
2005-01-02 13:21:17 +01:00
/**
* Retrieve current state of the NdbEventOperation object
*/
2004-04-14 10:53:21 +02:00
enum State {CREATED,EXECUTING,ERROR};
State getState();
/**
* Activates the NdbEventOperation to start receiving events. The
* changed attribute values may be retrieved after next() has returned
* a value greater than zero. The getValue() methods below must be called
* prior to execute().
*
* @return 0 if successful otherwise -1.
*/
int execute();
// about the event operation
// getting data
// NdbResultSet* getResultSet();
/**
* Defines a retrieval operation of an attribute value.
* The NDB API allocate memory for the NdbRecAttr object that
* will hold the returned attribute value.
*
* @note Note that it is the applications responsibility
* to allocate enough memory for aValue (if non-NULL).
* The buffer aValue supplied by the application must be
* aligned appropriately. The buffer is used directly
* (avoiding a copy penalty) only if it is aligned on a
* 4-byte boundary and the attribute size in bytes
* (i.e. NdbRecAttr::attrSize times NdbRecAttr::arraySize is
* a multiple of 4).
*
* @note There are two versions, NdbOperation::getValue and
* NdbOperation::getPreValue for retrieving the current and
* previous value repectively.
*
* @note This method does not fetch the attribute value from
* the database! The NdbRecAttr object returned by this method
* is <em>not</em> readable/printable before the
* NdbEventConnection::execute has been made and
* NdbEventConnection::next has returned a value greater than
* zero. If a specific attribute has not changed the corresponding
* NdbRecAttr will be in state UNDEFINED. This is checked by
* NdbRecAttr::isNull which then returns -1.
*
* @param anAttrName Attribute name
* @param aValue If this is non-NULL, then the attribute value
* will be returned in this parameter.<br>
* If NULL, then the attribute value will only
* be stored in the returned NdbRecAttr object.
* @return An NdbRecAttr object to hold the value of
* the attribute, or a NULL pointer
* (indicating error).
*/
NdbRecAttr *getValue(const char *anAttrName, char *aValue = 0);
NdbRecAttr *getPreValue(const char *anAttrName, char *aValue = 0);
2004-04-14 10:53:21 +02:00
/**
* Retrieves event resultset if available, inserted into the NdbRecAttrs
* specified in getValue() and getPreValue(). To avoid polling for
2005-01-02 13:21:17 +01:00
* a resultset, one can use Ndb::pollEvents
2004-04-14 10:53:21 +02:00
* which will wait on a mutex until an event occurs or the specified
* timeout occurs.
*
* @return >=0 if successful otherwise -1. Return value inicates number
* of available events. By sending pOverRun one may query for buffer
* overflow and *pOverRun will indicate the number of events that have
* overwritten.
2005-01-02 13:21:17 +01:00
*
* @return number of available events, -1 on failure
2004-04-14 10:53:21 +02:00
*/
int next(int *pOverRun=0);
2004-04-14 10:53:21 +02:00
/**
* In the current implementation a nodefailiure may cause loss of events,
* in which case isConsistent() will return false
*/
bool isConsistent();
/**
* Query for occured event type.
2005-01-02 13:21:17 +01:00
*
* @note Only valid after next() has been called and returned value >= 0
*
* @return type of event
2004-04-14 10:53:21 +02:00
*/
NdbDictionary::Event::TableEvent getEventType();
2004-12-21 17:16:39 +01:00
/**
2005-01-02 13:21:17 +01:00
* Retrieve the GCI of the latest retrieved event
2004-12-21 17:16:39 +01:00
*
2005-01-02 13:21:17 +01:00
* @return GCI number
2004-12-21 17:16:39 +01:00
*/
2004-04-14 10:53:21 +02:00
Uint32 getGCI();
2004-12-21 17:16:39 +01:00
/**
2005-01-02 13:21:17 +01:00
* Retrieve the complete GCI in the cluster (not necessarily
* associated with an event)
2004-12-21 17:16:39 +01:00
*
2005-01-02 13:21:17 +01:00
* @return GCI number
2004-12-21 17:16:39 +01:00
*/
2004-04-14 10:53:21 +02:00
Uint32 getLatestGCI();
2004-12-21 17:16:39 +01:00
2005-01-02 13:21:17 +01:00
#ifndef DOXYGEN_SHOULD_SKIP_INTERNAL
2004-12-21 17:16:39 +01:00
/*
*
*/
2004-04-14 10:53:21 +02:00
void print();
2005-01-02 13:21:17 +01:00
#endif
2004-04-14 10:53:21 +02:00
private:
#ifndef DOXYGEN_SHOULD_SKIP_INTERNAL
2004-04-14 10:53:21 +02:00
friend class NdbEventOperationImpl;
friend class Ndb;
#endif
2004-04-14 10:53:21 +02:00
NdbEventOperation(Ndb *theNdb, const char* eventName,int bufferLength);
~NdbEventOperation();
static int wait(void *p, int aMillisecondNumber);
class NdbEventOperationImpl &m_impl;
NdbEventOperation(NdbEventOperationImpl& impl);
};
typedef void (* NdbEventCallback)(NdbEventOperation*, Ndb*, void*);
#endif