mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	- add ndb_share connect_count to decide if share can be reused to setup replication sql/ha_ndbcluster.cc: add additional logging info remove inline real_free_share (not needed) and confuses valgrind printout sql/ha_ndbcluster.h: add connect_count to ndb_share to enable checking for version of share sql/ha_ndbcluster_binlog.cc: use ndb_share connect_count to decide if share can be reused to setup replication - share will be created early if table is accessed prior to handler setting up binlog stuff, see bug 26021 sql/ha_ndbcluster_binlog.h: remove inline real_free_share (not needed) and confuses valgrind printout
		
			
				
	
	
		
			220 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			220 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (C) 2000-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
 | |
| */
 | |
| 
 | |
| // Typedefs for long names
 | |
| typedef NdbDictionary::Object NDBOBJ;
 | |
| typedef NdbDictionary::Column NDBCOL;
 | |
| typedef NdbDictionary::Table NDBTAB;
 | |
| typedef NdbDictionary::Index  NDBINDEX;
 | |
| typedef NdbDictionary::Dictionary  NDBDICT;
 | |
| typedef NdbDictionary::Event  NDBEVENT;
 | |
| 
 | |
| #define IS_TMP_PREFIX(A) (is_prefix(A, tmp_file_prefix))
 | |
| 
 | |
| extern ulong ndb_extra_logging;
 | |
| 
 | |
| #define INJECTOR_EVENT_LEN 200
 | |
| 
 | |
| #define NDB_INVALID_SCHEMA_OBJECT 241
 | |
| 
 | |
| extern handlerton *ndbcluster_hton;
 | |
| 
 | |
| /*
 | |
|   The numbers below must not change as they
 | |
|   are passed between mysql servers, and if changed
 | |
|   would break compatablility.  Add new numbers to
 | |
|   the end.
 | |
| */
 | |
| enum SCHEMA_OP_TYPE
 | |
| {
 | |
|   SOT_DROP_TABLE= 0,
 | |
|   SOT_CREATE_TABLE= 1,
 | |
|   SOT_RENAME_TABLE_NEW= 2,
 | |
|   SOT_ALTER_TABLE= 3,
 | |
|   SOT_DROP_DB= 4,
 | |
|   SOT_CREATE_DB= 5,
 | |
|   SOT_ALTER_DB= 6,
 | |
|   SOT_CLEAR_SLOCK= 7,
 | |
|   SOT_TABLESPACE= 8,
 | |
|   SOT_LOGFILE_GROUP= 9,
 | |
|   SOT_RENAME_TABLE= 10,
 | |
|   SOT_TRUNCATE_TABLE= 11
 | |
| };
 | |
| 
 | |
| const uint max_ndb_nodes= 64; /* multiple of 32 */
 | |
| 
 | |
| static const char *ha_ndb_ext=".ndb";
 | |
| static const char share_prefix[]= "./";
 | |
| 
 | |
| class Ndb_table_guard
 | |
| {
 | |
| public:
 | |
|   Ndb_table_guard(NDBDICT *dict, const char *tabname)
 | |
|     : m_dict(dict)
 | |
|   {
 | |
|     DBUG_ENTER("Ndb_table_guard");
 | |
|     m_ndbtab= m_dict->getTableGlobal(tabname);
 | |
|     m_invalidate= 0;
 | |
|     DBUG_PRINT("info", ("m_ndbtab: %p", m_ndbtab));
 | |
|     DBUG_VOID_RETURN;
 | |
|   }
 | |
|   ~Ndb_table_guard()
 | |
|   {
 | |
|     DBUG_ENTER("~Ndb_table_guard");
 | |
|     if (m_ndbtab)
 | |
|     {
 | |
|       DBUG_PRINT("info", ("m_ndbtab: %p  m_invalidate: %d",
 | |
|                           m_ndbtab, m_invalidate));
 | |
|       m_dict->removeTableGlobal(*m_ndbtab, m_invalidate);
 | |
|     }
 | |
|     DBUG_VOID_RETURN;
 | |
|   }
 | |
|   const NDBTAB *get_table() { return m_ndbtab; }
 | |
|   void invalidate() { m_invalidate= 1; }
 | |
|   const NDBTAB *release()
 | |
|   {
 | |
|     DBUG_ENTER("Ndb_table_guard::release");
 | |
|     const NDBTAB *tmp= m_ndbtab;
 | |
|     DBUG_PRINT("info", ("m_ndbtab: %p", m_ndbtab));
 | |
|     m_ndbtab = 0;
 | |
|     DBUG_RETURN(tmp);
 | |
|   }
 | |
| private:
 | |
|   const NDBTAB *m_ndbtab;
 | |
|   NDBDICT *m_dict;
 | |
|   int m_invalidate;
 | |
| };
 | |
| 
 | |
| #ifdef HAVE_NDB_BINLOG
 | |
| extern pthread_t ndb_binlog_thread;
 | |
| extern pthread_mutex_t injector_mutex;
 | |
| extern pthread_cond_t  injector_cond;
 | |
| 
 | |
| extern unsigned char g_node_id_map[max_ndb_nodes];
 | |
| extern pthread_t ndb_util_thread;
 | |
| extern pthread_mutex_t LOCK_ndb_util_thread;
 | |
| extern pthread_cond_t COND_ndb_util_thread;
 | |
| extern int ndbcluster_util_inited;
 | |
| extern pthread_mutex_t ndbcluster_mutex;
 | |
| extern HASH ndbcluster_open_tables;
 | |
