ha_ndbcluster_binlog.h 6.92 KB
Newer Older
unknown's avatar
unknown committed
1 2 3 4
/* 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
unknown's avatar
unknown committed
5
  the Free Software Foundation; version 2 of the License.
unknown's avatar
unknown committed
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24

  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;

25
#define IS_TMP_PREFIX(A) (is_prefix(A, tmp_file_prefix))
unknown's avatar
unknown committed
26 27 28 29 30

extern ulong ndb_extra_logging;

#define INJECTOR_EVENT_LEN 200

31 32
#define NDB_INVALID_SCHEMA_OBJECT 241

33 34
extern handlerton *ndbcluster_hton;

35 36 37 38 39 40
/*
  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.
*/
unknown's avatar
unknown committed
41 42
enum SCHEMA_OP_TYPE
{
43 44
  SOT_DROP_TABLE= 0,
  SOT_CREATE_TABLE= 1,
45
  SOT_RENAME_TABLE_NEW= 2,
46 47 48 49 50 51
  SOT_ALTER_TABLE= 3,
  SOT_DROP_DB= 4,
  SOT_CREATE_DB= 5,
  SOT_ALTER_DB= 6,
  SOT_CLEAR_SLOCK= 7,
  SOT_TABLESPACE= 8,
52
  SOT_LOGFILE_GROUP= 9,
unknown's avatar
unknown committed
53 54
  SOT_RENAME_TABLE= 10,
  SOT_TRUNCATE_TABLE= 11
unknown's avatar
unknown committed
55 56 57 58
};

const uint max_ndb_nodes= 64; /* multiple of 32 */

59 60 61
static const char *ha_ndb_ext=".ndb";
static const char share_prefix[]= "./";

62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
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;
};

101
#ifdef HAVE_NDB_BINLOG
unknown's avatar
unknown committed
102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
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);

125
bool ndbcluster_check_if_local_table(const char *dbname, const char *tabname);
126
bool ndbcluster_check_if_local_tables_in_db(THD *thd, const char *dbname);
127

unknown's avatar
unknown committed
128
int ndbcluster_create_binlog_setup(Ndb *ndb, const char *key,
129
                                   uint key_len,
unknown's avatar
unknown committed
130 131
                                   const char *db,
                                   const char *table_name,
132
                                   my_bool share_may_exist);
unknown's avatar
unknown committed
133
int ndbcluster_create_event(Ndb *ndb, const NDBTAB *table,
unknown's avatar
unknown committed
134 135
                            const char *event_name, NDB_SHARE *share,
                            int push_warning= 0);
unknown's avatar
unknown committed
136 137 138 139 140 141 142 143
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,
144
                             enum SCHEMA_OP_TYPE type,
145 146 147
                             const char *new_db,
                             const char *new_table_name,
                             int have_lock_open);
unknown's avatar
unknown committed
148
int ndbcluster_handle_drop_table(Ndb *ndb, const char *event_name,
149 150
                                 NDB_SHARE *share,
                                 const char *type_str);
unknown's avatar
unknown committed
151 152
void ndb_rep_event_name(String *event_name,
                        const char *db, const char *tbl);
153 154
int ndb_create_table_from_engine(THD *thd, const char *db,
                                 const char *table_name);
unknown's avatar
unknown committed
155 156 157 158
int ndbcluster_binlog_start();
pthread_handler_t ndb_binlog_thread_func(void *arg);

/*
159
  table mysql.ndb_apply_status
unknown's avatar
unknown committed
160
*/
161
int ndbcluster_setup_binlog_table_shares(THD *thd);
162 163
extern NDB_SHARE *ndb_apply_status_share;
extern NDB_SHARE *ndb_schema_share;
unknown's avatar
unknown committed
164 165

extern THD *injector_thd;
166
extern my_bool ndb_binlog_running;
167
extern my_bool ndb_binlog_tables_inited;
unknown's avatar
unknown committed
168 169 170 171 172 173 174 175 176

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
*/
177 178
int cmp_frm(const NDBTAB *ndbtab, const void *pack_data,
            uint pack_length);
unknown's avatar
unknown committed
179
int ndbcluster_find_all_files(THD *thd);
180 181
#endif /* HAVE_NDB_BINLOG */

unknown's avatar
unknown committed
182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212
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 *
213
get_thd_ndb(THD *thd) { return (Thd_ndb *) thd->ha_data[ndbcluster_hton->slot]; }
unknown's avatar
unknown committed
214 215 216

inline
void
217
set_thd_ndb(THD *thd, Thd_ndb *thd_ndb) { thd->ha_data[ndbcluster_hton->slot]= thd_ndb; }
unknown's avatar
unknown committed
218 219

Ndb* check_ndb_in_thd(THD* thd);