mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			149 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (c) 2003-2007 MySQL AB
 | |
|    Use is subject to license terms
 | |
| 
 | |
|    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., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA */
 | |
| 
 | |
| 
 | |
| #ifndef CLUSTER_CONNECTION_HPP
 | |
| #define CLUSTER_CONNECTION_HPP
 | |
| #include <ndb_types.h>
 | |
| 
 | |
| class Ndb_cluster_connection_node_iter
 | |
| {
 | |
|   friend class Ndb_cluster_connection_impl;
 | |
| public:
 | |
|   Ndb_cluster_connection_node_iter() : scan_state(~0),
 | |
| 				       init_pos(0),
 | |
| 				       cur_pos(0) {};
 | |
| private:
 | |
|   unsigned char scan_state;
 | |
|   unsigned char init_pos;
 | |
|   unsigned char cur_pos;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * @class Ndb_cluster_connection
 | |
|  * @brief Represents a connection to a cluster of storage nodes.
 | |
|  *
 | |
|  * Any NDB application program should begin with the creation of a
 | |
|  * single Ndb_cluster_connection object, and should make use of one
 | |
|  * and only one Ndb_cluster_connection. The application connects to
 | |
|  * a cluster management server when this object's connect() method is called.
 | |
|  * By using the wait_until_ready() method it is possible to wait
 | |
|  * for the connection to reach one or more storage nodes.
 | |
|  */
 | |
| class Ndb_cluster_connection {
 | |
| public:
 | |
|   /**
 | |
|    * Create a connection to a cluster of storage nodes
 | |
|    *
 | |
|    * @param connectstring The connectstring for where to find the
 | |
|    *                      management server
 | |
|    */
 | |
|   Ndb_cluster_connection(const char * connectstring = 0);
 | |
|   ~Ndb_cluster_connection();
 | |
| 
 | |
|   /**
 | |
|    * Set a name on the connection, which will be reported in cluster log
 | |
|    *
 | |
|    * @param name
 | |
|    *
 | |
|    */
 | |
|   void set_name(const char *name);
 | |
| 
 | |
|   /**
 | |
|    * Set timeout
 | |
|    *
 | |
|    * Used as a timeout when talking to the management server,
 | |
|    * helps limit the amount of time that we may block when connecting
 | |
|    *
 | |
|    * Basically just calls ndb_mgm_set_timeout(h,ms).
 | |
|    *
 | |
|    * The default is 30 seconds.
 | |
|    *
 | |
|    * @param timeout_ms millisecond timeout. As with ndb_mgm_set_timeout,
 | |
|    *                   only increments of 1000 are really supported,
 | |
|    *                   with not to much gaurentees about calls completing
 | |
|    *                   in any hard amount of time.
 | |
|    * @return 0 on success
 | |
|    */
 | |
|   int set_timeout(int timeout_ms);
 | |
| 
 | |
|   /**
 | |
|    * Connect to a cluster management server
 | |
|    *
 | |
|    * @param no_retries specifies the number of retries to attempt
 | |
|    *        in the event of connection failure; a negative value 
 | |
|    *        will result in the attempt to connect being repeated 
 | |
|    *        indefinitely
 | |
|    *
 | |
|    * @param retry_delay_in_seconds specifies how often retries should
 | |
|    *        be performed
 | |
|    *
 | |
|    * @param verbose specifies if the method should print a report of its progess
 | |
|    *
 | |
|    * @return 0 = success, 
 | |
|    *         1 = recoverable error,
 | |
|    *        -1 = non-recoverable error
 | |
|    */
 | |
|   int connect(int no_retries=0, int retry_delay_in_seconds=1, int verbose=0);
 | |
| 
 | |
| #ifndef DOXYGEN_SHOULD_SKIP_INTERNAL
 | |
|   int start_connect_thread(int (*connect_callback)(void)= 0);
 | |
| #endif
 | |
| 
 | |
|   /**
 | |
|    * Wait until the requested connection with one or more storage nodes is successful
 | |
|    *
 | |
|    * @param timeout_for_first_alive   Number of seconds to wait until
 | |
|    *                                  first live node is detected
 | |
|    * @param timeout_after_first_alive Number of seconds to wait after
 | |
|    *                                  first live node is detected
 | |
|    *
 | |
|    * @return = 0 all nodes live,
 | |
|    *         > 0 at least one node live,
 | |
|    *         < 0 error
 | |
|    */
 | |
|   int wait_until_ready(int timeout_for_first_alive,
 | |
| 		       int timeout_after_first_alive);
 | |
| 
 | |
| #ifndef DOXYGEN_SHOULD_SKIP_INTERNAL
 | |
|   int get_no_ready();
 | |
|   const char *get_connectstring(char *buf, int buf_sz) const;
 | |
|   int get_connected_port() const;
 | |
|   const char *get_connected_host() const;
 | |
| 
 | |
|   void set_optimized_node_selection(int val);
 | |
| 
 | |
|   unsigned no_db_nodes();
 | |
|   unsigned node_id();
 | |
|   unsigned get_connect_count() const;
 | |
| 
 | |
|   void init_get_next_node(Ndb_cluster_connection_node_iter &iter);
 | |
|   unsigned int get_next_node(Ndb_cluster_connection_node_iter &iter);
 | |
|   unsigned get_active_ndb_objects() const;
 | |
|   
 | |
|   Uint64 *get_latest_trans_gci();
 | |
| #endif
 | |
| 
 | |
| private:
 | |
|   friend class Ndb;
 | |
|   friend class NdbImpl;
 | |
|   friend class Ndb_cluster_connection_impl;
 | |
|   class Ndb_cluster_connection_impl & m_impl;
 | |
|   Ndb_cluster_connection(Ndb_cluster_connection_impl&);
 | |
| };
 | |
| 
 | |
| #endif
 |