Renamed Table_filter to Rpl_filter
Eliminated very annoying memory leak
This commit is contained in:
lars@mysql.com 2005-03-21 22:09:42 +01:00
parent 7ed7fc7f58
commit c6d85289ab
13 changed files with 70 additions and 68 deletions

View file

@ -55,10 +55,10 @@ noinst_HEADERS = item.h item_func.h item_sum.h item_cmpfunc.h \
ha_ndbcluster.h opt_range.h protocol.h \ ha_ndbcluster.h opt_range.h protocol.h \
sql_select.h structs.h table.h sql_udf.h hash_filo.h\ sql_select.h structs.h table.h sql_udf.h hash_filo.h\
lex.h lex_symbol.h sql_acl.h sql_crypt.h \ lex.h lex_symbol.h sql_acl.h sql_crypt.h \
log_event.h sql_repl.h slave.h \ log_event.h sql_repl.h slave.h rpl_filter.h \
stacktrace.h sql_sort.h sql_cache.h set_var.h \ stacktrace.h sql_sort.h sql_cache.h set_var.h \
spatial.h gstream.h client_settings.h tzfile.h \ spatial.h gstream.h client_settings.h tzfile.h
table_filter.h tztime.h \ tztime.h \
sp_head.h sp_pcontext.h sp_rcontext.h sp.h sp_cache.h \ sp_head.h sp_pcontext.h sp_rcontext.h sp.h sp_cache.h \
parse_file.h sql_view.h sql_trigger.h \ parse_file.h sql_view.h sql_trigger.h \
examples/ha_example.h examples/ha_archive.h \ examples/ha_example.h examples/ha_archive.h \
@ -90,12 +90,13 @@ mysqld_SOURCES = sql_lex.cc sql_handler.cc \
sql_db.cc sql_table.cc sql_rename.cc sql_crypt.cc \ sql_db.cc sql_table.cc sql_rename.cc sql_crypt.cc \
sql_load.cc mf_iocache.cc field_conv.cc sql_show.cc \ sql_load.cc mf_iocache.cc field_conv.cc sql_show.cc \
sql_udf.cc sql_analyse.cc sql_analyse.h sql_cache.cc \ sql_udf.cc sql_analyse.cc sql_analyse.h sql_cache.cc \
slave.cc sql_repl.cc sql_union.cc sql_derived.cc \ slave.cc sql_repl.cc rpl_filter.cc \
sql_union.cc sql_derived.cc \
client.c sql_client.cc mini_client_errors.c pack.c\ client.c sql_client.cc mini_client_errors.c pack.c\
stacktrace.c repl_failsafe.h repl_failsafe.cc \ stacktrace.c repl_failsafe.h repl_failsafe.cc \
sql_olap.cc sql_view.cc \ sql_olap.cc sql_view.cc \
gstream.cc spatial.cc sql_help.cc protocol_cursor.cc \ gstream.cc spatial.cc sql_help.cc protocol_cursor.cc \
table_filter.cc tztime.cc my_time.c \ tztime.cc my_time.c \
sp_head.cc sp_pcontext.cc sp_rcontext.cc sp.cc \ sp_head.cc sp_pcontext.cc sp_rcontext.cc sp.cc \
sp_cache.cc parse_file.cc sql_trigger.cc \ sp_cache.cc parse_file.cc sql_trigger.cc \
examples/ha_example.cc examples/ha_archive.cc \ examples/ha_example.cc examples/ha_archive.cc \

View file

@ -24,7 +24,7 @@
#include "mysql_priv.h" #include "mysql_priv.h"
#include "sql_repl.h" #include "sql_repl.h"
#include "table_filter.h" #include "rpl_filter.h"
#include "ha_innodb.h" // necessary to cut the binlog when crash recovery #include "ha_innodb.h" // necessary to cut the binlog when crash recovery
#include <my_dir.h> #include <my_dir.h>

View file

