83
84
* TransactionLog::FLUSH_FREQUENCY_EVERY_WRITE == 1 ... sync on every write
84
85
* TransactionLog::FLUSH_FREQUENCY_EVERY_SECOND == 2 ... sync at most once a second
86
typedef constrained_check<uint32_t, 2, 0> flush_constraint;
87
static flush_constraint sysvar_transaction_log_flush_frequency;
87
static uint32_t sysvar_transaction_log_flush_frequency= 0;
89
89
* Transaction Log plugin system variable - Number of slots to create
90
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;
92
static uint32_t sysvar_transaction_log_num_write_buffers= 8;
95
94
* Transaction Log plugin system variable - The name of the replicator plugin
96
95
* to pair the transaction log's applier with. Defaults to "default"
98
97
static const char DEFAULT_USE_REPLICATOR[]= "default";
99
static string sysvar_transaction_log_use_replicator;
98
static char *sysvar_transaction_log_use_replicator= (char *)DEFAULT_USE_REPLICATOR;
101
100
/** DATA_DICTIONARY views */
102
101
static TransactionLogTool *transaction_log_tool;
122
121
(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;
124
/* These get strdup'd below */
125
free(sysvar_transaction_log_file);
126
free(sysvar_transaction_log_use_replicator);
139
129
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<uint32_t>("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));
131
const module::option_map &vm= context.getOptions();
133
if (vm.count("flush-frequency"))
135
if (sysvar_transaction_log_flush_frequency > 2)
137
errmsg_printf(ERRMSG_LVL_ERROR, _("Invalid value for sync-method\n"));
142
if (vm.count("num-write-buffers"))
144
if (sysvar_transaction_log_num_write_buffers < 4 || sysvar_transaction_log_num_write_buffers > 8192)
146
errmsg_printf(ERRMSG_LVL_ERROR, _("Invalid value for num-write-buffers\n"));
159
152
/* Create and initialize the transaction log itself */
160
153
if (sysvar_transaction_log_enabled)
155
if (vm.count("file"))
157
sysvar_transaction_log_file= strdup(vm["file"].as<string>().c_str());
161
sysvar_transaction_log_file= strdup(DEFAULT_LOG_FILE_PATH);
163
transaction_log= new (nothrow) TransactionLog(sysvar_transaction_log_file,
164
static_cast<int>(sysvar_transaction_log_flush_frequency),
164
if (vm.count("use-replicator"))
166
sysvar_transaction_log_use_replicator= strdup(vm["use-replicator"].as<string>().c_str());
170
sysvar_transaction_log_use_replicator= strdup(DEFAULT_USE_REPLICATOR);
172
transaction_log= new (nothrow) TransactionLog(string(sysvar_transaction_log_file),
173
sysvar_transaction_log_flush_frequency,
165
174
sysvar_transaction_log_checksum_enabled);
167
176
if (transaction_log == NULL)
169
sql_perror(_("Failed to allocate the TransactionLog instance"), sysvar_transaction_log_file);
178
char errmsg[STRERROR_MAX];
179
strerror_r(errno, errmsg, sizeof(errmsg));
180
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to allocate the TransactionLog instance. Got error: %s\n"),
202
217
transaction_log_applier= new (nothrow) TransactionLogApplier("transaction_log_applier",
204
219
transaction_log_index,
205
static_cast<uint32_t>(sysvar_transaction_log_num_write_buffers));
220
sysvar_transaction_log_num_write_buffers);
206
221
if (transaction_log_applier == NULL)
208
sql_perror(_("Failed to allocate the TransactionLogApplier instance"), sysvar_transaction_log_file);
223
char errmsg[STRERROR_MAX];
224
strerror_r(errno, errmsg, sizeof(errmsg));
225
errmsg_printf(ERRMSG_LVL_ERROR, _("Failed to allocate the TransactionLogApplier instance. Got error: %s\n"),
211
229
context.add(transaction_log_applier);
212
230
ReplicationServices &replication_services= ReplicationServices::singleton();
213
replication_services.attachApplier(transaction_log_applier,
214
sysvar_transaction_log_use_replicator);
231
string replicator_name(sysvar_transaction_log_use_replicator);
232
replication_services.attachApplier(transaction_log_applier, replicator_name);
216
234
/* Setup DATA_DICTIONARY views */
263
static void set_truncate_debug(Session *,
269
* The const void * save comes directly from the check function,
270
* which should simply return the result from the set statement.
274
if (*(bool *)save != false)
276
transaction_log->truncate();
277
transaction_log_index->clear();
282
static DRIZZLE_SYSVAR_BOOL(enable,
283
sysvar_transaction_log_enabled,
284
PLUGIN_VAR_NOCMDARG | PLUGIN_VAR_READONLY,
285
N_("Enable transaction log"),
286
NULL, /* check func */
287
NULL, /* update func */
288
false /* default */);
290
static DRIZZLE_SYSVAR_BOOL(truncate_debug,
291
sysvar_transaction_log_truncate_debug,
293
N_("DEBUGGING - Truncate transaction log"),
294
NULL, /* check func */
295
set_truncate_debug, /* update func */
296
false /* default */);
298
static DRIZZLE_SYSVAR_STR(file,
299
sysvar_transaction_log_file,
301
N_("Path to the file to use for transaction log"),
302
NULL, /* check func */
303
NULL, /* update func*/
304
DEFAULT_LOG_FILE_PATH /* default */);
306
static DRIZZLE_SYSVAR_STR(use_replicator,
307
sysvar_transaction_log_use_replicator,
309
N_("Name of the replicator plugin to use (default='default_replicator')"),
310
NULL, /* check func */
311
NULL, /* update func*/
312
DEFAULT_USE_REPLICATOR /* default */);
314
static DRIZZLE_SYSVAR_BOOL(enable_checksum,
315
sysvar_transaction_log_checksum_enabled,
317
N_("Enable CRC32 Checksumming of each written transaction log entry"),
318
NULL, /* check func */
319
NULL, /* update func */
320
false /* default */);
322
static DRIZZLE_SYSVAR_UINT(flush_frequency,
323
sysvar_transaction_log_flush_frequency,
325
N_("0 == rely on operating system to sync log file (default), "
326
"1 == sync file at each transaction write, "
327
"2 == sync log file once per second"),
328
NULL, /* check func */
329
NULL, /* update func */
335
static DRIZZLE_SYSVAR_UINT(num_write_buffers,
336
sysvar_transaction_log_num_write_buffers,
338
N_("Number of slots for in-memory write buffers (default=8)."),
339
NULL, /* check func */
340
NULL, /* update func */
245
346
static void init_options(drizzled::module::option_context &context)
247
348
context("truncate-debug",
248
349
po::value<bool>(&sysvar_transaction_log_truncate_debug)->default_value(false)->zero_tokens(),
249
_("DEBUGGING - Truncate transaction log"));
350
N_("DEBUGGING - Truncate transaction log"));
250
351
context("enable-checksum",
251
352
po::value<bool>(&sysvar_transaction_log_checksum_enabled)->default_value(false)->zero_tokens(),
252
_("Enable CRC32 Checksumming of each written transaction log entry"));
353
N_("Enable CRC32 Checksumming of each written transaction log entry"));
253
354
context("enable",
254
355
po::value<bool>(&sysvar_transaction_log_enabled)->default_value(false)->zero_tokens(),
255
_("Enable transaction log"));
356
N_("Enable transaction log"));
257
po::value<string>(&sysvar_transaction_log_file)->default_value(DEFAULT_LOG_FILE_PATH),
258
_("Path to the file to use for transaction log"));
359
N_("Path to the file to use for transaction log"));
259
360
context("use-replicator",
260
po::value<string>(&sysvar_transaction_log_use_replicator)->default_value(DEFAULT_USE_REPLICATOR),
261
_("Name of the replicator plugin to use (default='default_replicator')"));
362
N_("Name of the replicator plugin to use (default='default_replicator')"));
262
363
context("flush-frequency",
263
po::value<flush_constraint>(&sysvar_transaction_log_flush_frequency)->default_value(0),
264
_("0 == rely on operating system to sync log file (default), 1 == sync file at each transaction write, 2 == sync log file once per second"));
364
po::value<uint32_t>(&sysvar_transaction_log_flush_frequency)->default_value(0),
365
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"));
265
366
context("num-write-buffers",
266
po::value<write_buffers_constraint>(&sysvar_transaction_log_num_write_buffers)->default_value(8),
267
_("Number of slots for in-memory write buffers (default=8)."));
367
po::value<uint32_t>(&sysvar_transaction_log_num_write_buffers)->default_value(8),
368
N_("Number of slots for in-memory write buffers (default=8)."));
270
DRIZZLE_PLUGIN(init, NULL, init_options);
371
static drizzle_sys_var* sys_variables[]= {
372
DRIZZLE_SYSVAR(enable),
373
DRIZZLE_SYSVAR(truncate_debug),
374
DRIZZLE_SYSVAR(file),
375
DRIZZLE_SYSVAR(enable_checksum),
376
DRIZZLE_SYSVAR(flush_frequency),
377
DRIZZLE_SYSVAR(num_write_buffers),
378
DRIZZLE_SYSVAR(use_replicator),
382
DRIZZLE_PLUGIN(init, sys_variables, init_options);