40
40
#include "hexdump_transaction_message.h"
41
41
#include "background_worker.h"
43
45
#include <drizzled/plugin/plugin.h>
44
46
#include <drizzled/session.h>
45
#include <drizzled/set_var.h>
46
47
#include <drizzled/gettext.h>
48
#include <boost/program_options.hpp>
49
#include <drizzled/module/option_map.h>
51
namespace po= boost::program_options;
48
52
using namespace std;
49
53
using namespace drizzled;
56
* The name of the main transaction log file on disk. With no prefix,
57
* this goes into Drizzle's $datadir.
59
static const char DEFAULT_LOG_FILE_PATH[]= "transaction.log"; /* In datadir... */
52
61
* Transaction Log plugin system variable - Is the log enabled? Only used on init().
53
* The enable() and disable() methods of the TransactionLog class control online
56
63
static bool sysvar_transaction_log_enabled= false;
57
65
/** Transaction Log plugin system variable - The path to the log file used */
58
static char* sysvar_transaction_log_file= NULL;
66
static string sysvar_transaction_log_file;
60
69
* Transaction Log plugin system variable - A debugging variable to assist
61
70
* in truncating the log file.
63
72
static bool sysvar_transaction_log_truncate_debug= false;
64
static const char DEFAULT_LOG_FILE_PATH[]= "transaction.log"; /* In datadir... */
66
74
* Transaction Log plugin system variable - Should we write a CRC32 checksum for
67
75
* each written Transaction message?
71
79
* Numeric option controlling the sync/flush behaviour of the transaction
72
80
* log. Options are:
74
* TransactionLog::SYNC_METHOD_OS == 0 ... let OS do sync'ing
75
* TransactionLog::SYNC_METHOD_EVERY_WRITE == 1 ... sync on every write
76
* TransactionLog::SYNC_METHOD_EVERY_SECOND == 2 ... sync at most once a second
78
static uint32_t sysvar_transaction_log_sync_method= 0;
82
* TransactionLog::FLUSH_FREQUENCY_OS == 0 ... let OS do sync'ing
83
* TransactionLog::FLUSH_FREQUENCY_EVERY_WRITE == 1 ... sync on every write
84
* TransactionLog::FLUSH_FREQUENCY_EVERY_SECOND == 2 ... sync at most once a second
86
typedef constrained_check<int, 2, 0> flush_constraint;
87
static flush_constraint sysvar_transaction_log_flush_frequency;
89
* Transaction Log plugin system variable - Number of slots to create
90
* for managing write buffers
92
typedef constrained_check<uint32_t, 8192, 4> write_buffers_constraint;
93
static write_buffers_constraint sysvar_transaction_log_num_write_buffers;
95
* Transaction Log plugin system variable - The name of the replicator plugin
96
* to pair the transaction log's applier with. Defaults to "default"
98
static const char DEFAULT_USE_REPLICATOR[]= "default";
99
static string sysvar_transaction_log_use_replicator;
80
101
/** DATA_DICTIONARY views */
81
102
static TransactionLogTool *transaction_log_tool;
93
114
extern plugin::Create_function<PrintTransactionMessageFunction> *print_transaction_message_func_factory;
94
115
extern plugin::Create_function<HexdumpTransactionMessageFunction> *hexdump_transaction_message_func_factory;
96
static int init(drizzled::plugin::Context &context)
117
TransactionLog::~TransactionLog()
119
/* Clear up any resources we've consumed */
122
(void) close(log_file);
126
static void set_truncate_debug(Session *, sql_var_t)
130
if (sysvar_transaction_log_truncate_debug)
132
transaction_log->truncate();
133
transaction_log_index->clear();
134
sysvar_transaction_log_truncate_debug= false;
139
static int init(drizzled::module::Context &context)
141
context.registerVariable(new sys_var_bool_ptr_readonly("enable",
142
&sysvar_transaction_log_enabled));
143
context.registerVariable(new sys_var_bool_ptr("truncate-debug",
144
&sysvar_transaction_log_truncate_debug,
145
set_truncate_debug));
147
context.registerVariable(new sys_var_const_string("file",
148
sysvar_transaction_log_file));
149
context.registerVariable(new sys_var_const_string("use-replicator",
150
sysvar_transaction_log_use_replicator));
151
context.registerVariable(new sys_var_bool_ptr_readonly("enable-checksum",
152
&sysvar_transaction_log_checksum_enabled));
153
context.registerVariable(new sys_var_constrained_value_readonly<int>("flush-frequency", sysvar_transaction_log_flush_frequency));
155
context.registerVariable(new sys_var_constrained_value_readonly<uint32_t>("num-write-buffers",
156
sysvar_transaction_log_num_write_buffers));
98
159
/* Create and initialize the transaction log itself */
99
160
if (sysvar_transaction_log_enabled)
101
transaction_log= new (nothrow) TransactionLog(string(sysvar_transaction_log_file),
102
sysvar_transaction_log_sync_method);
163
transaction_log= new (nothrow) TransactionLog(sysvar_transaction_log_file,
164
static_cast<int>(sysvar_transaction_log_flush_frequency),
165
sysvar_transaction_log_checksum_enabled);
104
167
if (transaction_log == NULL)
169
char errmsg[STRERROR_MAX];
170
strerror_r(errno, errmsg, sizeof(errmsg));
106
171
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to allocate the TransactionLog instance. Got error: %s\n"),
186
/* Create and initialize the transaction log index */
187
transaction_log_index= new (nothrow) TransactionLogIndex(*transaction_log);
188
if (transaction_log_index == NULL)
190
char errmsg[STRERROR_MAX];
191
strerror_r(errno, errmsg, sizeof(errmsg));
192
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to allocate the TransactionLogIndex instance. Got error: %s\n"),
198
/* Check to see if the index was not created properly */
199
if (transaction_log_index->hasError())
201
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to initialize the Transaction Log Index. Got error: %s\n"),
202
transaction_log_index->getErrorMessage().c_str());
120
207
/* Create the applier plugin and register it */
121
208
transaction_log_applier= new (nothrow) TransactionLogApplier("transaction_log_applier",
123
sysvar_transaction_log_checksum_enabled);
210
transaction_log_index,
211
static_cast<uint32_t>(sysvar_transaction_log_num_write_buffers));
124
212
if (transaction_log_applier == NULL)
214
char errmsg[STRERROR_MAX];
215
strerror_r(errno, errmsg, sizeof(errmsg));
126
216
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to allocate the TransactionLogApplier instance. Got error: %s\n"),
130
220
context.add(transaction_log_applier);
221
ReplicationServices &replication_services= ReplicationServices::singleton();
222
replication_services.attachApplier(transaction_log_applier,
223
sysvar_transaction_log_use_replicator);
132
225
/* Setup DATA_DICTIONARY views */
147
240
new plugin::Create_function<HexdumpTransactionMessageFunction>("hexdump_transaction_message");
148
241
context.add(hexdump_transaction_message_func_factory);
150
/* Create and initialize the transaction log index */
151
transaction_log_index= new (nothrow) TransactionLogIndex(*transaction_log);
152
if (transaction_log_index == NULL)
154
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to allocate the TransactionLogIndex instance. Got error: %s\n"),
160
/* Check to see if the index was not created properly */
161
if (transaction_log_index->hasError())
163
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to initialize the Transaction Log Index. Got error: %s\n"),
164
transaction_log_index->getErrorMessage().c_str());
170
244
* Setup the background worker thread which maintains
171
245
* summary information about the transaction log.
180
static void set_truncate_debug(Session *,
254
static void init_options(drizzled::module::option_context &context)
186
* The const void * save comes directly from the check function,
187
* which should simply return the result from the set statement.
191
if (*(bool *)save != false)
193
transaction_log->truncate();
194
transaction_log_index->clear();
256
context("truncate-debug",
257
po::value<bool>(&sysvar_transaction_log_truncate_debug)->default_value(false)->zero_tokens(),
258
N_("DEBUGGING - Truncate transaction log"));
259
context("enable-checksum",
260
po::value<bool>(&sysvar_transaction_log_checksum_enabled)->default_value(false)->zero_tokens(),
261
N_("Enable CRC32 Checksumming of each written transaction log entry"));
263
po::value<bool>(&sysvar_transaction_log_enabled)->default_value(false)->zero_tokens(),
264
N_("Enable transaction log"));
266
po::value<string>(&sysvar_transaction_log_file)->default_value(DEFAULT_LOG_FILE_PATH),
267
N_("Path to the file to use for transaction log"));
268
context("use-replicator",
269
po::value<string>(&sysvar_transaction_log_use_replicator)->default_value(DEFAULT_USE_REPLICATOR),
270
N_("Name of the replicator plugin to use (default='default_replicator')"));
271
context("flush-frequency",
272
po::value<flush_constraint>(&sysvar_transaction_log_flush_frequency)->default_value(0),
273
N_("0 == rely on operating system to sync log file (default), 1 == sync file at each transaction write, 2 == sync log file once per second"));
274
context("num-write-buffers",
275
po::value<write_buffers_constraint>(&sysvar_transaction_log_num_write_buffers)->default_value(8),
276
N_("Number of slots for in-memory write buffers (default=8)."));
199
static DRIZZLE_SYSVAR_BOOL(enable,
200
sysvar_transaction_log_enabled,
202
N_("Enable transaction log"),
203
NULL, /* check func */
204
NULL, /* update func */
205
false /* default */);
207
static DRIZZLE_SYSVAR_BOOL(truncate_debug,
208
sysvar_transaction_log_truncate_debug,
210
N_("DEBUGGING - Truncate transaction log"),
211
NULL, /* check func */
212
set_truncate_debug, /* update func */
213
false /* default */);
215
static DRIZZLE_SYSVAR_STR(log_file,
216
sysvar_transaction_log_file,
218
N_("Path to the file to use for transaction log"),
219
NULL, /* check func */
220
NULL, /* update func*/
221
DEFAULT_LOG_FILE_PATH /* default */);
223
static DRIZZLE_SYSVAR_BOOL(enable_checksum,
224
sysvar_transaction_log_checksum_enabled,
226
N_("Enable CRC32 Checksumming of each written transaction log entry"),
227
NULL, /* check func */
228
NULL, /* update func */
229
false /* default */);
231
static DRIZZLE_SYSVAR_UINT(sync_method,
232
sysvar_transaction_log_sync_method,
234
N_("0 == rely on operating system to sync log file (default), "
235
"1 == sync file at each transaction write, "
236
"2 == sync log file once per second"),
237
NULL, /* check func */
238
NULL, /* update func */
244
static drizzle_sys_var* sys_variables[]= {
245
DRIZZLE_SYSVAR(enable),
246
DRIZZLE_SYSVAR(truncate_debug),
247
DRIZZLE_SYSVAR(log_file),
248
DRIZZLE_SYSVAR(enable_checksum),
249
DRIZZLE_SYSVAR(sync_method),
253
DRIZZLE_PLUGIN(init, sys_variables);
279
DRIZZLE_PLUGIN(init, NULL, init_options);