| extern Ndb_cluster_connection* g_ndb_cluster_connection;
 | |
| extern long ndb_number_of_storage_nodes;
 | |
| 
 | |
| /*
 | |
|   Initialize the binlog part of the ndb handlerton
 | |
| */
 | |
| void ndbcluster_binlog_init_handlerton();
 | |
| /*
 | |
|   Initialize the binlog part of the NDB_SHARE
 | |
| */
 | |
| void ndbcluster_binlog_init_share(NDB_SHARE *share, TABLE *table);
 | |
| 
 | |
| bool ndbcluster_check_if_local_table(const char *dbname, const char *tabname);
 | |
| bool ndbcluster_check_if_local_tables_in_db(THD *thd, const char *dbname);
 | |
| 
 | |
| int ndbcluster_create_binlog_setup(Ndb *ndb, const char *key,
 | |
|                                    uint key_len,
 | |
|                                    const char *db,
 | |
|                                    const char *table_name,
 | |
|                                    my_bool share_may_exist);
 | |
| int ndbcluster_create_event(Ndb *ndb, const NDBTAB *table,
 | |
|                             const char *event_name, NDB_SHARE *share,
 | |
|                             int push_warning= 0);
 | |
| int ndbcluster_create_event_ops(NDB_SHARE *share,
 | |
|                                 const NDBTAB *ndbtab,
 | |
|                                 const char *event_name);
 | |
| int ndbcluster_log_schema_op(THD *thd, NDB_SHARE *share,
 | |
|                              const char *query, int query_length,
 | |
|                              const char *db, const char *table_name,
 | |
|                              uint32 ndb_table_id,
 | |
|                              uint32 ndb_table_version,
 | |
|                              enum SCHEMA_OP_TYPE type,
 | |
|                              const char *new_db,
 | |
|                              const char *new_table_name,
 | |
|                              int have_lock_open);
 | |
| int ndbcluster_handle_drop_table(Ndb *ndb, const char *event_name,
 | |
|                                  NDB_SHARE *share,
 | |
|                                  const char *type_str);
 | |
| void ndb_rep_event_name(String *event_name,
 | |
|                         const char *db, const char *tbl);
 | |
| int ndb_create_table_from_engine(THD *thd, const char *db,
 | |
|                                  const char *table_name);
 | |
| int ndbcluster_binlog_start();
 | |
| pthread_handler_t ndb_binlog_thread_func(void *arg);
 | |
| 
 | |
| /*
 | |
|   table mysql.ndb_apply_status
 | |
| */
 | |
| int ndbcluster_setup_binlog_table_shares(THD *thd);
 | |
| extern NDB_SHARE *ndb_apply_status_share;
 | |
| extern NDB_SHARE *ndb_schema_share;
 | |
| 
 | |
| extern THD *injector_thd;
 | |
| extern my_bool ndb_binlog_running;
 | |
| extern my_bool ndb_binlog_tables_inited;
 | |
| 
 | |
| bool
 | |
| ndbcluster_show_status_binlog(THD* thd, stat_print_fn *stat_print,
 | |
|                               enum ha_stat_type stat_type);
 | |
| 
 | |
| /*
 | |
|   prototypes for ndb handler utility function also needed by
 | |
|   the ndb binlog code
 | |
| */
 | |
| int cmp_frm(const NDBTAB *ndbtab, const void *pack_data,
 | |
|             uint pack_length);
 | |
| int ndbcluster_find_all_files(THD *thd);
 | |
| #endif /* HAVE_NDB_BINLOG */
 | |
| 
 | |
| void ndb_unpack_record(TABLE *table, NdbValue *value,
 | |
|                        MY_BITMAP *defined, byte *buf);
 | |
| 
 | |
| NDB_SHARE *ndbcluster_get_share(const char *key,
 | |
|                                 TABLE *table,
 | |
|                                 bool create_if_not_exists,
 | |
|                                 bool have_lock);
 | |
| NDB_SHARE *ndbcluster_get_share(NDB_SHARE *share);
 | |
| void ndbcluster_free_share(NDB_SHARE **share, bool have_lock);
 | |
| void ndbcluster_real_free_share(NDB_SHARE **share);
 | |
| int handle_trailing_share(NDB_SHARE *share);
 | |
| inline NDB_SHARE *get_share(const char *key,
 | |
|                             TABLE *table,
 | |
|                             bool create_if_not_exists= TRUE,
 | |
|                             bool have_lock= FALSE)
 | |
| {
 | |
|   return ndbcluster_get_share(key, table, create_if_not_exists, have_lock);
 | |
| }
 | |
| 
 | |
| inline NDB_SHARE *get_share(NDB_SHARE *share)
 | |
| {
 | |
|   return ndbcluster_get_share(share);
 | |
| }
 | |
| 
 | |
| inline void free_share(NDB_SHARE **share, bool have_lock= FALSE)
 | |
| {
 | |
|   ndbcluster_free_share(share, have_lock);
 | |
| }
 | |
| 
 | |
| inline
 | |
| Thd_ndb *
 | |
| get_thd_ndb(THD *thd) { return (Thd_ndb *) thd->ha_data[ndbcluster_hton->slot]; }
 | |
| 
 | |
| inline
 | |
| void
 | |
| set_thd_ndb(THD *thd, Thd_ndb *thd_ndb) { thd->ha_data[ndbcluster_hton->slot]= thd_ndb; }
 | |
| 
 | |
| Ndb* check_ndb_in_thd(THD* thd);
 |