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

Addresses #1792 refs[t:1792] Added range lock info to show engine status

git-svn-id: file:///svn/toku/tokudb@14745 c7de825b-a66e-492c-adef-691d508d4ae1
parent 4ed4cdb8
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -359,6 +359,10 @@ int main (int argc __attribute__((__unused__)), char *argv[] __attribute__((__un ...@@ -359,6 +359,10 @@ int main (int argc __attribute__((__unused__)), char *argv[] __attribute__((__un
printf(" int64_t cachetable_size_limit; /* */ \n"); printf(" int64_t cachetable_size_limit; /* */ \n");
printf(" int64_t cachetable_size_writing; /* */ \n"); printf(" int64_t cachetable_size_writing; /* */ \n");
printf(" u_int32_t range_locks_max; /* max total number of range locks */ \n");
printf(" u_int32_t range_locks_max_per_db; /* max range locks per dictionary */ \n");
printf(" u_int32_t range_locks_curr; /* total range locks currently in use */ \n");
// printf(" struct timeval checkpoint_tbegin; /* time of last checkpoint begin */ \n"); // printf(" struct timeval checkpoint_tbegin; /* time of last checkpoint begin */ \n");
// printf(" struct timeval checkpoint_tend; /* time of last checkpoint end */ \n"); // printf(" struct timeval checkpoint_tend; /* time of last checkpoint end */ \n");
// printf(" DB_LSN lsn_of_last_checkpoint_begin; \n"); // printf(" DB_LSN lsn_of_last_checkpoint_begin; \n");
......
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status { ...@@ -54,6 +54,9 @@ typedef struct __toku_engine_status {
int64_t cachetable_size_current; /* */ int64_t cachetable_size_current; /* */
int64_t cachetable_size_limit; /* */ int64_t cachetable_size_limit; /* */
int64_t cachetable_size_writing; /* */ int64_t cachetable_size_writing; /* */
u_int32_t range_locks_max; /* max total number of range locks */
u_int32_t range_locks_max_per_db; /* max range locks per dictionary */
u_int32_t range_locks_curr; /* total range locks currently in use */
} ENGINE_STATUS; } ENGINE_STATUS;
typedef enum { typedef enum {
DB_BTREE=1, DB_BTREE=1,
......
...@@ -209,6 +209,16 @@ cleanup: ...@@ -209,6 +209,16 @@ cleanup:
return r; return r;
} }
int toku_ltm_get_curr_locks(toku_ltm* mgr, u_int32_t* curr_locks) {
int r = ENOSYS;
if (!mgr || !curr_locks) { r = EINVAL; goto cleanup; }
*curr_locks = mgr->curr_locks;
r = 0;
cleanup:
return r;
}
int toku_ltm_get_max_locks(toku_ltm* mgr, u_int32_t* max_locks) { int toku_ltm_get_max_locks(toku_ltm* mgr, u_int32_t* max_locks) {
int r = ENOSYS; int r = ENOSYS;
...@@ -267,7 +277,7 @@ cleanup: ...@@ -267,7 +277,7 @@ cleanup:
/* Functions to update the range count and compare it with the /* Functions to update the range count and compare it with the
maximum number of ranges */ maximum number of ranges */
#if 0 //See ticket #596 //See ticket #596
static inline BOOL toku__ltm_lock_test_incr(toku_ltm* tree_mgr, static inline BOOL toku__ltm_lock_test_incr(toku_ltm* tree_mgr,
u_int32_t replace_locks) { u_int32_t replace_locks) {
assert(tree_mgr); assert(tree_mgr);
...@@ -286,26 +296,28 @@ static inline void toku__ltm_lock_decr(toku_ltm* tree_mgr, u_int32_t locks) { ...@@ -286,26 +296,28 @@ static inline void toku__ltm_lock_decr(toku_ltm* tree_mgr, u_int32_t locks) {
assert(tree_mgr->curr_locks >= locks); assert(tree_mgr->curr_locks >= locks);
tree_mgr->curr_locks -= locks; tree_mgr->curr_locks -= locks;
} }
#endif
/* The following 3 are temporary functions. See #596 */ /* The following 3 are temporary functions. See #596 */
static inline BOOL toku__lt_lock_test_incr_per_db(toku_lock_tree* tree, static inline BOOL toku__lt_lock_test_incr_per_db(toku_lock_tree* tree,
u_int32_t replace_locks) { u_int32_t replace_locks) {
assert(tree); assert(tree);
assert(replace_locks <= tree->curr_locks); assert(replace_locks <= tree->curr_locks);
return (BOOL)(tree->curr_locks - replace_locks < tree->max_locks); return (BOOL)(tree->curr_locks - replace_locks < tree->max_locks) &&
toku__ltm_lock_test_incr(tree->mgr, replace_locks);
} }
static inline void toku__lt_lock_incr_per_db(toku_lock_tree* tree, u_int32_t replace_locks) { static inline void toku__lt_lock_incr_per_db(toku_lock_tree* tree, u_int32_t replace_locks) {
assert(toku__lt_lock_test_incr_per_db(tree, replace_locks)); assert(toku__lt_lock_test_incr_per_db(tree, replace_locks));
tree->curr_locks -= replace_locks; tree->curr_locks -= replace_locks;
tree->curr_locks += 1; tree->curr_locks += 1;
toku__ltm_lock_incr(tree->mgr, replace_locks);
} }
static inline void toku__lt_lock_decr_per_db(toku_lock_tree* tree, u_int32_t locks) { static inline void toku__lt_lock_decr_per_db(toku_lock_tree* tree, u_int32_t locks) {
assert(tree); assert(tree);
assert(tree->curr_locks >= locks); assert(tree->curr_locks >= locks);
tree->curr_locks -= locks; tree->curr_locks -= locks;
toku__ltm_lock_decr(tree->mgr, locks);
} }
static inline void toku__p_free(toku_lock_tree* tree, toku_point* point) { static inline void toku__p_free(toku_lock_tree* tree, toku_point* point) {
......
...@@ -131,7 +131,7 @@ struct __toku_ltm { ...@@ -131,7 +131,7 @@ struct __toku_ltm {
u_int32_t max_locks; u_int32_t max_locks;
/** The current number of locks for the environment. */ /** The current number of locks for the environment. */
u_int32_t curr_locks; u_int32_t curr_locks;
/** The maximum number of locks allowed for the environment. */ /** The maximum number of locks allowed for the db. */
u_int32_t max_locks_per_db; u_int32_t max_locks_per_db;
/** The list of lock trees it manages. */ /** The list of lock trees it manages. */
toku_lth* lth; toku_lth* lth;
...@@ -507,6 +507,8 @@ int toku_ltm_set_max_locks_per_db(toku_ltm* mgr, u_int32_t max_locks); ...@@ -507,6 +507,8 @@ int toku_ltm_set_max_locks_per_db(toku_ltm* mgr, u_int32_t max_locks);
*/ */
int toku_ltm_get_max_locks(toku_ltm* mgr, u_int32_t* max_locks); int toku_ltm_get_max_locks(toku_ltm* mgr, u_int32_t* max_locks);
int toku_ltm_get_curr_locks(toku_ltm* mgr, u_int32_t* curr_locks);
int toku_ltm_get_max_locks_per_db(toku_ltm* mgr, u_int32_t* max_locks); int toku_ltm_get_max_locks_per_db(toku_ltm* mgr, u_int32_t* max_locks);
void toku_lt_add_ref(toku_lock_tree* tree); void toku_lt_add_ref(toku_lock_tree* tree);
......
...@@ -973,6 +973,12 @@ env_get_engine_status(DB_ENV * env, ENGINE_STATUS * engstat) { ...@@ -973,6 +973,12 @@ env_get_engine_status(DB_ENV * env, ENGINE_STATUS * engstat) {
engstat->cachetable_size_limit = ctstat.size_limit; engstat->cachetable_size_limit = ctstat.size_limit;
engstat->cachetable_size_writing = ctstat.size_writing; engstat->cachetable_size_writing = ctstat.size_writing;
} }
{
toku_ltm* ltm = env->i->ltm;
r = toku_ltm_get_max_locks(ltm, &(engstat->range_locks_max)); assert(r==0);
r = toku_ltm_get_max_locks_per_db(ltm, &(engstat->range_locks_max_per_db)); assert(r==0);
r = toku_ltm_get_curr_locks(ltm, &(engstat->range_locks_curr)); assert(r==0);
}
} }
return r; return r;
} }
......
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