mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-22 16:18:28 -05:00
INFO commandstats section reset with config resetstat, a new microseconds per call field, and a few other minor things
This commit is contained in:
parent
9b45592c69
commit
d7ed7fd2fc
@ -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,
|
||||||
|
30
src/redis.c
30
src/redis.c
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user