Commit 415381f6 authored by unknown's avatar unknown

changed to use IO_CACHE instead of FILE


BitKeeper/deleted/.del-mf_reccache.c:
  ***MISSING WEAVE***
Docs/manual.texi:
  Fix licence information + update changelog
client/mysqlimport.c:
  Fixed typo
client/sql_string.cc:
  Added support for IO_CACHE
client/sql_string.h:
  Added support for IO_CACHE
include/my_sys.h:
  More options for IO_CACHE
mysql.proj:
  Update
mysys/Makefile.am:
  Remoced mf_reccache.c
mysys/mf_cache.c:
  Fixed return value on error and optimzed used of write cache files
mysys/mf_iocache.c:
  More options for IO_CACHE
mysys/my_vsnprintf.c:
  Optimized code
sql/mf_iocache.cc:
  merge with mf_iocache.c
sql/net_pkg.cc:
  cleanup
sql/sql_class.cc:
  Support for transaction safe log files
sql/sql_string.cc:
  Added support for IO_CACHE
sql/sql_string.h:
  Added support for IO_CACHE
sql/time.cc:
  cleanup
BitKeeper/etc/logging_ok:
  Logging to logging@openlogging.org accepted
parent 097173f4
monty@tik.mysql.com monty@narttu.mysql.fi
...@@ -3610,10 +3610,13 @@ similar system. In the worst case, we may require access to your system ...@@ -3610,10 +3610,13 @@ similar system. In the worst case, we may require access to your system
to be able to create a binary distribution. to be able to create a binary distribution.
@item @item
If you can provide accommodations and pay for traveler fares, you can even If you can provide accommodations and pay for traveler fares, you can
get a @strong{MySQL} developer to visit you and offer you help with your even get a @strong{MySQL} developer to visit you and offer you help with
troubles. Extended login support entitles you to one personal your troubles. Extended login support entitles you to one personal
encounter per year, but we are always very flexible towards our customers! encounter per year, but we are always very flexible towards our
customers! If the visit takes 16 hours or more, the first 8 hours is
without charge. For the hours above 8 hours, you will be charged with a
rate that is at least 20 % less than our standard rates.
@end itemize @end itemize
@node Installing, Compatibility, Licensing and Support, Top @node Installing, Compatibility, Licensing and Support, Top
...@@ -38367,6 +38370,9 @@ though, so 3.23 is not released as a stable version yet. ...@@ -38367,6 +38370,9 @@ though, so 3.23 is not released as a stable version yet.
@appendixsubsec Changes in release 3.23.28 @appendixsubsec Changes in release 3.23.28
@itemize @bullet @itemize @bullet
@item @item
Changed all log files to use our own IO_CACHE mechanism instead of
FILE:s to avoid OS problems when there is many files open.
@item
Added options @code{--open-files} and @code{--timezone} to @code{safe_mysqld}. Added options @code{--open-files} and @code{--timezone} to @code{safe_mysqld}.
@item @item
Fixed fatal bug in @code{CREATE TEMPORARY TABLE ...SELECT ...}. Fixed fatal bug in @code{CREATE TEMPORARY TABLE ...SELECT ...}.
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
** * * ** * *
** ************************* ** *************************
*/ */
#define IMPORT_VERSION "2.5" #define IMPORT_VERSION "2.6"
#include <global.h> #include <global.h>
#include <my_sys.h> #include <my_sys.h>
...@@ -125,7 +125,7 @@ file. The SQL command 'LOAD DATA INFILE' is used to import the rows.\n"); ...@@ -125,7 +125,7 @@ file. The SQL command 'LOAD DATA INFILE' is used to import the rows.\n");
Give the column names in a comma separated list.\n\ Give the column names in a comma separated list.\n\
This is same as giving columns to LOAD DATA INFILE.\n\ This is same as giving columns to LOAD DATA INFILE.\n\
-C, --compress Use compression in server/client protocol\n\ -C, --compress Use compression in server/client protocol\n\
-d, --delete Deletes first all rows from table.\n\ -d, --delete First delete all rows from table.\n\
-f, --force Continue even if we get an sql-error.\n\ -f, --force Continue even if we get an sql-error.\n\
-h, --host=... Connect to host.\n\ -h, --host=... Connect to host.\n\
-i, --ignore If duplicate unique key was found, keep old row.\n\ -i, --ignore If duplicate unique key was found, keep old row.\n\
......
...@@ -95,17 +95,6 @@ bool String::realloc(uint32 alloc_length) ...@@ -95,17 +95,6 @@ bool String::realloc(uint32 alloc_length)
return FALSE; return FALSE;
} }
#ifdef NOT_NEEDED
bool String::set(long num)
{
if (alloc(14))
return TRUE;
str_length=(uint32) (int10_to_str(num,Ptr,-10)-Ptr);
return FALSE;
}
#endif
bool String::set(longlong num) bool String::set(longlong num)
{ {
if (alloc(21)) if (alloc(21))
...@@ -274,6 +263,7 @@ bool String::append(const char *s,uint32 arg_length) ...@@ -274,6 +263,7 @@ bool String::append(const char *s,uint32 arg_length)
return FALSE; return FALSE;
} }
#ifdef TO_BE_REMOVED
bool String::append(FILE* file, uint32 arg_length, myf my_flags) bool String::append(FILE* file, uint32 arg_length, myf my_flags)
{ {
if (realloc(str_length+arg_length)) if (realloc(str_length+arg_length))
...@@ -286,6 +276,20 @@ bool String::append(FILE* file, uint32 arg_length, myf my_flags) ...@@ -286,6 +276,20 @@ bool String::append(FILE* file, uint32 arg_length, myf my_flags)
str_length+=arg_length; str_length+=arg_length;
return FALSE; return FALSE;
} }
#endif
bool String::append(IO_CACHE* file, uint32 arg_length)
{
if (realloc(str_length+arg_length))
return TRUE;
if (my_b_read(file, (byte*) Ptr + str_length, arg_length))
{
shrink(str_length);
return TRUE;
}
str_length+=arg_length;
return FALSE;
}
uint32 String::numchars() uint32 String::numchars()
{ {
......
...@@ -100,16 +100,16 @@ class String ...@@ -100,16 +100,16 @@ class String
bool set(ulonglong num); bool set(ulonglong num);
bool set(double num,uint decimals=2); bool set(double num,uint decimals=2);
inline void free() inline void free()
{
if (alloced)
{ {
if (alloced) alloced=0;
{ Alloced_length=0;
alloced=0; my_free(Ptr,MYF(0));
Alloced_length=0; Ptr=0;
my_free(Ptr,MYF(0)); str_length=0; /* Safety */
Ptr=0;
}
} }
}
inline bool alloc(uint32 arg_length) inline bool alloc(uint32 arg_length)
{ {
if (arg_length < Alloced_length) if (arg_length < Alloced_length)
...@@ -152,7 +152,7 @@ class String ...@@ -152,7 +152,7 @@ class String
bool copy(const char *s,uint32 arg_length); // Allocate new string bool copy(const char *s,uint32 arg_length); // Allocate new string
bool append(const String &s); bool append(const String &s);
bool append(const char *s,uint32 arg_length=0); bool append(const char *s,uint32 arg_length=0);
bool append(FILE* file, uint32 arg_length, myf my_flags); bool append(IO_CACHE* file, uint32 arg_length);
int strstr(const String &search,uint32 offset=0); // Returns offset to substring or -1 int strstr(const String &search,uint32 offset=0); // Returns offset to substring or -1
int strrstr(const String &search,uint32 offset=0); // Returns offset to substring or -1 int strrstr(const String &search,uint32 offset=0); // Returns offset to substring or -1
bool replace(uint32 offset,uint32 arg_length,const String &to); bool replace(uint32 offset,uint32 arg_length,const String &to);
......
...@@ -59,6 +59,7 @@ extern int NEAR my_errno; /* Last error in mysys */ ...@@ -59,6 +59,7 @@ extern int NEAR my_errno; /* Last error in mysys */
#define MY_WME 16 /* Write message on error */ #define MY_WME 16 /* Write message on error */
#define MY_WAIT_IF_FULL 32 /* Wait and try again if disk full error */ #define MY_WAIT_IF_FULL 32 /* Wait and try again if disk full error */
#define MY_RAID 64 /* Support for RAID (not the "Johnson&Johnson"-s one ;) */ #define MY_RAID 64 /* Support for RAID (not the "Johnson&Johnson"-s one ;) */
#define MY_DONT_CHECK_FILESIZE 128 /* Option to init_io_cache() */
#define MY_LINK_WARNING 32 /* my_redel() gives warning if links */ #define MY_LINK_WARNING 32 /* my_redel() gives warning if links */
#define MY_COPYTIME 64 /* my_redel() copys time */ #define MY_COPYTIME 64 /* my_redel() copys time */
#define MY_HOLD_ORIGINAL_MODES 128 /* my_copy() holds to file modes */ #define MY_HOLD_ORIGINAL_MODES 128 /* my_copy() holds to file modes */
...@@ -505,6 +506,10 @@ extern int my_block_write(IO_CACHE *info, const byte *Buffer, ...@@ -505,6 +506,10 @@ extern int my_block_write(IO_CACHE *info, const byte *Buffer,
uint Count, my_off_t pos); uint Count, my_off_t pos);
extern int flush_io_cache(IO_CACHE *info); extern int flush_io_cache(IO_CACHE *info);
extern int end_io_cache(IO_CACHE *info); extern int end_io_cache(IO_CACHE *info);
extern uint my_b_fill(IO_CACHE *info);
extern void my_b_seek(IO_CACHE *info,my_off_t pos);
extern uint my_b_gets(IO_CACHE *info, char *to, uint max_length);
extern uint my_b_printf(IO_CACHE *info, const char* fmt, ...);
extern my_bool open_cached_file(IO_CACHE *cache,const char *dir, extern my_bool open_cached_file(IO_CACHE *cache,const char *dir,
const char *prefix, uint cache_size, const char *prefix, uint cache_size,
myf cache_myflags); myf cache_myflags);
......
No preview for this file type
...@@ -26,7 +26,7 @@ libmysys_a_SOURCES = my_init.c my_getwd.c mf_getdate.c\ ...@@ -26,7 +26,7 @@ libmysys_a_SOURCES = my_init.c my_getwd.c mf_getdate.c\
mf_path.c mf_loadpath.c\ mf_path.c mf_loadpath.c\
my_open.c my_create.c my_seek.c my_read.c \ my_open.c my_create.c my_seek.c my_read.c \
my_pread.c my_write.c \ my_pread.c my_write.c \
mf_reccache.c mf_keycache.c \ mf_keycache.c \
mf_iocache.c mf_cache.c mf_tempfile.c \ mf_iocache.c mf_cache.c mf_tempfile.c \
my_lock.c mf_brkhant.c my_alarm.c \ my_lock.c mf_brkhant.c my_alarm.c \
my_malloc.c my_realloc.c my_once.c mulalloc.c \ my_malloc.c my_realloc.c my_once.c mulalloc.c \
......
...@@ -74,7 +74,7 @@ my_bool open_cached_file(IO_CACHE *cache, const char* dir, const char *prefix, ...@@ -74,7 +74,7 @@ my_bool open_cached_file(IO_CACHE *cache, const char* dir, const char *prefix,
} }
my_free(cache->dir, MYF(MY_ALLOW_ZERO_PTR)); my_free(cache->dir, MYF(MY_ALLOW_ZERO_PTR));
my_free(cache->prefix,MYF(MY_ALLOW_ZERO_PTR)); my_free(cache->prefix,MYF(MY_ALLOW_ZERO_PTR));
DBUG_RETURN(0); DBUG_RETURN(1);
} }
/* Create the temporary file */ /* Create the temporary file */
...@@ -101,10 +101,12 @@ void close_cached_file(IO_CACHE *cache) ...@@ -101,10 +101,12 @@ void close_cached_file(IO_CACHE *cache)
DBUG_ENTER("close_cached_file"); DBUG_ENTER("close_cached_file");
if (my_b_inited(cache)) if (my_b_inited(cache))
{ {
File file=cache->file;
cache->file= -1; /* Don't flush data */
(void) end_io_cache(cache); (void) end_io_cache(cache);
if (cache->file >= 0) if (file >= 0)
{ {
(void) my_close(cache->file,MYF(0)); (void) my_close(file,MYF(0));
#ifdef CANT_DELETE_OPEN_FILES #ifdef CANT_DELETE_OPEN_FILES
if (cache->file_name) if (cache->file_name)
{ {
......
...@@ -22,10 +22,13 @@ ...@@ -22,10 +22,13 @@
(and get a EOF-error). (and get a EOF-error).
Possibly use of asyncronic io. Possibly use of asyncronic io.
macros for read and writes for faster io. macros for read and writes for faster io.
Used instead of FILE when reading or writing hole files. Used instead of FILE when reading or writing whole files.
This shall make mf_rec_cache obsolite. This will make mf_rec_cache obsolete.
One can change info->pos_in_file to a higer value to skipp bytes in file if One can change info->pos_in_file to a higher value to skip bytes in file if
also info->rc_pos is set to info->rc_end. also info->rc_pos is set to info->rc_end.
If called through open_cached_file(), then the temporary file will
only be created if a write exeeds the file buffer or if one calls
flush_io_cache().
*/ */
#define MAP_TO_USE_RAID #define MAP_TO_USE_RAID
...@@ -40,7 +43,7 @@ static void my_aiowait(my_aio_result *result); ...@@ -40,7 +43,7 @@ static void my_aiowait(my_aio_result *result);
/* /*
** if cachesize == 0 then use default cachesize (from s-file) ** if cachesize == 0 then use default cachesize (from s-file)
** if file == -1 then real_open_cached_file() will be called to ** if file == -1 then real_open_cached_file() will be called.
** returns 0 if ok ** returns 0 if ok
*/ */
...@@ -59,17 +62,24 @@ int init_io_cache(IO_CACHE *info, File file, uint cachesize, ...@@ -59,17 +62,24 @@ int init_io_cache(IO_CACHE *info, File file, uint cachesize,
min_cache=use_async_io ? IO_SIZE*4 : IO_SIZE*2; min_cache=use_async_io ? IO_SIZE*4 : IO_SIZE*2;
if (type == READ_CACHE) if (type == READ_CACHE)
{ /* Assume file isn't growing */ { /* Assume file isn't growing */
my_off_t file_pos,end_of_file; if (cache_myflags & MY_DONT_CHECK_FILESIZE)
if ((file_pos=my_tell(file,MYF(0)) == MY_FILEPOS_ERROR))
DBUG_RETURN(1);
end_of_file=my_seek(file,0L,MY_SEEK_END,MYF(0));
if (end_of_file < seek_offset)
end_of_file=seek_offset;
VOID(my_seek(file,file_pos,MY_SEEK_SET,MYF(0)));
if ((my_off_t) cachesize > end_of_file-seek_offset+IO_SIZE*2-1)
{ {
cachesize=(uint) (end_of_file-seek_offset)+IO_SIZE*2-1; cache_myflags &= ~MY_DONT_CHECK_FILESIZE;
use_async_io=0; /* No nead to use async */ }
else
{
my_off_t file_pos,end_of_file;
if ((file_pos=my_tell(file,MYF(0)) == MY_FILEPOS_ERROR))
DBUG_RETURN(1);
end_of_file=my_seek(file,0L,MY_SEEK_END,MYF(0));
if (end_of_file < seek_offset)
end_of_file=seek_offset;
VOID(my_seek(file,file_pos,MY_SEEK_SET,MYF(0)));
if ((my_off_t) cachesize > end_of_file-seek_offset+IO_SIZE*2-1)
{
cachesize=(uint) (end_of_file-seek_offset)+IO_SIZE*2-1;
use_async_io=0; /* No nead to use async */
}
} }
} }
...@@ -545,7 +555,6 @@ int my_block_write(register IO_CACHE *info, const byte *Buffer, uint Count, ...@@ -545,7 +555,6 @@ int my_block_write(register IO_CACHE *info, const byte *Buffer, uint Count,
return error; return error;
} }
/* Flush write cache */ /* Flush write cache */
int flush_io_cache(IO_CACHE *info) int flush_io_cache(IO_CACHE *info)
...@@ -565,7 +574,9 @@ int flush_io_cache(IO_CACHE *info) ...@@ -565,7 +574,9 @@ int flush_io_cache(IO_CACHE *info)
length=(uint) (info->rc_pos - info->buffer); length=(uint) (info->rc_pos - info->buffer);
if (info->seek_not_done) if (info->seek_not_done)
{ /* File touched, do seek */ { /* File touched, do seek */
VOID(my_seek(info->file,info->pos_in_file,MY_SEEK_SET,MYF(0))); if (my_seek(info->file,info->pos_in_file,MY_SEEK_SET,MYF(0)) ==
MY_FILEPOS_ERROR)
DBUG_RETURN((info->error= -1));
info->seek_not_done=0; info->seek_not_done=0;
} }
info->rc_pos=info->buffer; info->rc_pos=info->buffer;
......
...@@ -21,74 +21,49 @@ ...@@ -21,74 +21,49 @@
#include <stdarg.h> #include <stdarg.h>
#include <m_ctype.h> #include <m_ctype.h>
int my_vsnprintf(char *to, size_t n, const char* fmt, va_list ap)
int my_vsnprintf(char* str, size_t n, const char* fmt, va_list ap)
{ {
uint olen = 0, plen; char *start=to, *end=to+n-1;
const char *tpos;
reg1 char *endpos;
reg2 char * par;
char* ebuff = str;
endpos=ebuff;
tpos = fmt;
while (*tpos) for (; *fmt ; fmt++)
{ {
if (tpos[0] != '%') if (fmt[0] != '%')
{ {
if(olen + 1 >= n) if (to == end) /* End of buffer */
break; break;
*to++= *fmt; /* Copy ordinary char */
*endpos++= *tpos++; /* Copy ordinary char */
olen++;
continue; continue;
} }
if (*++tpos == '%') /* test if %% */ /* Skipp if max size is used (to be compatible with printf) */
{ while (isdigit(*fmt) || *fmt == '.' || *fmt == '-')
olen--; fmt++;
} if (*fmt == 's') /* String parameter */
else
{ {
/* Skipp if max size is used (to be compatible with printf) */ reg2 char *par = va_arg(ap, char *);
while (isdigit(*tpos) || *tpos == '.' || *tpos == '-') uint plen = (uint) strlen(par);
tpos++; if ((uint) (end-to) > plen) /* Replace if possible */
if (*tpos == 's') /* String parameter */
{
par = va_arg(ap, char *);
plen = (uint) strlen(par);
if (olen + plen < n) /* Replace if possible */
{
endpos=strmov(endpos,par);
tpos++;
olen+=plen;
continue;
}
}
else if (*tpos == 'd' || *tpos == 'u') /* Integer parameter */
{ {
register int iarg; to=strmov(to,par);
iarg = va_arg(ap, int); continue;
if(olen + 16 >= n) break;
if (*tpos == 'd')
plen= (uint) (int2str((long) iarg,endpos, -10) - endpos);
else
plen= (uint) (int2str((long) (uint) iarg,endpos,10)- endpos);
if (olen + plen < n) /* Replace parameter if possible */
{
endpos+=plen;
tpos++;
olen+=plen;
continue;
}
} }
} }
*endpos++='%'; /* % used as % or unknown code */ else if (*fmt == 'd' || *fmt == 'u') /* Integer parameter */
{
register int iarg;
if ((uint) (end-to) < 16)
break;
iarg = va_arg(ap, int);
if (*fmt == 'd')
to=int10_to_str((long) iarg,to, -10);
else
to=int10_to_str((long) (uint) iarg,to,10);
continue;
}
/* We come here on '%%', unknown code or too long parameter */
if (to == end)
break;
*to++='%'; /* % used as % or unknown code */
} }
*endpos='\0'; *to='\0'; /* End of errmessage */
/* End of errmessage */ return (uint) (to - start);
return olen;
} }
This diff is collapsed.
This diff is collapsed.
...@@ -65,9 +65,9 @@ class Log_event ...@@ -65,9 +65,9 @@ class Log_event
int valid_exec_time; // if false, the exec time setting is bogus int valid_exec_time; // if false, the exec time setting is bogus
uint32 server_id; uint32 server_id;
int write(FILE* file); int write(IO_CACHE* file);
int write_header(FILE* file); int write_header(IO_CACHE* file);
virtual int write_data(FILE* file __attribute__((unused))) { return 0; } virtual int write_data(IO_CACHE* file __attribute__((unused))) { return 0; }
virtual Log_event_type get_type_code() = 0; virtual Log_event_type get_type_code() = 0;
Log_event(time_t when_arg, ulong exec_time_arg = 0, Log_event(time_t when_arg, ulong exec_time_arg = 0,
int valid_exec_time_arg = 0, uint32 server_id = 0): when(when_arg), int valid_exec_time_arg = 0, uint32 server_id = 0): when(when_arg),
...@@ -92,11 +92,11 @@ class Log_event ...@@ -92,11 +92,11 @@ class Log_event
void print_header(FILE* file); void print_header(FILE* file);
// if mutex is 0, the read will proceed without mutex // if mutex is 0, the read will proceed without mutex
static Log_event* read_log_event(FILE* file, pthread_mutex_t* log_lock); static Log_event* read_log_event(IO_CACHE* file, pthread_mutex_t* log_lock);
static Log_event* read_log_event(const char* buf, int max_buf); static Log_event* read_log_event(const char* buf, int max_buf);
#ifndef MYSQL_CLIENT #ifndef MYSQL_CLIENT
static int read_log_event(FILE* file, String* packet, static int read_log_event(IO_CACHE* file, String* packet,
pthread_mutex_t* log_lock); pthread_mutex_t* log_lock);
#endif #endif
...@@ -132,18 +132,18 @@ class Query_log_event: public Log_event ...@@ -132,18 +132,18 @@ class Query_log_event: public Log_event
} }
#endif #endif
Query_log_event(FILE* file, time_t when, uint32 server_id); Query_log_event(IO_CACHE* file, time_t when, uint32 server_id);
Query_log_event(const char* buf, int max_buf); Query_log_event(const char* buf, int max_buf);
~Query_log_event() ~Query_log_event()
{ {
if (data_buf) if (data_buf)
{ {
my_free((gptr)data_buf, MYF(0)); my_free((gptr) data_buf, MYF(0));
} }
} }
Log_event_type get_type_code() { return QUERY_EVENT; } Log_event_type get_type_code() { return QUERY_EVENT; }
int write(FILE* file); int write(IO_CACHE* file);
int write_data(FILE* file); // returns 0 on success, -1 on error int write_data(IO_CACHE* file); // returns 0 on success, -1 on error
int get_data_size() int get_data_size()
{ {
return q_len + db_len + 2 + return q_len + db_len + 2 +
...@@ -183,6 +183,8 @@ class Load_log_event: public Log_event ...@@ -183,6 +183,8 @@ class Load_log_event: public Log_event
{ {
protected: protected:
char* data_buf; char* data_buf;
void Load_log_event::copy_log_event(const char *buf, ulong data_len);
public: public:
int thread_id; int thread_id;
uint32 table_name_len; uint32 table_name_len;
...@@ -272,17 +274,17 @@ class Load_log_event: public Log_event ...@@ -272,17 +274,17 @@ class Load_log_event: public Log_event
void set_fields(List<Item> &fields); void set_fields(List<Item> &fields);
#endif #endif
Load_log_event(FILE* file, time_t when, uint32 server_id); Load_log_event(IO_CACHE * file, time_t when, uint32 server_id);
Load_log_event(const char* buf, int max_buf); Load_log_event(const char* buf, int max_buf);
~Load_log_event() ~Load_log_event()
{ {
if (data_buf) if (data_buf)
{ {
my_free((gptr)data_buf, MYF(0)); my_free((gptr) data_buf, MYF(0));
} }
} }
Log_event_type get_type_code() { return LOAD_EVENT; } Log_event_type get_type_code() { return LOAD_EVENT; }
int write_data(FILE* file); // returns 0 on success, -1 on error int write_data(IO_CACHE* file); // returns 0 on success, -1 on error
int get_data_size() int get_data_size()
{ {
return table_name_len + 2 + db_len + 2 + fname_len return table_name_len + 2 + db_len + 2 + fname_len
...@@ -311,30 +313,26 @@ class Start_log_event: public Log_event ...@@ -311,30 +313,26 @@ class Start_log_event: public Log_event
created = (uint32) when; created = (uint32) when;
memcpy(server_version, ::server_version, sizeof(server_version)); memcpy(server_version, ::server_version, sizeof(server_version));
} }
Start_log_event(FILE* file, time_t when_arg, uint32 server_id) : Start_log_event(IO_CACHE* file, time_t when_arg, uint32 server_id) :
Log_event(when_arg, 0, 0, server_id) Log_event(when_arg, 0, 0, server_id)
{ {
char buf[sizeof(server_version) + sizeof(binlog_version) + char buf[sizeof(server_version) + sizeof(binlog_version) +
sizeof(created)]; sizeof(created)+4];
my_fseek(file, 4L, MY_SEEK_CUR, MYF(MY_WME)); // skip the event length if (my_b_read(file, (byte*) buf, sizeof(buf)))
if (my_fread(file, (byte*) buf, sizeof(buf), MYF(MY_NABP | MY_WME)))
return; return;
binlog_version = uint2korr(buf); binlog_version = uint2korr(buf+4);
memcpy(server_version, buf + 2, sizeof(server_version)); memcpy(server_version, buf + 6, sizeof(server_version));
created = uint4korr(buf + 2 + sizeof(server_version)); created = uint4korr(buf + 6 + sizeof(server_version));
} }
Start_log_event(const char* buf); Start_log_event(const char* buf);
~Start_log_event() {} ~Start_log_event() {}
Log_event_type get_type_code() { return START_EVENT;} Log_event_type get_type_code() { return START_EVENT;}
int write_data(FILE* file) int write_data(IO_CACHE* file)
{ {
if(my_fwrite(file, (byte*) &binlog_version, sizeof(binlog_version), if (my_b_write(file, (byte*) &binlog_version, sizeof(binlog_version)) ||
MYF(MY_NABP | MY_WME)) || my_b_write(file, (byte*) server_version, sizeof(server_version)) ||
my_fwrite(file, (byte*) server_version, sizeof(server_version), my_b_write(file, (byte*) &created, sizeof(created)))
MYF(MY_NABP | MY_WME)) ||
my_fwrite(file, (byte*) &created, sizeof(created),
MYF(MY_NABP | MY_WME)))
return -1; return -1;
return 0; return 0;
} }
...@@ -354,12 +352,12 @@ class Intvar_log_event: public Log_event ...@@ -354,12 +352,12 @@ class Intvar_log_event: public Log_event
Intvar_log_event(uchar type_arg, ulonglong val_arg) Intvar_log_event(uchar type_arg, ulonglong val_arg)
:Log_event(time(NULL)),val(val_arg),type(type_arg) :Log_event(time(NULL)),val(val_arg),type(type_arg)
{} {}
Intvar_log_event(FILE* file, time_t when, uint32 server_id); Intvar_log_event(IO_CACHE* file, time_t when, uint32 server_id);
Intvar_log_event(const char* buf); Intvar_log_event(const char* buf);
~Intvar_log_event() {} ~Intvar_log_event() {}
Log_event_type get_type_code() { return INTVAR_EVENT;} Log_event_type get_type_code() { return INTVAR_EVENT;}
int get_data_size() { return sizeof(type) + sizeof(val);} int get_data_size() { return sizeof(type) + sizeof(val);}
int write_data(FILE* file); int write_data(IO_CACHE* file);
void print(FILE* file, bool short_form = 0); void print(FILE* file, bool short_form = 0);
...@@ -370,10 +368,11 @@ class Stop_log_event: public Log_event ...@@ -370,10 +368,11 @@ class Stop_log_event: public Log_event
public: public:
Stop_log_event() :Log_event(time(NULL)) Stop_log_event() :Log_event(time(NULL))
{} {}
Stop_log_event(FILE* file, time_t when_arg, uint32 server_id): Stop_log_event(IO_CACHE* file, time_t when_arg, uint32 server_id):
Log_event(when_arg,0,0,server_id) Log_event(when_arg,0,0,server_id)
{ {
my_fseek(file, 4L, MY_SEEK_CUR, MYF(MY_WME)); // skip the event length char skip[4];
my_b_read(file, skip, sizeof(skip)); // skip the event length
} }
Stop_log_event(const char* buf):Log_event(buf) Stop_log_event(const char* buf):Log_event(buf)
{ {
...@@ -397,7 +396,7 @@ class Rotate_log_event: public Log_event ...@@ -397,7 +396,7 @@ class Rotate_log_event: public Log_event
alloced(0) alloced(0)
{} {}
Rotate_log_event(FILE* file, time_t when, uint32 server_id) ; Rotate_log_event(IO_CACHE* file, time_t when, uint32 server_id) ;
Rotate_log_event(const char* buf, int max_buf); Rotate_log_event(const char* buf, int max_buf);
~Rotate_log_event() ~Rotate_log_event()
{ {
...@@ -406,7 +405,7 @@ class Rotate_log_event: public Log_event ...@@ -406,7 +405,7 @@ class Rotate_log_event: public Log_event
} }
Log_event_type get_type_code() { return ROTATE_EVENT;} Log_event_type get_type_code() { return ROTATE_EVENT;}
int get_data_size() { return ident_len;} int get_data_size() { return ident_len;}
int write_data(FILE* file); int write_data(IO_CACHE* file);
void print(FILE* file, bool short_form = 0); void print(FILE* file, bool short_form = 0);
}; };
......
...@@ -32,17 +32,19 @@ ...@@ -32,17 +32,19 @@
#define MAP_TO_USE_RAID #define MAP_TO_USE_RAID
#include "mysql_priv.h" #include "mysql_priv.h"
#include <mysys_err.h>
#ifdef HAVE_AIOWAIT #ifdef HAVE_AIOWAIT
#include <mysys_err.h>
#include <errno.h> #include <errno.h>
static void my_aiowait(my_aio_result *result); static void my_aiowait(my_aio_result *result);
#endif #endif
/* if cachesize == 0 then use default cachesize (from s-file) */
/* returns 0 if we have enough memory */
extern "C" { extern "C" {
/*
** if cachesize == 0 then use default cachesize (from s-file)
** if file == -1 then real_open_cached_file() will be called.
** returns 0 if ok
*/
int init_io_cache(IO_CACHE *info, File file, uint cachesize, int init_io_cache(IO_CACHE *info, File file, uint cachesize,
enum cache_type type, my_off_t seek_offset, enum cache_type type, my_off_t seek_offset,
...@@ -60,20 +62,26 @@ int init_io_cache(IO_CACHE *info, File file, uint cachesize, ...@@ -60,20 +62,26 @@ int init_io_cache(IO_CACHE *info, File file, uint cachesize,
min_cache=use_async_io ? IO_SIZE*4 : IO_SIZE*2; min_cache=use_async_io ? IO_SIZE*4 : IO_SIZE*2;
if (type == READ_CACHE) if (type == READ_CACHE)
{ /* Assume file isn't growing */ { /* Assume file isn't growing */
my_off_t file_pos,end_of_file; if (cache_myflags & MY_DONT_CHECK_FILESIZE)
if ((file_pos=my_tell(file,MYF(0)) == MY_FILEPOS_ERROR)) {
DBUG_RETURN(1); cache_myflags &= ~MY_DONT_CHECK_FILESIZE;
end_of_file=my_seek(file,0L,MY_SEEK_END,MYF(0)); }
if (end_of_file < seek_offset) else
end_of_file=seek_offset;
VOID(my_seek(file,file_pos,MY_SEEK_SET,MYF(0)));
if ((my_off_t) cachesize > end_of_file-seek_offset+IO_SIZE*2-1)
{ {
cachesize=(uint) (end_of_file-seek_offset)+IO_SIZE*2-1; my_off_t file_pos,end_of_file;
use_async_io=0; /* No nead to use async */ if ((file_pos=my_tell(file,MYF(0)) == MY_FILEPOS_ERROR))
DBUG_RETURN(1);
end_of_file=my_seek(file,0L,MY_SEEK_END,MYF(0));
if (end_of_file < seek_offset)
end_of_file=seek_offset;
VOID(my_seek(file,file_pos,MY_SEEK_SET,MYF(0)));
if ((my_off_t) cachesize > end_of_file-seek_offset+IO_SIZE*2-1)
{
cachesize=(uint) (end_of_file-seek_offset)+IO_SIZE*2-1;
use_async_io=0; /* No nead to use async */
}
} }
} }
if ((int) type < (int) READ_NET) if ((int) type < (int) READ_NET)
{ {
for (;;) for (;;)
...@@ -167,7 +175,8 @@ my_bool reinit_io_cache(IO_CACHE *info, enum cache_type type, ...@@ -167,7 +175,8 @@ my_bool reinit_io_cache(IO_CACHE *info, enum cache_type type,
DBUG_ENTER("reinit_io_cache"); DBUG_ENTER("reinit_io_cache");
info->seek_not_done= test(info->file >= 0); /* Seek not done */ info->seek_not_done= test(info->file >= 0); /* Seek not done */
if (!clear_cache && seek_offset >= info->pos_in_file && if (! clear_cache &&
seek_offset >= info->pos_in_file &&
seek_offset <= info->pos_in_file + seek_offset <= info->pos_in_file +
(uint) (info->rc_end - info->rc_request_pos)) (uint) (info->rc_end - info->rc_request_pos))
{ /* use current buffer */ { /* use current buffer */
...@@ -231,6 +240,7 @@ int _my_b_read(register IO_CACHE *info, byte *Buffer, uint Count) ...@@ -231,6 +240,7 @@ int _my_b_read(register IO_CACHE *info, byte *Buffer, uint Count)
{ {
uint length,diff_length,left_length; uint length,diff_length,left_length;
my_off_t max_length, pos_in_file; my_off_t max_length, pos_in_file;
memcpy(Buffer,info->rc_pos, memcpy(Buffer,info->rc_pos,
(size_t) (left_length=(uint) (info->rc_end-info->rc_pos))); (size_t) (left_length=(uint) (info->rc_end-info->rc_pos)));
Buffer+=left_length; Buffer+=left_length;
...@@ -607,7 +617,9 @@ int flush_io_cache(IO_CACHE *info) ...@@ -607,7 +617,9 @@ int flush_io_cache(IO_CACHE *info)
length=(uint) (info->rc_pos - info->buffer); length=(uint) (info->rc_pos - info->buffer);
if (info->seek_not_done) if (info->seek_not_done)
{ /* File touched, do seek */ { /* File touched, do seek */
VOID(my_seek(info->file,info->pos_in_file,MY_SEEK_SET,MYF(0))); if (my_seek(info->file,info->pos_in_file,MY_SEEK_SET,MYF(0)) ==
MY_FILEPOS_ERROR)
DBUG_RETURN((info->error= -1));
info->seek_not_done=0; info->seek_not_done=0;
} }
info->rc_pos=info->buffer; info->rc_pos=info->buffer;
...@@ -644,4 +656,4 @@ int end_io_cache(IO_CACHE *info) ...@@ -644,4 +656,4 @@ int end_io_cache(IO_CACHE *info)
DBUG_RETURN(error); DBUG_RETURN(error);
} /* end_io_cache */ } /* end_io_cache */
} } /* extern "C" */
...@@ -55,7 +55,7 @@ static struct option long_options[] = ...@@ -55,7 +55,7 @@ static struct option long_options[] =
{"password", required_argument,0, 'p'}, {"password", required_argument,0, 'p'},
{"position", required_argument,0, 'j'}, {"position", required_argument,0, 'j'},
#ifndef DBUG_OFF #ifndef DBUG_OFF
{"debug", required_argument, 0, '#'} {"debug", optional_argument, 0, '#'}
#endif #endif
}; };
...@@ -151,7 +151,7 @@ static int parse_args(int *argc, char*** argv) ...@@ -151,7 +151,7 @@ static int parse_args(int *argc, char*** argv)
{ {
int c, opt_index = 0; int c, opt_index = 0;
while((c = getopt_long(*argc, *argv, "so:#:h:j:u:p:P:t:?", long_options, while((c = getopt_long(*argc, *argv, "so:#::h:j:u:p:P:t:?", long_options,
&opt_index)) != EOF) &opt_index)) != EOF)
{ {
switch(c) switch(c)
...@@ -310,86 +310,106 @@ Unfortunately, no sweepstakes today, adjusted position to 4\n"); ...@@ -310,86 +310,106 @@ Unfortunately, no sweepstakes today, adjusted position to 4\n");
static void dump_local_log_entries(const char* logname) static void dump_local_log_entries(const char* logname)
{ {
FILE* file; File fd;
int rec_count = 0; IO_CACHE cache,*file= &cache;
int rec_count = 0;
if(logname && logname[0] != '-')
file = my_fopen(logname, O_RDONLY|O_BINARY, MYF(MY_WME)); if (logname && logname[0] != '-')
else {
file = stdin; if ((fd = my_open(logname, O_RDONLY | O_BINARY, MYF(MY_WME))) < 0)
exit(1);
if(!file) if (init_io_cache(file, fd, 0, READ_CACHE, (my_off_t) position, 0,
die("Could not open log file %s", logname); MYF(MY_WME | MY_NABP)))
exit(1);
if(my_fseek(file, position, MY_SEEK_SET, MYF(MY_WME))) }
die("failed on my_fseek()"); else
{
if(!position) if (init_io_cache(file, fileno(stdout), 0, READ_CACHE, (my_off_t) 0,
{ 0, MYF(MY_WME | MY_NABP | MY_DONT_CHECK_FILESIZE)))
char magic[4]; exit(1);
if (my_fread(file, (byte*) magic, sizeof(magic), MYF(MY_NABP|MY_WME))) if (position)
die("I/O error reading binlog magic number"); {
if(memcmp(magic, BINLOG_MAGIC, 4)) /* skip 'position' characters from stdout */
die("Bad magic number"); char buff[IO_SIZE];
my_off_t length,tmp;
for (length=position ; length > 0 ; length-=tmp)
{
tmp=min(length,sizeof(buff));
if (my_b_read(file,buff,tmp))
exit(1);
}
}
file->pos_in_file=position;
file->seek_not_done=0;
}
if (!position)
{
char magic[4];
if (my_b_read(file, (byte*) magic, sizeof(magic)))
die("I/O error reading binlog magic number");
if(memcmp(magic, BINLOG_MAGIC, 4))
die("Bad magic number");
} }
while(1) while(1)
{ {
Log_event* ev = Log_event::read_log_event(file, 0); Log_event* ev = Log_event::read_log_event(file, 0);
if(!ev) if (!ev)
if(!feof(file)) {
if (file->error)
die("Could not read entry at offset %ld : Error in log format or \ die("Could not read entry at offset %ld : Error in log format or \
read error", read error",
my_ftell(file, MYF(MY_WME))); my_b_tell(file));
else break;
break; }
if (rec_count >= offset)
if(rec_count >= offset) ev->print(stdout, short_form);
ev->print(stdout, short_form); rec_count++;
rec_count++; delete ev;
delete ev; }
} my_close(fd, MYF(MY_WME));
end_io_cache(file);
my_fclose(file, MYF(MY_WME));
} }
int main(int argc, char** argv) int main(int argc, char** argv)
{ {
MY_INIT(argv[0]); MY_INIT(argv[0]);
parse_args(&argc, (char***)&argv); parse_args(&argc, (char***)&argv);
if(!argc && !table) if(!argc && !table)
{ {
usage(); usage();
return -1; return -1;
} }
if(use_remote) if(use_remote)
{ {
init_thr_alarm(10); // need to do this manually init_thr_alarm(10); // need to do this manually
mysql = safe_connect(); mysql = safe_connect();
} }
if(table) if (table)
{ {
if(!use_remote) if(!use_remote)
die("You must specify connection parameter to get table dump"); die("You must specify connection parameter to get table dump");
char* db = (char*)table; char* db = (char*)table;
char* tbl = (char*) strchr(table, '.'); char* tbl = (char*) strchr(table, '.');
if(!tbl) if(!tbl)
die("You must use database.table syntax to specify the table"); die("You must use database.table syntax to specify the table");
*tbl++ = 0; *tbl++ = 0;
dump_remote_table(&mysql->net, db, tbl); dump_remote_table(&mysql->net, db, tbl);
} }
else else
while(--argc >= 0) {
while(--argc >= 0)
{ {
dump_log_entries(*(argv++)); dump_log_entries(*(argv++));
} }
}
if(use_remote) if (use_remote)
mc_mysql_close(mysql); mc_mysql_close(mysql);
return 0; return 0;
} }
......
...@@ -319,11 +319,11 @@ bool net_store_data(String* packet, I_List<i_string>* str_list) ...@@ -319,11 +319,11 @@ bool net_store_data(String* packet, I_List<i_string>* str_list)
i_string* s; i_string* s;
while((s=it++)) while((s=it++))
{ {
if(tmp.length()) if(tmp.length())
tmp.append(','); tmp.append(',');
tmp.append(s->ptr); tmp.append(s->ptr);
} }
return net_store_data(packet, (char*)tmp.ptr(), tmp.length()); return net_store_data(packet, (char*)tmp.ptr(), tmp.length());
} }
...@@ -113,11 +113,17 @@ THD::THD() ...@@ -113,11 +113,17 @@ THD::THD()
ull=0; ull=0;
system_thread=0; system_thread=0;
bzero((char*) &mem_root,sizeof(mem_root)); bzero((char*) &mem_root,sizeof(mem_root));
#if defined(HAVE_BDB) || defined(HAVE_INNOBASE) || defined(HAVE_GEMENI)
if (open_cached_file(&transactions.trans_log,
mysql_tempdir,LOG_PREFIX,0,MYF(MY_WME)))
killed=1;
transaction.bdb_lock_count=0;
#endif
transaction.bdb_tid=0;
#ifdef __WIN__ #ifdef __WIN__
real_id = 0 ; real_id = 0 ;
#endif #endif
transaction.bdb_lock_count=0;
transaction.bdb_tid=0;
} }
THD::~THD() THD::~THD()
...@@ -136,6 +142,9 @@ THD::~THD() ...@@ -136,6 +142,9 @@ THD::~THD()
close_thread_tables(this); close_thread_tables(this);
} }
close_temporary_tables(this); close_temporary_tables(this);
#if defined(HAVE_BDB) || defined(HAVE_INNOBASE) || defined(HAVE_GEMENI)
close_cached_file(transactions.trans_log);
#endif
if (global_read_lock) if (global_read_lock)
{ {
pthread_mutex_lock(&LOCK_open); pthread_mutex_lock(&LOCK_open);
......
...@@ -82,16 +82,16 @@ typedef struct st_master_info ...@@ -82,16 +82,16 @@ typedef struct st_master_info
} MASTER_INFO; } MASTER_INFO;
class MYSQL_LOG { class MYSQL_LOG {
public:
private: private:
pthread_mutex_t LOCK_log, LOCK_index; pthread_mutex_t LOCK_log, LOCK_index;
File file, index_file;
time_t last_time,query_start; time_t last_time,query_start;
IO_CACHE log_file;
File index_file;
char *name; char *name;
enum_log_type log_type; volatile enum_log_type log_type;
char time_buff[20],db[NAME_LEN+1]; char time_buff[20],db[NAME_LEN+1];
char log_file_name[FN_REFLEN],index_file_name[FN_REFLEN]; char log_file_name[FN_REFLEN],index_file_name[FN_REFLEN];
bool write_error,inited; bool write_error,inited,opened;
bool no_rotate; // for binlog - if log name can never change bool no_rotate; // for binlog - if log name can never change
// we should not try to rotate it or write any rotation events // we should not try to rotate it or write any rotation events
// the user should use FLUSH MASTER instead of FLUSH LOGS for // the user should use FLUSH MASTER instead of FLUSH LOGS for
...@@ -114,7 +114,7 @@ class MYSQL_LOG { ...@@ -114,7 +114,7 @@ class MYSQL_LOG {
int generate_new_name(char *new_name,const char *old_name); int generate_new_name(char *new_name,const char *old_name);
void make_log_name(char* buf, const char* log_ident); void make_log_name(char* buf, const char* log_ident);
bool is_active(const char* log_file_name); bool is_active(const char* log_file_name);
void flush(void); // void flush(void);
void close(bool exiting = 0); // if we are exiting, we also want to close the void close(bool exiting = 0); // if we are exiting, we also want to close the
// index file // index file
...@@ -270,6 +270,7 @@ class THD :public ilink { ...@@ -270,6 +270,7 @@ class THD :public ilink {
thr_lock_type update_lock_default; thr_lock_type update_lock_default;
delayed_insert *di; delayed_insert *di;
struct st_transactions { struct st_transactions {
IO_CACHE trans_log;
void *bdb_tid; void *bdb_tid;
uint bdb_lock_count; uint bdb_lock_count;
} transaction; } transaction;
......
...@@ -2439,7 +2439,7 @@ bool reload_acl_and_cache(THD *thd, uint options, TABLE_LIST *tables) ...@@ -2439,7 +2439,7 @@ bool reload_acl_and_cache(THD *thd, uint options, TABLE_LIST *tables)
bool result=0; bool result=0;
select_errors=0; /* Write if more errors */ select_errors=0; /* Write if more errors */
mysql_log.flush(); // Flush log // mysql_log.flush(); // Flush log
if (options & REFRESH_GRANT) if (options & REFRESH_GRANT)
{ {
acl_reload(); acl_reload();
......
This diff is collapsed.
...@@ -95,17 +95,6 @@ bool String::realloc(uint32 alloc_length) ...@@ -95,17 +95,6 @@ bool String::realloc(uint32 alloc_length)
return FALSE; return FALSE;
} }
#ifdef NOT_NEEDED
bool String::set(long num)
{
if (alloc(14))
return TRUE;
str_length=(uint32) (int10_to_str(num,Ptr,-10)-Ptr);
return FALSE;
}
#endif
bool String::set(longlong num) bool String::set(longlong num)
{ {
if (alloc(21)) if (alloc(21))
...@@ -274,6 +263,7 @@ bool String::append(const char *s,uint32 arg_length) ...@@ -274,6 +263,7 @@ bool String::append(const char *s,uint32 arg_length)
return FALSE; return FALSE;
} }
#ifdef TO_BE_REMOVED
bool String::append(FILE* file, uint32 arg_length, myf my_flags) bool String::append(FILE* file, uint32 arg_length, myf my_flags)
{ {
if (realloc(str_length+arg_length)) if (realloc(str_length+arg_length))
...@@ -286,6 +276,20 @@ bool String::append(FILE* file, uint32 arg_length, myf my_flags) ...@@ -286,6 +276,20 @@ bool String::append(FILE* file, uint32 arg_length, myf my_flags)
str_length+=arg_length; str_length+=arg_length;
return FALSE; return FALSE;
} }
#endif
bool String::append(IO_CACHE* file, uint32 arg_length)
{
if (realloc(str_length+arg_length))
return TRUE;
if (my_b_read(file, (byte*) Ptr + str_length, arg_length))
{
shrink(str_length);
return TRUE;
}
str_length+=arg_length;
return FALSE;
}
uint32 String::numchars() uint32 String::numchars()
{ {
......
...@@ -152,7 +152,7 @@ class String ...@@ -152,7 +152,7 @@ class String
bool copy(const char *s,uint32 arg_length); // Allocate new string bool copy(const char *s,uint32 arg_length); // Allocate new string
bool append(const String &s); bool append(const String &s);
bool append(const char *s,uint32 arg_length=0); bool append(const char *s,uint32 arg_length=0);
bool append(FILE* file, uint32 arg_length, myf my_flags); bool append(IO_CACHE* file, uint32 arg_length);
int strstr(const String &search,uint32 offset=0); // Returns offset to substring or -1 int strstr(const String &search,uint32 offset=0); // Returns offset to substring or -1
int strrstr(const String &search,uint32 offset=0); // Returns offset to substring or -1 int strrstr(const String &search,uint32 offset=0); // Returns offset to substring or -1
bool replace(uint32 offset,uint32 arg_length,const String &to); bool replace(uint32 offset,uint32 arg_length,const String &to);
......
...@@ -413,16 +413,6 @@ ulong convert_month_to_period(ulong month) ...@@ -413,16 +413,6 @@ ulong convert_month_to_period(ulong month)
return year*100+month%12+1; return year*100+month%12+1;
} }
#ifdef NOT_NEEDED
ulong add_to_period(ulong period,int months)
{
if (period == 0L)
return 0L;
return convert_month_to_period(convert_period_to_month(period)+months);
}
#endif
/***************************************************************************** /*****************************************************************************
** convert a timestamp string to a TIME value. ** convert a timestamp string to a TIME value.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment