Server IP : 172.67.216.182 / Your IP : 162.158.163.100 Web Server : Apache System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /www/server/mysql/src/sql/ |
Upload File : |
/* Copyright (c) 2000, 2023, Oracle and/or its affiliates. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License, version 2.0, as published by the Free Software Foundation. This program is also distributed with certain software (including but not limited to OpenSSL) that is licensed under separate terms, as designated in a particular file or component or in included license documentation. The authors of MySQL hereby grant you an additional permission to link the program and your derivative works with the separately licensed software that they have included with MySQL. 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, version 2.0, 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 St, Fifth Floor, Boston, MA 02110-1301 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)) #define INJECTOR_EVENT_LEN 200 #define NDB_INVALID_SCHEMA_OBJECT 241 static const char *ha_ndb_ext=".ndb"; extern Ndb_cluster_connection* g_ndb_cluster_connection; extern native_mutex_t ndbcluster_mutex; extern HASH ndbcluster_open_tables; /* Initialize the binlog part of the ndb handlerton */ void ndbcluster_binlog_init(handlerton* hton); /* Initialize the binlog part of the NDB_SHARE */ int ndbcluster_binlog_init_share(THD *thd, NDB_SHARE *share, TABLE *table); int ndbcluster_create_binlog_setup(THD *thd, Ndb *ndb, const char *key, uint key_len, const char *db, const char *table_name, TABLE * table); int ndbcluster_create_event(THD *thd, Ndb *ndb, const NDBTAB *table, const char *event_name, NDB_SHARE *share, int push_warning= 0); int ndbcluster_create_event_ops(THD *thd, NDB_SHARE *share, const NDBTAB *ndbtab, const char *event_name); int ndbcluster_drop_event(THD *thd, Ndb *ndb, NDB_SHARE *share, const char * dbname, const char * tabname); int ndbcluster_handle_drop_table(THD *thd, Ndb *ndb, NDB_SHARE *share, const char *type_str, const char * db, const char * tabname); void ndb_rep_event_name(String *event_name, const char *db, const char *tbl, my_bool full); #ifdef HAVE_NDB_BINLOG int ndbcluster_get_binlog_replication_info(THD *thd, Ndb *ndb, const char* db, const char* table_name, uint server_id, Uint32* binlog_flags, const st_conflict_fn_def** conflict_fn, st_conflict_fn_arg* args, Uint32* num_args); int ndbcluster_apply_binlog_replication_info(THD *thd, NDB_SHARE *share, const NDBTAB* ndbtab, const st_conflict_fn_def* conflict_fn, const st_conflict_fn_arg* args, Uint32 num_args, bool do_set_binlog_flags, Uint32 binlog_flags); int ndbcluster_read_binlog_replication(THD *thd, Ndb *ndb, NDB_SHARE *share, const NDBTAB *ndbtab, uint server_id, bool do_set_binlog_flags); #endif int ndb_create_table_from_engine(THD *thd, const char *db, const char *table_name); int ndbcluster_binlog_start(); /* Setup function for the ndb binlog component. The function should be called on startup until it succeeds(to allow initial setup) and with regular intervals afterwards to reconnect after a lost cluster connection */ bool ndb_binlog_setup(THD *thd); /* Will return true when the ndb binlog component is properly setup and ready to receive events from the cluster. As long as function returns false, all tables in this MySQL Server are opened in read only mode to avoid writes before the binlog is ready to record them. */ bool ndb_binlog_is_read_only(void); extern NDB_SHARE *ndb_apply_status_share; extern my_bool ndb_binlog_running; /* Prints ndb binlog status string in buf */ size_t ndbcluster_show_status_binlog(char* buf, size_t buf_size); /* Helper functions */ bool ndbcluster_check_if_local_table(const char *dbname, const char *tabname);