26
18
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
28
20
You should have received a copy of the GNU General Public License along with
29
this program; if not, write to the Free Software Foundation, Inc., 51 Franklin
30
St, Fifth Floor, Boston, MA 02110-1301 USA
21
this program; if not, write to the Free Software Foundation, Inc., 59 Temple
22
Place, Suite 330, Boston, MA 02111-1307 USA
32
24
*****************************************************************************/
34
/********************************************************************//**
26
/************************************************************************
36
27
Starts the InnoDB database server
38
29
Created 2/16/1996 Heikki Tuuri
39
30
*************************************************************************/
33
#include "sync0sync.h"
41
34
#include "ut0mem.h"
42
35
#include "mem0mem.h"
43
36
#include "data0data.h"
44
37
#include "data0type.h"
45
38
#include "dict0dict.h"
46
39
#include "buf0buf.h"
47
42
#include "os0file.h"
48
43
#include "os0thread.h"
49
44
#include "fil0fil.h"
50
45
#include "fsp0fsp.h"
51
46
#include "rem0rec.h"
52
48
#include "mtr0mtr.h"
53
49
#include "log0log.h"
54
50
#include "log0recv.h"
55
51
#include "page0page.h"
56
52
#include "page0cur.h"
57
53
#include "trx0trx.h"
54
#include "dict0boot.h"
55
#include "dict0load.h"
58
56
#include "trx0sys.h"
57
#include "dict0crea.h"
59
58
#include "btr0btr.h"
60
60
#include "btr0cur.h"
61
62
#include "rem0rec.h"
66
#include "lock0lock.h"
68
#include "trx0purge.h"
73
#include "row0mysql.h"
74
#include "lock0lock.h"
62
75
#include "ibuf0ibuf.h"
76
#include "pars0pars.h"
63
78
#include "srv0start.h"
65
#ifndef UNIV_HOTBACKUP
67
# include "sync0sync.h"
70
# include "dict0boot.h"
71
# include "dict0load.h"
73
# include "usr0sess.h"
74
# include "lock0lock.h"
75
# include "trx0roll.h"
76
# include "trx0purge.h"
77
# include "lock0lock.h"
78
# include "pars0pars.h"
81
# include "dict0crea.h"
86
# include "row0mysql.h"
87
# include "btr0pcur.h"
89
# include "os0sync.h" /* for INNODB_RW_LOCKS_USE_ATOMICS */
90
# include "zlib.h" /* for ZLIB_VERSION */
95
#include <drizzled/gettext.h>
96
#include <drizzled/errmsg_print.h>
98
/** Log sequence number immediately after startup */
81
/* Log sequence number immediately after startup */
99
82
UNIV_INTERN ib_uint64_t srv_start_lsn;
100
/** Log sequence number at shutdown */
83
/* Log sequence number at shutdown */
101
84
UNIV_INTERN ib_uint64_t srv_shutdown_lsn;
103
86
#ifdef HAVE_DARWIN_THREADS
104
87
# include <sys/utsname.h>
105
/** TRUE if the F_FULLFSYNC option is available */
106
88
UNIV_INTERN ibool srv_have_fullfsync = FALSE;
109
/** TRUE if a raw partition is in use */
110
91
UNIV_INTERN ibool srv_start_raw_disk_in_use = FALSE;
112
/** TRUE if the server is being started, before rolling back any
113
incomplete transactions */
114
93
UNIV_INTERN ibool srv_startup_is_before_trx_rollback_phase = FALSE;
115
/** TRUE if the server is being started */
116
94
UNIV_INTERN ibool srv_is_being_started = FALSE;
117
/** TRUE if the server was successfully started */
118
95
UNIV_INTERN ibool srv_was_started = FALSE;
119
/** TRUE if innobase_start_or_create_for_mysql() has been called */
96
#ifndef UNIV_HOTBACKUP
120
97
static ibool srv_start_has_been_called = FALSE;
122
/** At a shutdown this value climbs from SRV_SHUTDOWN_NONE to
123
SRV_SHUTDOWN_CLEANUP and then to SRV_SHUTDOWN_LAST_PHASE, and so on */
124
UNIV_INTERN enum srv_shutdown_state srv_shutdown_state = SRV_SHUTDOWN_NONE;
126
/** Files comprising the system tablespace */
98
#endif /* !UNIV_HOTBACKUP */
100
/* At a shutdown the value first climbs to SRV_SHUTDOWN_CLEANUP
101
and then to SRV_SHUTDOWN_LAST_PHASE */
102
UNIV_INTERN ulint srv_shutdown_state = 0;
104
#ifndef UNIV_HOTBACKUP
127
105
static os_file_t files[1000];
129
/** io_handler_thread parameters for thread identification */
130
static ulint n[SRV_MAX_N_IO_THREADS + 6];
131
/** io_handler_thread identifiers */
132
static os_thread_id_t thread_ids[SRV_MAX_N_IO_THREADS + 6];
134
/** We use this mutex to test the return value of pthread_mutex_trylock
107
static mutex_t ios_mutex;
110
static ulint n[SRV_MAX_N_IO_THREADS + 5];
111
static os_thread_id_t thread_ids[SRV_MAX_N_IO_THREADS + 5];
113
/* We use this mutex to test the return value of pthread_mutex_trylock
135
114
on successful locking. HP-UX does NOT return 0, though Linux et al do. */
136
115
static os_fast_mutex_t srv_os_test_mutex;
138
/** Name of srv_monitor_file */
117
/* Name of srv_monitor_file */
139
118
static char* srv_monitor_file_name;
140
119
#endif /* !UNIV_HOTBACKUP */
143
121
#define SRV_N_PENDING_IOS_PER_THREAD OS_AIO_N_PENDING_IOS_PER_THREAD
144
122
#define SRV_MAX_N_PENDING_SYNC_IOS 100
146
#ifdef UNIV_PFS_THREAD
147
/* Keys to register InnoDB threads with performance schema */
148
UNIV_INTERN mysql_pfs_key_t io_handler_thread_key;
149
UNIV_INTERN mysql_pfs_key_t srv_lock_timeout_thread_key;
150
UNIV_INTERN mysql_pfs_key_t srv_error_monitor_thread_key;
151
UNIV_INTERN mysql_pfs_key_t srv_monitor_thread_key;
152
UNIV_INTERN mysql_pfs_key_t srv_master_thread_key;
153
#endif /* UNIV_PFS_THREAD */
155
/*********************************************************************//**
156
Convert a numeric string that optionally ends in G or M, to a number
157
containing megabytes.
158
@return next character in string */
161
127
srv_parse_megabytes(
162
128
/*================*/
163
char* str, /*!< in: string containing a quantity in bytes */
164
ulint* megs) /*!< out: the number in megabytes */
129
/* out: next character in string */
130
char* str, /* in: string containing a quantity in bytes */
131
ulint* megs) /* out: the number in megabytes */
492
/*************************************************************************
493
Adds a slash or a backslash to the end of a string if it is missing
494
and the string is not empty. */
497
srv_add_path_separator_if_needed(
498
/*=============================*/
499
/* out: string which has the separator if the
500
string is not empty */
501
char* str) /* in: null-terminated character string */
504
ulint len = ut_strlen(str);
506
if (len == 0 || str[len - 1] == SRV_PATH_SEPARATOR) {
511
out_str = ut_malloc(len + 2);
512
memcpy(out_str, str, len);
513
out_str[len] = SRV_PATH_SEPARATOR;
514
out_str[len + 1] = 0;
528
519
#ifndef UNIV_HOTBACKUP
529
/*********************************************************************//**
520
/*************************************************************************
530
521
Calculates the low 32 bits when a file size which is given as a number
531
database pages is converted to the number of bytes.
532
@return low 32 bytes of file size when expressed in bytes */
522
database pages is converted to the number of bytes. */
537
ulint file_size) /*!< in: file size in database pages */
527
/* out: low 32 bytes of file size when
528
expressed in bytes */
529
ulint file_size) /* in: file size in database pages */
539
531
return(0xFFFFFFFFUL & (file_size << UNIV_PAGE_SIZE_SHIFT));
542
/*********************************************************************//**
534
/*************************************************************************
543
535
Calculates the high 32 bits when a file size which is given as a number
544
database pages is converted to the number of bytes.
545
@return high 32 bytes of file size when expressed in bytes */
536
database pages is converted to the number of bytes. */
550
ulint file_size) /*!< in: file size in database pages */
541
/* out: high 32 bytes of file size when
542
expressed in bytes */
543
ulint file_size) /* in: file size in database pages */
552
545
return(file_size >> (32 - UNIV_PAGE_SIZE_SHIFT));
555
/*********************************************************************//**
556
Creates or opens the log files and closes them.
557
@return DB_SUCCESS or error code */
548
/*************************************************************************
549
Creates or opens the log files and closes them. */
560
552
open_or_create_log_file(
561
553
/*====================*/
562
ibool create_new_db, /*!< in: TRUE if we should create a
554
/* out: DB_SUCCESS or error code */
555
ibool create_new_db, /* in: TRUE if we should create a
564
ibool* log_file_created, /*!< out: TRUE if new log file
557
ibool* log_file_created, /* out: TRUE if new log file
566
ibool log_file_has_been_opened,/*!< in: TRUE if a log file has been
559
ibool log_file_has_been_opened,/* in: TRUE if a log file has been
567
560
opened before: then it is an error
568
561
to try to create another log file */
569
ulint k, /*!< in: log group number */
570
ulint i) /*!< in: log file number in group */
562
ulint k, /* in: log group number */
563
ulint i) /* in: log file number in group */
575
568
char name[10000];
578
570
UT_NOT_USED(create_new_db);
580
572
*log_file_created = FALSE;
582
574
srv_normalize_path_for_win(srv_log_group_home_dirs[k]);
584
dirnamelen = strlen(srv_log_group_home_dirs[k]);
585
ut_a(dirnamelen < (sizeof name) - 10 - sizeof "ib_logfile");
586
memcpy(name, srv_log_group_home_dirs[k], dirnamelen);
588
/* Add a path separator if needed. */
589
if (dirnamelen && name[dirnamelen - 1] != SRV_PATH_SEPARATOR) {
590
name[dirnamelen++] = SRV_PATH_SEPARATOR;
593
sprintf(name + dirnamelen, "%s%lu", "ib_logfile", (ulong) i);
595
files[i] = os_file_create(innodb_file_log_key, name,
596
OS_FILE_CREATE, OS_FILE_NORMAL,
575
srv_log_group_home_dirs[k] = srv_add_path_separator_if_needed(
576
srv_log_group_home_dirs[k]);
578
ut_a(strlen(srv_log_group_home_dirs[k])
579
< (sizeof name) - 10 - sizeof "ib_logfile");
580
sprintf(name, "%s%s%lu", srv_log_group_home_dirs[k],
581
"ib_logfile", (ulong) i);
583
files[i] = os_file_create(name, OS_FILE_CREATE, OS_FILE_NORMAL,
597
584
OS_LOG_FILE, &ret);
598
585
if (ret == FALSE) {
599
586
if (os_file_get_last_error(FALSE) != OS_FILE_ALREADY_EXISTS
604
591
&& os_file_get_last_error(FALSE) != 100
607
drizzled::errmsg_printf(drizzled::error::ERROR,
608
"InnoDB: Error in creating or opening %s", name);
595
"InnoDB: Error in creating"
596
" or opening %s\n", name);
613
files[i] = os_file_create(innodb_file_log_key, name,
614
OS_FILE_OPEN, OS_FILE_AIO,
601
files[i] = os_file_create(name, OS_FILE_OPEN, OS_FILE_AIO,
615
602
OS_LOG_FILE, &ret);
617
drizzled::errmsg_printf(drizzled::error::ERROR,
618
"InnoDB: Error in opening %s.", name);
605
"InnoDB: Error in opening %s\n", name);
620
607
return(DB_ERROR);
626
613
if (size != srv_calc_low32(srv_log_file_size)
627
614
|| size_high != srv_calc_high32(srv_log_file_size)) {
629
drizzled::errmsg_printf(drizzled::error::ERROR,
630
"InnoDB: Error: log file %s is of different size %lu %lu bytes than specified in the .cnf"
631
" file %lu %lu bytes!",
632
name, (ulong) size_high, (ulong) size,
633
(ulong) srv_calc_high32(srv_log_file_size),
634
(ulong) srv_calc_low32(srv_log_file_size));
617
"InnoDB: Error: log file %s is"
618
" of different size %lu %lu bytes\n"
619
"InnoDB: than specified in the .cnf"
620
" file %lu %lu bytes!\n",
621
name, (ulong) size_high, (ulong) size,
622
(ulong) srv_calc_high32(srv_log_file_size),
623
(ulong) srv_calc_low32(srv_log_file_size));
636
625
return(DB_ERROR);
639
628
*log_file_created = TRUE;
641
drizzled::errmsg_printf(drizzled::error::INFO,
642
"InnoDB: Log file %s did not exist: new to be created",
630
ut_print_timestamp(stderr);
633
" InnoDB: Log file %s did not exist:"
634
" new to be created\n",
644
636
if (log_file_has_been_opened) {
646
638
return(DB_ERROR);
649
drizzled::errmsg_printf(drizzled::error::INFO,
650
"InnoDB: Setting log file %s size to %lu MB",
651
name, (ulong) srv_log_file_size
652
>> (20 - UNIV_PAGE_SIZE_SHIFT));
641
fprintf(stderr, "InnoDB: Setting log file %s size to %lu MB\n",
642
name, (ulong) srv_log_file_size
643
>> (20 - UNIV_PAGE_SIZE_SHIFT));
654
drizzled::errmsg_printf(drizzled::error::INFO,
655
"InnoDB: Database physically writes the file full: wait...\n");
646
"InnoDB: Database physically writes the file"
657
649
ret = os_file_set_size(name, files[i],
658
650
srv_calc_low32(srv_log_file_size),
659
651
srv_calc_high32(srv_log_file_size));
661
drizzled::errmsg_printf(drizzled::error::ERROR,
662
"InnoDB: Error in creating %s: probably out of disk space",
654
"InnoDB: Error in creating %s:"
655
" probably out of disk space\n",
665
658
return(DB_ERROR);
705
698
return(DB_SUCCESS);
708
/*********************************************************************//**
709
Creates or opens database data files and closes them.
710
@return DB_SUCCESS or error code */
701
/*************************************************************************
702
Creates or opens database data files and closes them. */
713
705
open_or_create_data_files(
714
706
/*======================*/
715
ibool* create_new_db, /*!< out: TRUE if new database should be
707
/* out: DB_SUCCESS or error code */
708
ibool* create_new_db, /* out: TRUE if new database should be
717
710
#ifdef UNIV_LOG_ARCHIVE
718
ulint* min_arch_log_no,/*!< out: min of archived log
711
ulint* min_arch_log_no,/* out: min of archived log
719
712
numbers in data files */
720
ulint* max_arch_log_no,/*!< out: max of archived log
713
ulint* max_arch_log_no,/* out: max of archived log
721
714
numbers in data files */
722
715
#endif /* UNIV_LOG_ARCHIVE */
723
ib_uint64_t* min_flushed_lsn,/*!< out: min of flushed lsn
724
values in data files */
725
ib_uint64_t* max_flushed_lsn,/*!< out: max of flushed lsn
726
values in data files */
727
ulint* sum_of_new_sizes)/*!< out: sum of sizes of the
716
ib_uint64_t* min_flushed_lsn,/* out: min of flushed lsn
717
values in data files */
718
ib_uint64_t* max_flushed_lsn,/* out: max of flushed lsn
719
values in data files */
720
ulint* sum_of_new_sizes)/* out: sum of sizes of the
728
721
new files added */
748
741
*create_new_db = FALSE;
750
743
srv_normalize_path_for_win(srv_data_home);
744
srv_data_home = srv_add_path_separator_if_needed(srv_data_home);
752
746
for (i = 0; i < srv_n_data_files; i++) {
755
747
srv_normalize_path_for_win(srv_data_file_names[i]);
756
dirnamelen = strlen(srv_data_home);
758
ut_a(dirnamelen + strlen(srv_data_file_names[i])
749
ut_a(strlen(srv_data_home) + strlen(srv_data_file_names[i])
759
750
< (sizeof name) - 1);
760
memcpy(name, srv_data_home, dirnamelen);
761
/* Add a path separator if needed. */
762
if (dirnamelen && name[dirnamelen - 1] != SRV_PATH_SEPARATOR) {
763
name[dirnamelen++] = SRV_PATH_SEPARATOR;
766
strcpy(name + dirnamelen, srv_data_file_names[i]);
751
sprintf(name, "%s%s", srv_data_home, srv_data_file_names[i]);
768
753
if (srv_data_file_is_raw_partition[i] == 0) {
770
755
/* First we try to create the file: if it already
771
756
exists, ret will get value FALSE */
773
files[i] = os_file_create(innodb_file_data_key,
774
name, OS_FILE_CREATE,
758
files[i] = os_file_create(name, OS_FILE_CREATE,
776
760
OS_DATA_FILE, &ret);
819
803
/* We open the data file */
821
805
if (one_created) {
822
drizzled::errmsg_printf(drizzled::error::ERROR,
823
"InnoDB: Error: data files can only be added at the end of a tablespace, but"
824
" data file %s existed beforehand.",
807
"InnoDB: Error: data files can only"
808
" be added at the end\n");
810
"InnoDB: of a tablespace, but"
811
" data file %s existed beforehand.\n",
826
813
return(DB_ERROR);
829
816
if (srv_data_file_is_raw_partition[i] == SRV_OLD_RAW) {
830
817
files[i] = os_file_create(
831
innodb_file_data_key,
832
818
name, OS_FILE_OPEN_RAW,
833
819
OS_FILE_NORMAL, OS_DATA_FILE, &ret);
834
820
} else if (i == 0) {
835
821
files[i] = os_file_create(
836
innodb_file_data_key,
837
822
name, OS_FILE_OPEN_RETRY,
838
823
OS_FILE_NORMAL, OS_DATA_FILE, &ret);
840
825
files[i] = os_file_create(
841
innodb_file_data_key,
842
826
name, OS_FILE_OPEN, OS_FILE_NORMAL,
843
827
OS_DATA_FILE, &ret);
847
drizzled::errmsg_printf(drizzled::error::ERROR,
848
"InnoDB: Error in opening %s", name);
832
"InnoDB: Error in opening %s\n", name);
849
833
os_file_get_last_error(TRUE);
851
835
return(DB_ERROR);
872
856
&& srv_last_file_size_max
873
857
< rounded_size_pages)) {
875
drizzled::errmsg_printf(drizzled::error::ERROR,
876
"InnoDB: Error: auto-extending data file %s is of a different size. "
877
"%lu pages (rounded down to MB) than specified in the .cnf file: "
878
"initial %lu pages, max %lu (relevant if non-zero) pages!",
880
(ulong) rounded_size_pages,
881
(ulong) srv_data_file_sizes[i],
883
srv_last_file_size_max);
860
"InnoDB: Error: auto-extending"
862
" of a different size\n"
863
"InnoDB: %lu pages (rounded"
864
" down to MB) than specified"
865
" in the .cnf file:\n"
866
"InnoDB: initial %lu pages,"
867
" max %lu (relevant if"
868
" non-zero) pages!\n",
870
(ulong) rounded_size_pages,
871
(ulong) srv_data_file_sizes[i],
873
srv_last_file_size_max);
885
875
return(DB_ERROR);
915
908
one_created = TRUE;
918
drizzled::errmsg_printf(drizzled::error::INFO,
919
" InnoDB: Data file %s did not exist: new to be created",
911
ut_print_timestamp(stderr);
913
" InnoDB: Data file %s did not"
914
" exist: new to be created\n",
922
drizzled::errmsg_printf(drizzled::error::INFO,
923
"InnoDB: The first specified data file %s did not exist. A new database to be created!", name);
918
"InnoDB: The first specified"
919
" data file %s did not exist:\n"
920
"InnoDB: a new database"
921
" to be created!\n", name);
924
922
*create_new_db = TRUE;
927
drizzled::errmsg_printf(drizzled::error::INFO,
928
" InnoDB: Setting file %s size to %lu MB",
929
name, (ulong) (srv_data_file_sizes[i]
930
>> (20 - UNIV_PAGE_SIZE_SHIFT)));
925
ut_print_timestamp(stderr);
927
" InnoDB: Setting file %s size to %lu MB\n",
929
(ulong) (srv_data_file_sizes[i]
930
>> (20 - UNIV_PAGE_SIZE_SHIFT)));
932
drizzled::errmsg_printf(drizzled::error::INFO,
933
"InnoDB: Database physically writes the file full: wait...");
933
"InnoDB: Database physically writes the"
934
" file full: wait...\n");
935
936
ret = os_file_set_size(
1003
1009
on Mac OS X 10.3 or later. */
1004
1010
struct utsname utsname;
1005
1011
if (uname(&utsname)) {
1006
fputs(_("InnoDB: cannot determine Mac OS X version!\n"), stderr);
1012
fputs("InnoDB: cannot determine Mac OS X version!\n", stderr);
1008
1014
srv_have_fullfsync = strcmp(utsname.release, "7.") >= 0;
1010
1016
if (!srv_have_fullfsync) {
1011
fputs(_("InnoDB: On Mac OS X, fsync() may be"
1012
" broken on internal drives,\n"
1013
"InnoDB: making transactions unsafe!\n"), stderr);
1017
fputs("InnoDB: On Mac OS X, fsync() may be"
1018
" broken on internal drives,\n"
1019
"InnoDB: making transactions unsafe!\n", stderr);
1015
1021
# endif /* F_FULLFSYNC */
1016
1022
#endif /* HAVE_DARWIN_THREADS */
1018
1024
if (sizeof(ulint) != sizeof(void*)) {
1019
drizzled::errmsg_printf(drizzled::error::WARN,
1020
_("InnoDB: Error: size of InnoDB's ulint is %lu, but size of void* is %lu. "
1021
"The sizes should be the same so that on a 64-bit platform you can. Allocate more than 4 GB of memory."),
1026
"InnoDB: Error: size of InnoDB's ulint is %lu,"
1027
" but size of void* is %lu.\n"
1028
"InnoDB: The sizes should be the same"
1029
" so that on a 64-bit platform you can\n"
1030
"InnoDB: allocate more than 4 GB of memory.",
1022
1031
(ulong)sizeof(ulint), (ulong)sizeof(void*));
1028
1037
innodb_file_per_table) until this function has returned. */
1029
1038
srv_file_per_table = FALSE;
1030
1039
#ifdef UNIV_DEBUG
1031
drizzled::errmsg_printf(drizzled::error::INFO,
1032
_("InnoDB: !!!!!!!! UNIV_DEBUG switched on !!!!!!!!!\n"));
1041
"InnoDB: !!!!!!!! UNIV_DEBUG switched on !!!!!!!!!\n");
1035
1044
#ifdef UNIV_IBUF_DEBUG
1036
drizzled::errmsg_printf(drizzled::error::INFO,
1037
_("InnoDB: !!!!!!!! UNIV_IBUF_DEBUG switched on !!!!!!!!!\n"
1038
# ifdef UNIV_IBUF_COUNT_DEBUG
1039
"InnoDB: !!!!!!!! UNIV_IBUF_COUNT_DEBUG switched on !!!!!!!!!\n"
1040
"InnoDB: Crash recovery will fail with UNIV_IBUF_COUNT_DEBUG\n"
1046
"InnoDB: !!!!!!!! UNIV_IBUF_DEBUG switched on !!!!!!!!!\n"
1047
"InnoDB: Crash recovery will fail with UNIV_IBUF_DEBUG\n");
1045
1050
#ifdef UNIV_SYNC_DEBUG
1046
drizzled::errmsg_printf(drizzled::error::INFO,
1047
_("InnoDB: !!!!!!!! UNIV_SYNC_DEBUG switched on !!!!!!!!!\n"));
1052
"InnoDB: !!!!!!!! UNIV_SYNC_DEBUG switched on !!!!!!!!!\n");
1050
1055
#ifdef UNIV_SEARCH_DEBUG
1051
drizzled::errmsg_printf(drizzled::error::INFO,
1052
_("InnoDB: !!!!!!!! UNIV_SEARCH_DEBUG switched on !!!!!!!!!\n"));
1057
"InnoDB: !!!!!!!! UNIV_SEARCH_DEBUG switched on !!!!!!!!!\n");
1055
#ifdef UNIV_LOG_LSN_DEBUG
1056
drizzled::errmsg_printf(drizzled::error::INFO,
1057
_("InnoDB: !!!!!!!! UNIV_LOG_LSN_DEBUG switched on !!!!!!!!!\n"));
1058
#endif /* UNIV_LOG_LSN_DEBUG */
1059
1060
#ifdef UNIV_MEM_DEBUG
1060
drizzled::errmsg_printf(drizzled::error::INFO,
1061
_("InnoDB: !!!!!!!! UNIV_MEM_DEBUG switched on !!!!!!!!!\n"));
1062
"InnoDB: !!!!!!!! UNIV_MEM_DEBUG switched on !!!!!!!!!\n");
1064
if (UNIV_LIKELY(srv_use_sys_malloc))
1066
drizzled::errmsg_printf(drizzled::error::ERROR, _("InnoDB: The InnoDB memory heap is disabled\n"));
1065
if (UNIV_LIKELY(srv_use_sys_malloc)) {
1067
"InnoDB: The InnoDB memory heap is disabled\n");
1069
fputs("InnoDB: " IB_ATOMICS_STARTUP_MSG
1070
"\nInnoDB: Compressed tables use zlib " ZLIB_VERSION
1071
#ifdef UNIV_ZIP_DEBUG
1073
#endif /* UNIV_ZIP_DEBUG */
1074
#ifdef UNIV_ZIP_COPY
1075
" and extra copying"
1076
#endif /* UNIV_ZIP_COPY */
1070
#ifdef HAVE_GCC_ATOMIC_BUILTINS
1071
#ifdef INNODB_RW_LOCKS_USE_ATOMICS
1073
"InnoDB: Mutexes and rw_locks use GCC atomic builtins.\n");
1074
#else /* INNODB_RW_LOCKS_USE_ATOMICS */
1076
"InnoDB: Mutexes use GCC atomic builtins, rw_locks do not.\n");
1077
#endif /* INNODB_RW_LOCKS_USE_ATOMICS */
1078
#else /* HAVE_GCC_ATOMIC_BUILTINS */
1080
"InnoDB: Neither mutexes nor rw_locks use GCC atomic builtins.\n");
1081
#endif /* HAVE_GCC_ATOMIC_BUILTINS */
1080
1083
/* Since InnoDB does not currently clean up all its internal data
1081
1084
structures in MySQL Embedded Server Library server_end(), we
1097
1105
srv_is_being_started = TRUE;
1098
1106
srv_startup_is_before_trx_rollback_phase = TRUE;
1107
os_aio_use_native_aio = FALSE;
1101
switch (os_get_os_version()) {
1110
if (os_get_os_version() == OS_WIN95
1111
|| os_get_os_version() == OS_WIN31
1112
|| os_get_os_version() == OS_WINNT) {
1105
1114
/* On Win 95, 98, ME, Win32 subsystem for Windows 3.1,
1106
1115
and NT use simulated aio. In NT Windows provides async i/o,
1107
1116
but when run in conjunction with InnoDB Hot Backup, it seemed
1108
1117
to corrupt the data files. */
1110
srv_use_native_aio = FALSE;
1115
/* On 2000 and XP, async IO is available. */
1116
srv_use_native_aio = TRUE;
1120
/* Vista and later have both async IO and condition variables */
1121
srv_use_native_aio = TRUE;
1122
srv_use_native_conditions = TRUE;
1126
#elif defined(LINUX_NATIVE_AIO)
1128
if (srv_use_native_aio) {
1129
drizzled::errmsg_printf(drizzled::error::INFO,
1130
_("InnoDB: Using Linux native AIO"));
1133
/* Currently native AIO is supported only on windows and linux
1134
and that also when the support is compiled in. In all other
1135
cases, we ignore the setting of innodb_use_native_aio. */
1136
srv_use_native_aio = FALSE;
1119
os_aio_use_native_aio = FALSE;
1121
/* On Win 2000 and XP use async i/o */
1122
os_aio_use_native_aio = TRUE;
1140
1125
if (srv_file_flush_method_str == NULL) {
1141
1126
/* These are the default options */
1162
1147
} else if (0 == ut_strcmp(srv_file_flush_method_str, "normal")) {
1163
1148
srv_win_file_flush_method = SRV_WIN_IO_NORMAL;
1164
srv_use_native_aio = FALSE;
1149
os_aio_use_native_aio = FALSE;
1166
1151
} else if (0 == ut_strcmp(srv_file_flush_method_str, "unbuffered")) {
1167
1152
srv_win_file_flush_method = SRV_WIN_IO_UNBUFFERED;
1168
srv_use_native_aio = FALSE;
1153
os_aio_use_native_aio = FALSE;
1170
1155
} else if (0 == ut_strcmp(srv_file_flush_method_str,
1171
1156
"async_unbuffered")) {
1172
1157
srv_win_file_flush_method = SRV_WIN_IO_UNBUFFERED;
1175
drizzled::errmsg_printf(drizzled::error::ERROR,
1176
"InnoDB: Unrecognized value %s for innodb_flush_method",
1177
srv_file_flush_method_str);
1161
"InnoDB: Unrecognized value %s for"
1162
" innodb_flush_method\n",
1163
srv_file_flush_method_str);
1178
1164
return(DB_ERROR);
1186
1172
maximum number of threads that can wait in the 'srv_conc array' for
1187
1173
their time to enter InnoDB. */
1175
#if defined(__NETWARE__)
1177
/* Create less event semaphores because Win 98/ME had
1178
difficulty creating 40000 event semaphores. Comment from
1179
Novell, Inc.: also, these just take a lot of memory on
1181
srv_max_n_threads = 1000;
1189
1183
if (srv_buf_pool_size >= 1000 * 1024 * 1024) {
1190
1184
/* If buffer pool is less than 1000 MB,
1191
assume fewer threads. Also use only one
1192
buffer pool instance */
1185
assume fewer threads. */
1193
1186
srv_max_n_threads = 50000;
1195
1188
} else if (srv_buf_pool_size >= 8 * 1024 * 1024) {
1197
srv_buf_pool_instances = 1;
1198
1190
srv_max_n_threads = 10000;
1200
srv_buf_pool_instances = 1;
1201
1192
srv_max_n_threads = 1000; /* saves several MB of memory,
1202
1193
especially in 64-bit
1206
1197
err = srv_boot();
1208
1199
if (err != DB_SUCCESS) {
1210
1201
return((int) err);
1213
mutex_create(srv_monitor_file_mutex_key,
1214
&srv_monitor_file_mutex, SYNC_NO_ORDER_CHECK);
1204
mutex_create(&srv_monitor_file_mutex, SYNC_NO_ORDER_CHECK);
1216
1206
if (srv_innodb_status) {
1217
srv_monitor_file_name = static_cast<char *>(mem_alloc(
1207
srv_monitor_file_name = mem_alloc(
1218
1208
strlen(fil_path_to_mysql_datadir)
1219
+ 20 + sizeof "/innodb_status."));
1209
+ 20 + sizeof "/innodb_status.");
1220
1210
sprintf(srv_monitor_file_name, "%s/innodb_status.%lu",
1221
1211
fil_path_to_mysql_datadir, os_proc_get_number());
1222
1212
srv_monitor_file = fopen(srv_monitor_file_name, "w+");
1223
1213
if (!srv_monitor_file) {
1224
drizzled::errmsg_printf(drizzled::error::ERROR,
1225
"InnoDB: unable to create %s: %s\n", srv_monitor_file_name, strerror(errno));
1214
fprintf(stderr, "InnoDB: unable to create %s: %s\n",
1215
srv_monitor_file_name, strerror(errno));
1226
1216
return(DB_ERROR);
1236
mutex_create(srv_dict_tmpfile_mutex_key,
1237
&srv_dict_tmpfile_mutex, SYNC_DICT_OPERATION);
1226
mutex_create(&srv_dict_tmpfile_mutex, SYNC_DICT_OPERATION);
1239
1228
srv_dict_tmpfile = os_file_create_tmpfile();
1240
1229
if (!srv_dict_tmpfile) {
1241
1230
return(DB_ERROR);
1244
mutex_create(srv_misc_tmpfile_mutex_key,
1245
&srv_misc_tmpfile_mutex, SYNC_ANY_LATCH);
1233
mutex_create(&srv_misc_tmpfile_mutex, SYNC_ANY_LATCH);
1247
1235
srv_misc_tmpfile = os_file_create_tmpfile();
1248
1236
if (!srv_misc_tmpfile) {
1249
1237
return(DB_ERROR);
1252
/* innodb_file_io_threads used to be user settable.
1253
It is now just a combination of read_io_threads and
1254
write_io_threads that is set by innodb internally. */
1256
/* Now overwrite the value on srv_n_file_io_threads */
1257
srv_n_file_io_threads = 2 + srv_n_read_io_threads
1258
+ srv_n_write_io_threads;
1260
ut_a(srv_n_file_io_threads <= SRV_MAX_N_IO_THREADS);
1262
/* TODO: Investigate if SRV_N_PENDING_IOS_PER_THREAD (32) limit
1263
still applies to windows. */
1264
if (!srv_use_native_aio) {
1265
io_limit = 8 * SRV_N_PENDING_IOS_PER_THREAD;
1267
io_limit = SRV_N_PENDING_IOS_PER_THREAD;
1270
os_aio_init(io_limit,
1271
srv_n_read_io_threads,
1272
srv_n_write_io_threads,
1273
SRV_MAX_N_PENDING_SYNC_IOS);
1275
fil_init(srv_file_per_table ? 50000 : 5000,
1276
srv_max_n_open_files);
1278
/* Print time to initialize the buffer pool */
1280
if (srv_buf_pool_size >= 1024 * 1024 * 1024) {
1281
drizzled::errmsg_printf(drizzled::error::INFO, "InnoDB: Initializing buffer pool, size = %.1fG",
1282
((double) srv_buf_pool_size) / (1024 * 1024 * 1024));
1284
drizzled::errmsg_printf(drizzled::error::INFO, "InnoDB: Initializing buffer pool, size = %.1fM",
1285
((double) srv_buf_pool_size) / (1024 * 1024));
1288
err = buf_pool_init(srv_buf_pool_size, srv_buf_pool_instances);
1290
drizzled::errmsg_printf(drizzled::error::INFO, "InnoDB: Completed initialization of buffer pool");
1292
if (err != DB_SUCCESS) {
1293
drizzled::errmsg_printf(drizzled::error::ERROR, "InnoDB: Fatal error: cannot allocate the memory for the buffer pool");
1240
/* Restrict the maximum number of file i/o threads */
1241
if (srv_n_file_io_threads > SRV_MAX_N_IO_THREADS) {
1243
srv_n_file_io_threads = SRV_MAX_N_IO_THREADS;
1246
if (!os_aio_use_native_aio) {
1247
/* In simulated aio we currently have use only for 4 threads */
1248
srv_n_file_io_threads = 4;
1250
os_aio_init(8 * SRV_N_PENDING_IOS_PER_THREAD
1251
* srv_n_file_io_threads,
1252
srv_n_file_io_threads,
1253
SRV_MAX_N_PENDING_SYNC_IOS);
1255
os_aio_init(SRV_N_PENDING_IOS_PER_THREAD
1256
* srv_n_file_io_threads,
1257
srv_n_file_io_threads,
1258
SRV_MAX_N_PENDING_SYNC_IOS);
1261
fil_init(srv_max_n_open_files);
1263
ret = buf_pool_init();
1267
"InnoDB: Fatal error: cannot allocate the memory"
1268
" for the buffer pool\n");
1298
1273
#ifdef UNIV_DEBUG
1365
1347
&min_flushed_lsn, &max_flushed_lsn,
1366
1348
&sum_of_new_sizes);
1367
1349
if (err != DB_SUCCESS) {
1368
drizzled::errmsg_printf(drizzled::error::ERROR,
1369
"InnoDB: Could not open or create data files.\n"
1370
"InnoDB: If you tried to add new data files, and it failed here,\n"
1371
"InnoDB: you should now edit innodb_data_file_path in my.cnf back\n"
1372
"InnoDB: to what it was, and remove the new ibdata files InnoDB created\n"
1373
"InnoDB: in this failed attempt. InnoDB only wrote those files full of\n"
1374
"InnoDB: zeros, but did not yet use them in any way. But be careful: do not\n"
1375
"InnoDB: remove old data files which contain your precious data!\n");
1351
"InnoDB: Could not open or create data files.\n"
1352
"InnoDB: If you tried to add new data files,"
1353
" and it failed here,\n"
1354
"InnoDB: you should now edit innodb_data_file_path"
1356
"InnoDB: to what it was, and remove the"
1357
" new ibdata files InnoDB created\n"
1358
"InnoDB: in this failed attempt. InnoDB only wrote"
1359
" those files full of\n"
1360
"InnoDB: zeros, but did not yet use them in any way."
1361
" But be careful: do not\n"
1362
"InnoDB: remove old data files"
1363
" which contain your precious data!\n");
1377
1365
return((int) err);
1398
1386
if ((log_opened && create_new_db)
1399
1387
|| (log_opened && log_created)) {
1400
drizzled::errmsg_printf(drizzled::error::ERROR,
1401
"InnoDB: Error: all log files must be created at the same time.\n"
1402
"InnoDB: All log files must be created also in database creation.\n"
1403
"InnoDB: If you want bigger or smaller log files, shut down the\n"
1404
"InnoDB: database and make sure there were no errors in shutdown.\n"
1405
"InnoDB: Then delete the existing log files. Edit the .cnf file\n"
1389
"InnoDB: Error: all log files must be"
1390
" created at the same time.\n"
1391
"InnoDB: All log files must be"
1392
" created also in database creation.\n"
1393
"InnoDB: If you want bigger or smaller"
1394
" log files, shut down the\n"
1395
"InnoDB: database and make sure there"
1396
" were no errors in shutdown.\n"
1397
"InnoDB: Then delete the existing log files."
1398
" Edit the .cnf file\n"
1406
1399
"InnoDB: and start the database again.\n");
1408
1401
return(DB_ERROR);
1424
1417
|| max_arch_log_no != min_arch_log_no
1425
1418
#endif /* UNIV_LOG_ARCHIVE */
1427
drizzled::errmsg_printf(drizzled::error::ERROR,
1428
"InnoDB: Cannot initialize created log files because\n"
1429
"InnoDB: data files were not in sync with each other\n"
1421
"InnoDB: Cannot initialize created"
1422
" log files because\n"
1423
"InnoDB: data files were not in sync"
1424
" with each other\n"
1430
1425
"InnoDB: or the data files are corrupt.\n");
1432
1427
return(DB_ERROR);
1435
1430
if (max_flushed_lsn < (ib_uint64_t) 1000) {
1436
drizzled::errmsg_printf(drizzled::error::ERROR,
1437
"InnoDB: Cannot initialize created log files because\n"
1438
"InnoDB: data files are corrupt, or new data files were\n"
1439
"InnoDB: created when the database was started previous\n"
1440
"InnoDB: time but the database was not shut down\n"
1441
"InnoDB: normally after that.\n");
1432
"InnoDB: Cannot initialize created"
1433
" log files because\n"
1434
"InnoDB: data files are corrupt,"
1435
" or new data files were\n"
1436
"InnoDB: created when the database"
1437
" was started previous\n"
1438
"InnoDB: time but the database"
1439
" was not shut down\n"
1440
"InnoDB: normally after that.\n");
1443
1442
return(DB_ERROR);
1461
1460
if (create_new_db) {
1462
1461
mtr_start(&mtr);
1464
1462
fsp_header_init(0, sum_of_new_sizes, &mtr);
1466
1464
mtr_commit(&mtr);
1468
/* To maintain backward compatibility we create only
1469
the first rollback segment before the double write buffer.
1470
All the remaining rollback segments will be created later,
1471
after the double write buffer has been created. */
1472
1466
trx_sys_create();
1476
1468
srv_startup_is_before_trx_rollback_phase = FALSE;
1478
1470
#ifdef UNIV_LOG_ARCHIVE
1479
1471
} else if (srv_archive_recovery) {
1480
drizzled::errmsg_printf(drizzled::error::INFO,
1481
"InnoDB: Starting archive recovery from a backup...");
1473
"InnoDB: Starting archive"
1474
" recovery from a backup...\n");
1482
1475
err = recv_recovery_from_archive_start(
1483
1476
min_flushed_lsn, srv_archive_recovery_limit_lsn,
1484
1477
min_arch_log_no);
1573
1556
every table in the InnoDB data dictionary that has
1576
We also determine the maximum tablespace id used. */
1559
We also determine the maximum tablespace id used.
1561
TODO: We may have incomplete transactions in the
1562
data dictionary tables. Does that harm the scanning of
1563
the data dictionary below? */
1578
1565
dict_check_tablespaces_and_store_max_id(
1579
1566
recv_needed_recovery);
1582
1569
srv_startup_is_before_trx_rollback_phase = FALSE;
1583
recv_recovery_rollback_active();
1571
/* Initialize the fsp free limit global variable in the log
1573
fsp_header_get_free_limit();
1575
/* recv_recovery_from_checkpoint_finish needs trx lists which
1576
are initialized in trx_sys_init_at_db_start(). */
1578
recv_recovery_from_checkpoint_finish();
1585
1580
/* It is possible that file_format tag has never
1586
1581
been set. In this case we initialize it to minimum
1629
1624
/* fprintf(stderr, "Max allowed record size %lu\n",
1630
1625
page_get_free_space_of_empty() / 2); */
1632
if (trx_doublewrite == NULL) {
1633
/* Create the doublewrite buffer to a new tablespace */
1635
trx_sys_create_doublewrite_buf();
1638
/* Here the double write buffer has already been created and so
1639
any new rollback segments will be allocated after the double
1640
write buffer. The default segment should already exist.
1641
We create the new segments only if it's a new database or
1642
the database was shutdown cleanly. */
1644
/* Note: When creating the extra rollback segments during an upgrade
1645
we violate the latching order, even if the change buffer is empty.
1646
We make an exception in sync0sync.c and check srv_is_being_started
1647
for that violation. It cannot create a deadlock because we are still
1648
running in single threaded mode essentially. Only the IO threads
1649
should be running at this stage. */
1651
trx_sys_create_rsegs(TRX_SYS_N_RSEGS - 1);
1653
/* Create the thread which watches the timeouts for lock waits */
1654
os_thread_create(&srv_lock_timeout_thread, NULL,
1627
/* Create the thread which watches the timeouts for lock waits
1628
and prints InnoDB monitor info */
1630
os_thread_create(&srv_lock_timeout_and_monitor_thread, NULL,
1655
1631
thread_ids + 2 + SRV_MAX_N_IO_THREADS);
1657
1633
/* Create the thread which warns of long semaphore waits */
1658
1634
os_thread_create(&srv_error_monitor_thread, NULL,
1659
1635
thread_ids + 3 + SRV_MAX_N_IO_THREADS);
1661
/* Create the thread which prints InnoDB monitor info */
1662
os_thread_create(&srv_monitor_thread, NULL,
1663
thread_ids + 4 + SRV_MAX_N_IO_THREADS);
1665
1636
srv_is_being_started = FALSE;
1638
if (trx_doublewrite == NULL) {
1639
/* Create the doublewrite buffer to a new tablespace */
1641
trx_sys_create_doublewrite_buf();
1667
1644
err = dict_create_or_check_foreign_constraint_tables();
1669
1646
if (err != DB_SUCCESS) {
1699
1666
if (!srv_auto_extend_last_data_file
1700
1667
&& sum_of_data_file_sizes != tablespace_size_in_header) {
1702
drizzled::errmsg_printf(drizzled::error::ERROR,
1703
"InnoDB: Error: tablespace size stored in header is %lu pages, but the sum of data file sizes is %lu pages.",
1704
(ulong) tablespace_size_in_header,
1705
(ulong) sum_of_data_file_sizes);
1670
"InnoDB: Error: tablespace size"
1671
" stored in header is %lu pages, but\n"
1672
"InnoDB: the sum of data file sizes is %lu pages\n",
1673
(ulong) tablespace_size_in_header,
1674
(ulong) sum_of_data_file_sizes);
1707
1676
if (srv_force_recovery == 0
1708
1677
&& sum_of_data_file_sizes < tablespace_size_in_header) {
1709
1678
/* This is a fatal error, the tail of a tablespace is
1712
drizzled::errmsg_printf(drizzled::error::ERROR,
1713
"InnoDB: Cannot start InnoDB. The tail of the system tablespace is "
1714
"missing. Have you edited innodb_data_file_path in my.cnf in an "
1715
"inappropriate way, removing ibdata files from there? "
1716
"You can set innodb_force_recovery=1 in my.cnf to force "
1717
"a startup if you are trying to recover a badly corrupt database.");
1682
"InnoDB: Cannot start InnoDB."
1683
" The tail of the system tablespace is\n"
1684
"InnoDB: missing. Have you edited"
1685
" innodb_data_file_path in my.cnf in an\n"
1686
"InnoDB: inappropriate way, removing"
1687
" ibdata files from there?\n"
1688
"InnoDB: You can set innodb_force_recovery=1"
1689
" in my.cnf to force\n"
1690
"InnoDB: a startup if you are trying"
1691
" to recover a badly corrupt database.\n");
1719
1693
return(DB_ERROR);
1723
1697
if (srv_auto_extend_last_data_file
1724
1698
&& sum_of_data_file_sizes < tablespace_size_in_header) {
1726
drizzled::errmsg_printf(drizzled::error::ERROR,
1727
"InnoDB: Error: tablespace size stored in header is %lu pages, but the sum of data file sizes"
1728
" is only %lu pages\n",
1729
(ulong) tablespace_size_in_header,
1730
(ulong) sum_of_data_file_sizes);
1701
"InnoDB: Error: tablespace size stored in header"
1702
" is %lu pages, but\n"
1703
"InnoDB: the sum of data file sizes"
1704
" is only %lu pages\n",
1705
(ulong) tablespace_size_in_header,
1706
(ulong) sum_of_data_file_sizes);
1732
1708
if (srv_force_recovery == 0) {
1734
drizzled::errmsg_printf(drizzled::error::ERROR,
1735
"InnoDB: Cannot start InnoDB. The tail of the system tablespace is "
1736
"missing. Have you edited innodb_data_file_path in my.cnf in an "
1737
"inappropriate way, removing ibdata files from there? "
1738
"You can set innodb_force_recovery=1 in my.cnf to force "
1739
"a startup if you are trying to recover a badly corrupt database.\n");
1711
"InnoDB: Cannot start InnoDB. The tail of"
1712
" the system tablespace is\n"
1713
"InnoDB: missing. Have you edited"
1714
" innodb_data_file_path in my.cnf in an\n"
1715
"InnoDB: inappropriate way, removing"
1716
" ibdata files from there?\n"
1717
"InnoDB: You can set innodb_force_recovery=1"
1718
" in my.cnf to force\n"
1719
"InnoDB: a startup if you are trying to"
1720
" recover a badly corrupt database.\n");
1741
1722
return(DB_ERROR);
1760
1743
os_fast_mutex_free(&srv_os_test_mutex);
1762
1745
if (srv_print_verbose_log) {
1763
drizzled::errmsg_printf(drizzled::error::ERROR,
1764
"InnoDB %s started; log sequence number %"PRIu64"\n",
1765
INNODB_VERSION_STR, srv_start_lsn);
1746
ut_print_timestamp(stderr);
1748
" InnoDB Plugin %s started; "
1749
"log sequence number %"PRIu64"\n",
1750
INNODB_VERSION_STR, srv_start_lsn);
1768
1753
if (srv_force_recovery > 0) {
1769
drizzled::errmsg_printf(drizzled::error::ERROR,
1770
"InnoDB: !!! innodb_force_recovery is set to %lu !!!\n",
1771
(ulong) srv_force_recovery);
1755
"InnoDB: !!! innodb_force_recovery"
1756
" is set to %lu !!!\n",
1757
(ulong) srv_force_recovery);
1774
1762
if (trx_doublewrite_must_reset_space_ids) {
1775
1763
/* Actually, we did not change the undo log format between
1776
1764
4.0 and 4.1.1, and we would not need to run purge to
1802
drizzled::errmsg_printf(drizzled::error::INFO,
1803
"InnoDB: Full purge and insert buffer merge completed.");
1794
"InnoDB: Full purge and insert buffer merge"
1805
1797
trx_sys_mark_upgraded_to_multiple_tablespaces();
1807
drizzled::errmsg_printf(drizzled::error::INFO,
1808
"InnoDB: You have now successfully upgraded"
1809
" to the multiple tablespaces\n"
1810
"InnoDB: format. You should NOT DOWNGRADE"
1811
" to an earlier version of\n"
1812
"InnoDB: InnoDB! But if you absolutely need to"
1814
"InnoDB: " REFMAN "multiple-tablespaces.html\n"
1815
"InnoDB: for instructions.\n");
1800
"InnoDB: You have now successfully upgraded"
1801
" to the multiple tablespaces\n"
1802
"InnoDB: format. You should NOT DOWNGRADE"
1803
" to an earlier version of\n"
1804
"InnoDB: InnoDB! But if you absolutely need to"
1806
"InnoDB: http://dev.mysql.com/doc/refman/5.1/en/"
1807
"multiple-tablespaces.html\n"
1808
"InnoDB: for instructions.\n");
1818
1811
if (srv_force_recovery == 0) {
1831
1824
return((int) DB_SUCCESS);
1834
/****************************************************************//**
1835
Shuts down the InnoDB database.
1836
@return DB_SUCCESS or error code */
1827
/********************************************************************
1828
Shuts down the InnoDB database. */
1839
1831
innobase_shutdown_for_mysql(void)
1840
1832
/*=============================*/
1833
/* out: DB_SUCCESS or error code */
1837
extern ibool panic_shutdown;
1843
1839
if (!srv_was_started) {
1844
1840
if (srv_is_being_started) {
1845
drizzled::errmsg_printf(drizzled::error::ERROR,
1846
"InnoDB: Warning: shutting down a not properly started or created database!");
1841
ut_print_timestamp(stderr);
1843
" InnoDB: Warning: shutting down"
1844
" a not properly started\n"
1845
"InnoDB: or created database!\n");
1849
1848
return(DB_SUCCESS);
1858
1857
if (srv_fast_shutdown == 2) {
1859
drizzled::errmsg_printf(drizzled::error::INFO,
1860
"InnoDB: MySQL has requested a very fast shutdown without flushing "
1861
"the InnoDB buffer pool to data files. At the next mysqld startup "
1862
"InnoDB will do a crash recovery!");
1858
ut_print_timestamp(stderr);
1860
" InnoDB: MySQL has requested a very fast shutdown"
1861
" without flushing "
1862
"the InnoDB buffer pool to data files."
1863
" At the next mysqld startup "
1864
"InnoDB will do a crash recovery!\n");
1865
logs_empty_and_mark_files_at_shutdown();
1870
logs_empty_and_mark_files_at_shutdown();
1867
1872
if (srv_conc_n_threads != 0) {
1868
drizzled::errmsg_printf(drizzled::error::WARN,
1869
"InnoDB: Warning: query counter shows %ld queries still InnoDB: inside InnoDB at shutdown.",
1870
srv_conc_n_threads);
1874
"InnoDB: Warning: query counter shows %ld queries"
1876
"InnoDB: inside InnoDB at shutdown\n",
1877
srv_conc_n_threads);
1873
1880
/* 2. Make all threads created by InnoDB to exit */
1953
1956
srv_misc_tmpfile = 0;
1956
/* This must be disabled before closing the buffer pool
1957
and closing the data dictionary. */
1958
btr_search_disable();
1964
1959
trx_sys_file_format_close();
1967
1961
mutex_free(&srv_monitor_file_mutex);
1968
1962
mutex_free(&srv_dict_tmpfile_mutex);
1969
1963
mutex_free(&srv_misc_tmpfile_mutex);
1971
btr_search_sys_free();
1973
1965
/* 3. Free all InnoDB's own mutexes and the os_fast_mutexes inside
1969
/* 4. Free the os_conc_mutex and all os_events and os_mutexes */
1980
/* 4. Free the os_conc_mutex and all os_events and os_mutexes */
1982
1972
os_sync_free();
1984
/* 5. Free all allocated memory */
1988
buf_pool_free(srv_buf_pool_instances);
1991
/* ut_free_all_mem() frees all allocated memory not freed yet
1992
in shutdown, and it will also free the ut_list_mutex, so it
1993
should be the last one for all operation */
1974
/* Check that all read views are closed except read view owned
1977
if (UT_LIST_GET_LEN(trx_sys->view_list) > 1) {
1979
"InnoDB: Error: all read views were not closed"
1980
" before shutdown:\n"
1981
"InnoDB: %lu read views open \n",
1982
UT_LIST_GET_LEN(trx_sys->view_list) - 1);
1985
/* 5. Free all allocated memory and the os_fast_mutex created in
1994
1989
ut_free_all_mem();
1996
1991
if (os_thread_count != 0
1997
1992
|| os_event_count != 0
1998
1993
|| os_mutex_count != 0
1999
1994
|| os_fast_mutex_count != 0) {
2000
drizzled::errmsg_printf(drizzled::error::WARN,
2001
"InnoDB: Warning: some resources were not cleaned up in shutdown:\n"
2002
"InnoDB: threads %lu, events %lu, os_mutexes %lu, os_fast_mutexes %lu\n",
2003
(ulong) os_thread_count, (ulong) os_event_count,
2004
(ulong) os_mutex_count, (ulong) os_fast_mutex_count);
1996
"InnoDB: Warning: some resources were not"
1997
" cleaned up in shutdown:\n"
1998
"InnoDB: threads %lu, events %lu,"
1999
" os_mutexes %lu, os_fast_mutexes %lu\n",
2000
(ulong) os_thread_count, (ulong) os_event_count,
2001
(ulong) os_mutex_count, (ulong) os_fast_mutex_count);
2007
2004
if (dict_foreign_err_file) {