INFO commandstats section reset with config resetstat, a new microseconds per call field, and a few other minor things

This commit is contained in:
antirez 2011-01-24 10:56:06 +01:00
parent 9b45592c69
commit d7ed7fd2fc
3 changed files with 24 additions and 8 deletions

View File

@ -555,6 +555,7 @@ void configCommand(redisClient *c) {
server.stat_numcommands = 0; server.stat_numcommands = 0;
server.stat_numconnections = 0; server.stat_numconnections = 0;
server.stat_expiredkeys = 0; server.stat_expiredkeys = 0;
resetCommandTableStats();
addReply(c,shared.ok); addReply(c,shared.ok);
} else { } else {
addReplyError(c, addReplyError(c,

View File

@ -68,7 +68,7 @@ double R_Zero, R_PosInf, R_NegInf, R_Nan;
/* Global vars */ /* Global vars */
struct redisServer server; /* server global state */ struct redisServer server; /* server global state */
struct redisCommand *commandTable; struct redisCommand *commandTable;
struct redisCommand readonlyCommandTable[] = { struct redisCommand redisCommandTable[] = {
{"get",getCommand,2,0,NULL,1,1,1,0,0}, {"get",getCommand,2,0,NULL,1,1,1,0,0},
{"set",setCommand,3,REDIS_CMD_DENYOOM,NULL,0,0,0,0,0}, {"set",setCommand,3,REDIS_CMD_DENYOOM,NULL,0,0,0,0,0},
{"setnx",setnxCommand,3,REDIS_CMD_DENYOOM,NULL,0,0,0,0,0}, {"setnx",setnxCommand,3,REDIS_CMD_DENYOOM,NULL,0,0,0,0,0},
@ -936,10 +936,10 @@ void initServer() {
* we have on top of redis.c file. */ * we have on top of redis.c file. */
void populateCommandTable(void) { void populateCommandTable(void) {
int j; int j;
int numcommands = sizeof(readonlyCommandTable)/sizeof(struct redisCommand); int numcommands = sizeof(redisCommandTable)/sizeof(struct redisCommand);
for (j = 0; j < numcommands; j++) { for (j = 0; j < numcommands; j++) {
struct redisCommand *c = readonlyCommandTable+j; struct redisCommand *c = redisCommandTable+j;
int retval; int retval;
retval = dictAdd(server.commands, sdsnew(c->name), c); retval = dictAdd(server.commands, sdsnew(c->name), c);
@ -947,6 +947,18 @@ void populateCommandTable(void) {
} }
} }
void resetCommandTableStats(void) {
int numcommands = sizeof(redisCommandTable)/sizeof(struct redisCommand);
int j;
for (j = 0; j < numcommands; j++) {
struct redisCommand *c = redisCommandTable+j;
c->microseconds = 0;
c->calls = 0;
}
}
/* ====================== Commands lookup and execution ===================== */ /* ====================== Commands lookup and execution ===================== */
struct redisCommand *lookupCommand(sds name) { struct redisCommand *lookupCommand(sds name) {
@ -1405,13 +1417,15 @@ sds genRedisInfoString(char *section) {
if (allsections || !strcasecmp(section,"commandstats")) { if (allsections || !strcasecmp(section,"commandstats")) {
if (sections++) info = sdscat(info,"\r\n"); if (sections++) info = sdscat(info,"\r\n");
info = sdscatprintf(info, "# Commandstats\r\n"); info = sdscatprintf(info, "# Commandstats\r\n");
numcommands = sizeof(readonlyCommandTable)/sizeof(struct redisCommand); numcommands = sizeof(redisCommandTable)/sizeof(struct redisCommand);
for (j = 0; j < numcommands; j++) { for (j = 0; j < numcommands; j++) {
struct redisCommand *c = readonlyCommandTable+j; struct redisCommand *c = redisCommandTable+j;
if (!c->microseconds) continue; if (!c->calls) continue;
info = sdscatprintf(info,"cmdstat_%s:calls=%lld,usec=%lld\r\n", info = sdscatprintf(info,
c->name, c->calls, c->microseconds); "cmdstat_%s:calls=%lld,usec=%lld,usec_per_call=%.2f\r\n",
c->name, c->calls, c->microseconds,
(c->calls == 0) ? 0 : ((float)c->microseconds/c->calls));
} }
} }

View File

@ -800,6 +800,7 @@ void updateDictResizePolicy(void);
int htNeedsResize(dict *dict); int htNeedsResize(dict *dict);
void oom(const char *msg); void oom(const char *msg);
void populateCommandTable(void); void populateCommandTable(void);
void resetCommandTableStats(void);
/* Disk store */ /* Disk store */
int dsOpen(void); int dsOpen(void);