@ -21,7 +21,7 @@
#endif #endif
#include "mysql_priv.h" #include "mysql_priv.h"
#include "slave.h" #include "slave.h"
#include "table_filter.h" #include "rpl_filter.h"
#include <my_dir.h> #include <my_dir.h>
#endif /* MYSQL_CLIENT */ #endif /* MYSQL_CLIENT */

View file

@ -19,7 +19,7 @@
#include <my_dir.h> #include <my_dir.h>
#include "slave.h" #include "slave.h"
#include "sql_repl.h" #include "sql_repl.h"
#include "table_filter.h" #include "rpl_filter.h"
#include "repl_failsafe.h" #include "repl_failsafe.h"
#include "stacktrace.h" #include "stacktrace.h"
#include "mysqld_suffix.h" #include "mysqld_suffix.h"
@ -385,8 +385,8 @@ FILE *bootstrap_file;
I_List<THD> threads,thread_cache; I_List<THD> threads,thread_cache;
I_List<NAMED_LIST> key_caches; I_List<NAMED_LIST> key_caches;
Table_filter* rpl_filter; Rpl_filter* rpl_filter;
Table_filter* binlog_filter; Rpl_filter* binlog_filter;
struct system_variables global_system_variables; struct system_variables global_system_variables;
struct system_variables max_system_variables; struct system_variables max_system_variables;
@ -994,6 +994,8 @@ void clean_up(bool print_message)
#ifdef HAVE_REPLICATION #ifdef HAVE_REPLICATION
end_slave_list(); end_slave_list();
#endif #endif
delete binlog_filter;
delete rpl_filter;
#ifdef HAVE_OPENSSL #ifdef HAVE_OPENSSL
if (ssl_acceptor_fd) if (ssl_acceptor_fd)
my_free((gptr) ssl_acceptor_fd, MYF(MY_ALLOW_ZERO_PTR)); my_free((gptr) ssl_acceptor_fd, MYF(MY_ALLOW_ZERO_PTR));
@ -2963,8 +2965,8 @@ int main(int argc, char **argv)
{ {
DEBUGGER_OFF; DEBUGGER_OFF;
rpl_filter= new Table_filter; rpl_filter= new Rpl_filter;
binlog_filter= new Table_filter; binlog_filter= new Rpl_filter;
if (!rpl_filter || !binlog_filter) if (!rpl_filter || !binlog_filter)
{ {
sql_perror("Could not allocate replication and binlog filters"); sql_perror("Could not allocate replication and binlog filters");
@ -3215,9 +3217,6 @@ we force server id to 2, but this MySQL server will not act as a slave.");
clean_up_mutexes(); clean_up_mutexes();
my_end(opt_endinfo ? MY_CHECK_ERROR | MY_GIVE_INFO : 0); my_end(opt_endinfo ? MY_CHECK_ERROR | MY_GIVE_INFO : 0);
delete rpl_filter;
delete binlog_filter;
exit(0); exit(0);
return(0); /* purecov: deadcode */ return(0); /* purecov: deadcode */
} }

View file

@ -20,7 +20,7 @@
#include "repl_failsafe.h" #include "repl_failsafe.h"
#include "sql_repl.h" #include "sql_repl.h"
#include "slave.h" #include "slave.h"
#include "table_filter.h" #include "rpl_filter.h"
#include "log_event.h" #include "log_event.h"
#include <mysql.h> #include <mysql.h>

View file

@ -15,12 +15,12 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#include "mysql_priv.h" #include "mysql_priv.h"
#include "table_filter.h" #include "rpl_filter.h"
#define TABLE_RULE_HASH_SIZE 16 #define TABLE_RULE_HASH_SIZE 16
#define TABLE_RULE_ARR_SIZE 16 #define TABLE_RULE_ARR_SIZE 16
Table_filter::Table_filter() : Rpl_filter::Rpl_filter() :
table_rules_on(0), do_table_inited(0), ignore_table_inited(0), table_rules_on(0), do_table_inited(0), ignore_table_inited(0),
wild_do_table_inited(0), wild_ignore_table_inited(0) wild_do_table_inited(0), wild_ignore_table_inited(0)
{ {
@ -30,7 +30,7 @@ Table_filter::Table_filter() :
} }
Table_filter::~Table_filter() Rpl_filter::~Rpl_filter()
{ {
if (do_table_inited) if (do_table_inited)
hash_free(&do_table); hash_free(&do_table);
@ -85,10 +85,10 @@ Table_filter::~Table_filter()
*/ */
bool bool
Table_filter::tables_ok(const char* db, TABLE_LIST* tables) Rpl_filter::tables_ok(const char* db, TABLE_LIST* tables)
{ {
bool some_tables_updating= 0; bool some_tables_updating= 0;
DBUG_ENTER("Table_filter::tables_ok"); DBUG_ENTER("Rpl_filter::tables_ok");
for (; tables; tables= tables->next_global) for (; tables; tables= tables->next_global)
{ {
@ -144,9 +144,9 @@ Table_filter::tables_ok(const char* db, TABLE_LIST* tables)
*/ */
bool bool
Table_filter::db_ok(const char* db) Rpl_filter::db_ok(const char* db)
{ {
DBUG_ENTER("Table_filter::db_ok"); DBUG_ENTER("Rpl_filter::db_ok");
if (do_db.is_empty() && ignore_db.is_empty()) if (do_db.is_empty() && ignore_db.is_empty())
DBUG_RETURN(1); // Ok to replicate if the user puts no constraints DBUG_RETURN(1); // Ok to replicate if the user puts no constraints
@ -216,9 +216,9 @@ Table_filter::db_ok(const char* db)
*/ */
bool bool
Table_filter::db_ok_with_wild_table(const char *db) Rpl_filter::db_ok_with_wild_table(const char *db)
{ {
DBUG_ENTER("Table_filter::db_ok_with_wild_table"); DBUG_ENTER("Rpl_filter::db_ok_with_wild_table");
char hash_key[NAME_LEN+2]; char hash_key[NAME_LEN+2];
char *end; char *end;
@ -247,16 +247,16 @@ Table_filter::db_ok_with_wild_table(const char *db)
bool bool
Table_filter::is_on() Rpl_filter::is_on()
{ {
return table_rules_on; return table_rules_on;
} }
int int
Table_filter::add_do_table(const char* table_spec) Rpl_filter::add_do_table(const char* table_spec)
{ {
DBUG_ENTER("Table_filter::add_do_table"); DBUG_ENTER("Rpl_filter::add_do_table");
if (!do_table_inited) if (!do_table_inited)
init_table_rule_hash(&do_table, &do_table_inited); init_table_rule_hash(&do_table, &do_table_inited);
table_rules_on= 1; table_rules_on= 1;
@ -265,9 +265,9 @@ Table_filter::add_do_table(const char* table_spec)
int int
Table_filter::add_ignore_table(const char* table_spec) Rpl_filter::add_ignore_table(const char* table_spec)
{ {
DBUG_ENTER("Table_filter::add_ignore_table"); DBUG_ENTER("Rpl_filter::add_ignore_table");
if (!ignore_table_inited) if (!ignore_table_inited)
init_table_rule_hash(&ignore_table, &ignore_table_inited); init_table_rule_hash(&ignore_table, &ignore_table_inited);
table_rules_on= 1; table_rules_on= 1;
@ -276,9 +276,9 @@ Table_filter::add_ignore_table(const char* table_spec)
int int
Table_filter::add_wild_do_table(const char* table_spec) Rpl_filter::add_wild_do_table(const char* table_spec)
{ {
DBUG_ENTER("Table_filter::add_wild_do_table"); DBUG_ENTER("Rpl_filter::add_wild_do_table");
if (!wild_do_table_inited) if (!wild_do_table_inited)
init_table_rule_array(&wild_do_table, &wild_do_table_inited); init_table_rule_array(&wild_do_table, &wild_do_table_inited);
table_rules_on= 1; table_rules_on= 1;
@ -287,9 +287,9 @@ Table_filter::add_wild_do_table(const char* table_spec)
int int
Table_filter::add_wild_ignore_table(const char* table_spec) Rpl_filter::add_wild_ignore_table(const char* table_spec)
{ {
DBUG_ENTER("Table_filter::add_wild_ignore_table"); DBUG_ENTER("Rpl_filter::add_wild_ignore_table");
if (!wild_ignore_table_inited) if (!wild_ignore_table_inited)
init_table_rule_array(&wild_ignore_table, &wild_ignore_table_inited); init_table_rule_array(&wild_ignore_table, &wild_ignore_table_inited);
table_rules_on= 1; table_rules_on= 1;
@ -298,7 +298,7 @@ Table_filter::add_wild_ignore_table(const char* table_spec)
void void
Table_filter::add_db_rewrite(const char* from_db, const char* to_db) Rpl_filter::add_db_rewrite(const char* from_db, const char* to_db)
{ {
i_string_pair *db_pair = new i_string_pair(from_db, to_db); i_string_pair *db_pair = new i_string_pair(from_db, to_db);
rewrite_db.push_back(db_pair); rewrite_db.push_back(db_pair);
@ -306,7 +306,7 @@ Table_filter::add_db_rewrite(const char* from_db, const char* to_db)
int int
Table_filter::add_table_rule(HASH* h, const char* table_spec) Rpl_filter::add_table_rule(HASH* h, const char* table_spec)
{ {
const char* dot = strchr(table_spec, '.'); const char* dot = strchr(table_spec, '.');
if (!dot) return 1; if (!dot) return 1;
@ -329,7 +329,7 @@ Table_filter::add_table_rule(HASH* h, const char* table_spec)
*/ */
int int
Table_filter::add_wild_table_rule(DYNAMIC_ARRAY* a, const char* table_spec) Rpl_filter::add_wild_table_rule(DYNAMIC_ARRAY* a, const char* table_spec)
{ {
const char* dot = strchr(table_spec, '.'); const char* dot = strchr(table_spec, '.');
if (!dot) return 1; if (!dot) return 1;
@ -347,16 +347,18 @@ Table_filter::add_wild_table_rule(DYNAMIC_ARRAY* a, const char* table_spec)
void void
Table_filter::add_do_db(const char* table_spec) Rpl_filter::add_do_db(const char* table_spec)
{ {
DBUG_ENTER("Rpl_filter::add_do_db");
i_string *db = new i_string(table_spec); i_string *db = new i_string(table_spec);
do_db.push_back(db); do_db.push_back(db);
} }
void void
Table_filter::add_ignore_db(const char* table_spec) Rpl_filter::add_ignore_db(const char* table_spec)
{ {
DBUG_ENTER("Rpl_filter::add_ignore_db");
i_string *db = new i_string(table_spec); i_string *db = new i_string(table_spec);
ignore_db.push_back(db); ignore_db.push_back(db);
} }
@ -381,7 +383,7 @@ static void free_table_ent(void* a)
void void
Table_filter::init_table_rule_hash(HASH* h, bool* h_inited) Rpl_filter::init_table_rule_hash(HASH* h, bool* h_inited)
{ {
hash_init(h, system_charset_info,TABLE_RULE_HASH_SIZE,0,0, hash_init(h, system_charset_info,TABLE_RULE_HASH_SIZE,0,0,
get_table_key, free_table_ent, 0); get_table_key, free_table_ent, 0);
@ -390,7 +392,7 @@ Table_filter::init_table_rule_hash(HASH* h, bool* h_inited)
void void
Table_filter::init_table_rule_array(DYNAMIC_ARRAY* a, bool* a_inited) Rpl_filter::init_table_rule_array(DYNAMIC_ARRAY* a, bool* a_inited)
{ {
my_init_dynamic_array(a, sizeof(TABLE_RULE_ENT*), TABLE_RULE_ARR_SIZE, my_init_dynamic_array(a, sizeof(TABLE_RULE_ENT*), TABLE_RULE_ARR_SIZE,
TABLE_RULE_ARR_SIZE); TABLE_RULE_ARR_SIZE);
@ -399,7 +401,7 @@ Table_filter::init_table_rule_array(DYNAMIC_ARRAY* a, bool* a_inited)
TABLE_RULE_ENT* TABLE_RULE_ENT*
Table_filter::find_wild(DYNAMIC_ARRAY *a, const char* key, int len) Rpl_filter::find_wild(DYNAMIC_ARRAY *a, const char* key, int len)
{ {
uint i; uint i;
const char* key_end= key + len; const char* key_end= key + len;
@ -420,7 +422,7 @@ Table_filter::find_wild(DYNAMIC_ARRAY *a, const char* key, int len)
void void
Table_filter::free_string_array(DYNAMIC_ARRAY *a) Rpl_filter::free_string_array(DYNAMIC_ARRAY *a)
{ {
uint i; uint i;
for (i= 0; i < a->elements; i++) for (i= 0; i < a->elements; i++)
@ -447,7 +449,7 @@ Table_filter::free_string_array(DYNAMIC_ARRAY *a)
*/ */
void void
Table_filter::table_rule_ent_hash_to_str(String* s, HASH* h) Rpl_filter::table_rule_ent_hash_to_str(String* s, HASH* h)
{ {
s->length(0); s->length(0);
for (uint i= 0; i < h->records; i++) for (uint i= 0; i < h->records; i++)
@ -461,7 +463,7 @@ Table_filter::table_rule_ent_hash_to_str(String* s, HASH* h)
void void
Table_filter::table_rule_ent_dynamic_array_to_str(String* s, DYNAMIC_ARRAY* a) Rpl_filter::table_rule_ent_dynamic_array_to_str(String* s, DYNAMIC_ARRAY* a)
{ {
s->length(0); s->length(0);
for (uint i= 0; i < a->elements; i++) for (uint i= 0; i < a->elements; i++)
@ -476,35 +478,35 @@ Table_filter::table_rule_ent_dynamic_array_to_str(String* s, DYNAMIC_ARRAY* a)
void void
Table_filter::get_do_table(String* str) Rpl_filter::get_do_table(String* str)
{ {
table_rule_ent_hash_to_str(str, &do_table); table_rule_ent_hash_to_str(str, &do_table);
} }
void void
Table_filter::get_ignore_table(String* str) Rpl_filter::get_ignore_table(String* str)
{ {
table_rule_ent_hash_to_str(str, &ignore_table); table_rule_ent_hash_to_str(str, &ignore_table);
} }
void void
Table_filter::get_wild_do_table(String* str) Rpl_filter::get_wild_do_table(String* str)
{ {
table_rule_ent_dynamic_array_to_str(str, &wild_do_table); table_rule_ent_dynamic_array_to_str(str, &wild_do_table);
} }
void void
Table_filter::get_wild_ignore_table(String* str) Rpl_filter::get_wild_ignore_table(String* str)
{ {
table_rule_ent_dynamic_array_to_str(str, &wild_ignore_table); table_rule_ent_dynamic_array_to_str(str, &wild_ignore_table);
} }
const char* const char*
Table_filter::get_rewrite_db(const char* db, uint32 *new_len) Rpl_filter::get_rewrite_db(const char* db, uint32 *new_len)
{ {
if (rewrite_db.is_empty() || !db) if (rewrite_db.is_empty() || !db)
return db; return db;
@ -524,14 +526,14 @@ Table_filter::get_rewrite_db(const char* db, uint32 *new_len)
I_List<i_string>* I_List<i_string>*
Table_filter::get_do_db() Rpl_filter::get_do_db()
{ {
return &do_db; return &do_db;
} }
I_List<i_string>* I_List<i_string>*
Table_filter::get_ignore_db() Rpl_filter::get_ignore_db()
{ {
return &ignore_db; return &ignore_db;
} }

View file

@ -14,8 +14,8 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#ifndef __TABLE_FILTER_H__ #ifndef __RPL_FILTER_H__
#define __TABLE_FILTER_H__ #define __RPL_FILTER_H__
#include "mysql.h" #include "mysql.h"
#include "my_list.h" #include "my_list.h"
@ -28,19 +28,19 @@ typedef struct st_table_rule_ent
} TABLE_RULE_ENT; } TABLE_RULE_ENT;
/* /*
Table_filter Rpl_filter
Inclusion and exclusion rules of tables and databases. Inclusion and exclusion rules of tables and databases.
Also handles rewrites of db. Also handles rewrites of db.
Used for replication and binlogging. Used for replication and binlogging.
*/ */
class Table_filter class Rpl_filter
{ {
public: public:
Table_filter(); Rpl_filter();
~Table_filter(); ~Rpl_filter();
Table_filter(Table_filter const&); Rpl_filter(Rpl_filter const&);
Table_filter& operator=(Table_filter const&); Rpl_filter& operator=(Rpl_filter const&);
/* Checks - returns true if ok to replicate/log */ /* Checks - returns true if ok to replicate/log */

View file

@ -22,7 +22,7 @@
#include <myisam.h> #include <myisam.h>
#include "slave.h" #include "slave.h"
#include "sql_repl.h" #include "sql_repl.h"
#include "table_filter.h" #include "rpl_filter.h"
#include "repl_failsafe.h" #include "repl_failsafe.h"
#include <thr_alarm.h> #include <thr_alarm.h>
#include <my_dir.h> #include <my_dir.h>

View file

@ -21,13 +21,13 @@
#include "mysql.h" #include "mysql.h"
#include "my_list.h" #include "my_list.h"
#include "table_filter.h" #include "rpl_filter.h"
#define SLAVE_NET_TIMEOUT 3600 #define SLAVE_NET_TIMEOUT 3600
#define MAX_SLAVE_ERRMSG 1024 #define MAX_SLAVE_ERRMSG 1024
#define MAX_SLAVE_ERROR 2000 #define MAX_SLAVE_ERROR 2000
extern Table_filter *rpl_filter; extern Rpl_filter *rpl_filter;
/***************************************************************************** /*****************************************************************************

View file

@ -15,7 +15,7 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
#include "slave.h" // for tables_ok(), rpl_filter #include "slave.h" // for tables_ok(), rpl_filter
extern Table_filter *rpl_filter; extern Rpl_filter *rpl_filter;
#define SELECT_ACL (1L << 0) #define SELECT_ACL (1L << 0)
#define INSERT_ACL (1L << 1) #define INSERT_ACL (1L << 1)

View file

@ -16,7 +16,7 @@
#include "mysql_priv.h" #include "mysql_priv.h"
#include "sql_repl.h" #include "sql_repl.h"
#include "table_filter.h" #include "rpl_filter.h"
#include "repl_failsafe.h" #include "repl_failsafe.h"
#include <m_ctype.h> #include <m_ctype.h>
#include <myisam.h> #include <myisam.h>

View file

@ -19,7 +19,7 @@
#include "sql_repl.h" #include "sql_repl.h"
#include "log_event.h" #include "log_event.h"
#include "table_filter.h" #include "rpl_filter.h"
#include <my_dir.h> #include <my_dir.h>
int max_binlog_dump_events = 0; // unlimited int max_binlog_dump_events = 0; // unlimited

View file

@ -17,8 +17,8 @@
#ifdef HAVE_REPLICATION #ifdef HAVE_REPLICATION
#include "slave.h" #include "slave.h"
extern Table_filter *binlog_filter; extern Rpl_filter *binlog_filter;
extern Table_filter *rpl_filter; extern Rpl_filter *rpl_filter;
typedef struct st_slave_info typedef struct st_slave_info
{ {