Commit f398fd55 authored by Barry Perlman's avatar Barry Perlman Committed by Yoni Fogel

[t:3654] #3654 Create new BRT_STATUS to collect info on brt behavior.

git-svn-id: file:///svn/toku/tokudb@32971 c7de825b-a66e-492c-adef-691d508d4ae1
parent 106838df
...@@ -641,13 +641,19 @@ typedef struct le_status { ...@@ -641,13 +641,19 @@ typedef struct le_status {
void toku_le_get_status(LE_STATUS); void toku_le_get_status(LE_STATUS);
typedef struct update_status { typedef struct brt_status {
u_int64_t updates; u_int64_t updates;
u_int64_t updates_broadcast; u_int64_t updates_broadcast;
u_int64_t descriptor_set; u_int64_t descriptor_set;
} UPDATE_STATUS_S, *UPDATE_STATUS; u_int64_t partial_fetch_hit; // node partition is present
u_int64_t partial_fetch_miss; // node is present but partition is absent
void toku_update_get_status(UPDATE_STATUS); u_int64_t partial_fetch_compressed; // node partition is present but compressed
u_int64_t msn_discards; // how many messages were ignored by leaf because of msn
u_int64_t max_workdone; // max workdone value of any buffer
u_int64_t dsn_gap; // dsn has detected a gap in continuity of root-to-leaf path (internal node was evicted and re-read)
} BRT_STATUS_S, *BRT_STATUS;
void toku_brt_get_status(BRT_STATUS);
void void
brt_leaf_apply_cmd_once ( brt_leaf_apply_cmd_once (
......
...@@ -113,6 +113,14 @@ Split_or_merge (node, childnum) { ...@@ -113,6 +113,14 @@ Split_or_merge (node, childnum) {
static const uint32_t this_version = BRT_LAYOUT_VERSION; static const uint32_t this_version = BRT_LAYOUT_VERSION;
static BRT_STATUS_S brt_status;
void
toku_brt_get_status(BRT_STATUS s) {
*s = brt_status;
}
void void
toku_brt_header_suppress_rollbacks(struct brt_header *h, TOKUTXN txn) { toku_brt_header_suppress_rollbacks(struct brt_header *h, TOKUTXN txn) {
...@@ -1657,8 +1665,11 @@ brt_leaf_apply_cmd_once ( ...@@ -1657,8 +1665,11 @@ brt_leaf_apply_cmd_once (
workdone_this_le = newlen; workdone_this_le = newlen;
} }
} }
if (workdone) // test programs may call with NULL if (workdone) { // test programs may call with NULL
*workdone += workdone_this_le; *workdone += workdone_this_le;
if (*workdone > brt_status.max_workdone)
brt_status.max_workdone = *workdone;
}
// brt_leaf_check_leaf_stats(node); // brt_leaf_check_leaf_stats(node);
...@@ -1716,13 +1727,6 @@ static void setval_fun (const DBT *new_val, void *svextra_v) { ...@@ -1716,13 +1727,6 @@ static void setval_fun (const DBT *new_val, void *svextra_v) {
svextra->made_change = TRUE; svextra->made_change = TRUE;
} }
static UPDATE_STATUS_S update_status;
void
toku_update_get_status(UPDATE_STATUS s) {
*s = update_status;
}
// We are already past the msn filter (in brt_leaf_put_cmd(), which calls do_update()), // We are already past the msn filter (in brt_leaf_put_cmd(), which calls do_update()),
// so capturing the msn in the setval_extra_s is not strictly required. The alternative // so capturing the msn in the setval_extra_s is not strictly required. The alternative
// would be to put a dummy msn in the messages created by setval_fun(), but preserving // would be to put a dummy msn in the messages created by setval_fun(), but preserving
...@@ -1741,7 +1745,7 @@ static int do_update(BRT t, BASEMENTNODE bn, SUBTREE_EST se, BRT_MSG cmd, int id ...@@ -1741,7 +1745,7 @@ static int do_update(BRT t, BASEMENTNODE bn, SUBTREE_EST se, BRT_MSG cmd, int id
if (cmd->type == BRT_UPDATE) { if (cmd->type == BRT_UPDATE) {
// key is passed in with command (should be same as from le) // key is passed in with command (should be same as from le)
// update function extra is passed in with command // update function extra is passed in with command
update_status.updates++; brt_status.updates++;
keyp = cmd->u.id.key; keyp = cmd->u.id.key;
update_function_extra = cmd->u.id.val; update_function_extra = cmd->u.id.val;
} else if (cmd->type == BRT_UPDATE_BROADCAST_ALL) { } else if (cmd->type == BRT_UPDATE_BROADCAST_ALL) {
...@@ -1750,7 +1754,7 @@ static int do_update(BRT t, BASEMENTNODE bn, SUBTREE_EST se, BRT_MSG cmd, int id ...@@ -1750,7 +1754,7 @@ static int do_update(BRT t, BASEMENTNODE bn, SUBTREE_EST se, BRT_MSG cmd, int id
assert(le); // for broadcast updates, we just hit all leafentries assert(le); // for broadcast updates, we just hit all leafentries
// so this cannot be null // so this cannot be null
assert(cmd->u.id.key->size == 0); assert(cmd->u.id.key->size == 0);
update_status.updates_broadcast++; brt_status.updates_broadcast++;
keyp = toku_fill_dbt(&key, le_key(le), le_keylen(le)); keyp = toku_fill_dbt(&key, le_key(le), le_keylen(le));
update_function_extra = cmd->u.id.val; update_function_extra = cmd->u.id.val;
} else { } else {
...@@ -1806,7 +1810,7 @@ brt_leaf_put_cmd ( ...@@ -1806,7 +1810,7 @@ brt_leaf_put_cmd (
LEAFENTRY storeddata; LEAFENTRY storeddata;
OMTVALUE storeddatav=NULL; OMTVALUE storeddatav=NULL;
if (cmd->msn.msn <= bn->max_msn_applied.msn) { if (cmd->msn.msn <= bn->max_msn_applied.msn) {
// TODO3514 add accountability counter here brt_status.msn_discards++;
return; return;
} }
else { else {
...@@ -2836,6 +2840,7 @@ partition_requires_msg_application(BRTNODE node, int childnum, ANCESTORS ancesto ...@@ -2836,6 +2840,7 @@ partition_requires_msg_application(BRTNODE node, int childnum, ANCESTORS ancesto
{ {
if (curr_ancestors->node->dsn.dsn > BLB_MAX_DSN_APPLIED(node,childnum).dsn) { if (curr_ancestors->node->dsn.dsn > BLB_MAX_DSN_APPLIED(node,childnum).dsn) {
requires_msg_application = TRUE; requires_msg_application = TRUE;
brt_status.dsn_gap++;
break; break;
} }
} }
...@@ -3847,7 +3852,7 @@ toku_brt_change_descriptor( ...@@ -3847,7 +3852,7 @@ toku_brt_change_descriptor(
fd = toku_cachefile_get_and_pin_fd (t->cf); fd = toku_cachefile_get_and_pin_fd (t->cf);
r = toku_update_descriptor(t->h, &new_d, fd); r = toku_update_descriptor(t->h, &new_d, fd);
if (r == 0) // very infrequent operation, worth precise threadsafe count if (r == 0) // very infrequent operation, worth precise threadsafe count
(void) toku_sync_fetch_and_increment_uint64(&update_status.descriptor_set); (void) toku_sync_fetch_and_increment_uint64(&brt_status.descriptor_set);
toku_cachefile_unpin_fd(t->cf); toku_cachefile_unpin_fd(t->cf);
if (r!=0) goto cleanup; if (r!=0) goto cleanup;
......
...@@ -1925,11 +1925,11 @@ env_get_engine_status(DB_ENV * env, ENGINE_STATUS * engstat, char * env_panic_st ...@@ -1925,11 +1925,11 @@ env_get_engine_status(DB_ENV * env, ENGINE_STATUS * engstat, char * env_panic_st
engstat->directory_write_locks_fail = directory_write_locks_fail; engstat->directory_write_locks_fail = directory_write_locks_fail;
} }
{ {
UPDATE_STATUS_S update_stat; BRT_STATUS_S brt_stat;
toku_update_get_status(&update_stat); toku_brt_get_status(&brt_stat);
engstat->le_updates = update_stat.updates; engstat->le_updates = brt_stat.updates;
engstat->le_updates_broadcast = update_stat.updates_broadcast; engstat->le_updates_broadcast = brt_stat.updates_broadcast;
engstat->descriptor_set = update_stat.descriptor_set; engstat->descriptor_set = brt_stat.descriptor_set;
} }
{ {
u_int64_t fsync_count, fsync_time; u_int64_t fsync_count, fsync_time;
......
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