From fc05e8c850824d511ddbeee6eacd5ba187176447 Mon Sep 17 00:00:00 2001 From: Pieter Noordhuis Date: Tue, 31 May 2011 17:15:42 -0700 Subject: [PATCH 1/3] More const's in redis-benchmark.c --- src/redis-benchmark.c | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/redis-benchmark.c b/src/redis-benchmark.c index 618d9c030..b88ab2145 100644 --- a/src/redis-benchmark.c +++ b/src/redis-benchmark.c @@ -48,6 +48,10 @@ #define REDIS_NOTUSED(V) ((void) V) static struct config { + aeEventLoop *el; + const char *hostip; + int hostport; + const char *hostsocket; int debug; int numclients; int requests; @@ -57,15 +61,11 @@ static struct config { int datasize; int randomkeys; int randomkeys_keyspacelen; - aeEventLoop *el; - char *hostip; - int hostport; - char *hostsocket; int keepalive; long long start; long long totlatency; long long *latency; - char *title; + const char *title; list *clients; int quiet; int loop; @@ -227,7 +227,7 @@ static void writeHandler(aeEventLoop *el, int fd, void *privdata, int mask) { } } -static client createClient(char *cmd, int len) { +static client createClient(const char *cmd, size_t len) { client c = zmalloc(sizeof(struct _client)); if (config.hostsocket == NULL) { c->context = redisConnectNonBlock(config.hostip,config.hostport); @@ -311,7 +311,7 @@ static void showLatencyReport(void) { } } -static void benchmark(char *title, char *cmd, int len) { +static void benchmark(const char *title, const char *cmd, int len) { client c; config.title = title; @@ -328,7 +328,7 @@ static void benchmark(char *title, char *cmd, int len) { freeAllClients(); } -void parseOptions(int argc, char **argv) { +void parseOptions(int argc, const char **argv) { int i; for (i = 1; i < argc; i++) { @@ -344,13 +344,13 @@ void parseOptions(int argc, char **argv) { config.keepalive = atoi(argv[i+1]); i++; } else if (!strcmp(argv[i],"-h") && !lastarg) { - config.hostip = argv[i+1]; + config.hostip = strdup(argv[i+1]); i++; } else if (!strcmp(argv[i],"-p") && !lastarg) { config.hostport = atoi(argv[i+1]); i++; } else if (!strcmp(argv[i],"-s") && !lastarg) { - config.hostsocket = argv[i+1]; + config.hostsocket = strdup(argv[i+1]); i++; } else if (!strcmp(argv[i],"-d") && !lastarg) { config.datasize = atoi(argv[i+1]); @@ -409,7 +409,7 @@ int showThroughput(struct aeEventLoop *eventLoop, long long id, void *clientData return 250; /* every 250ms */ } -int main(int argc, char **argv) { +int main(int argc, const char **argv) { int i; client c; From 39bf440243d18afbc764f6a637d7138eeeb37372 Mon Sep 17 00:00:00 2001 From: Pieter Noordhuis Date: Tue, 31 May 2011 17:19:11 -0700 Subject: [PATCH 2/3] Provide custom command to benchmark against via args --- src/redis-benchmark.c | 142 ++++++++++++++++++++++++++---------------- 1 file changed, 90 insertions(+), 52 deletions(-) diff --git a/src/redis-benchmark.c b/src/redis-benchmark.c index b88ab2145..e5ce203d0 100644 --- a/src/redis-benchmark.c +++ b/src/redis-benchmark.c @@ -328,41 +328,44 @@ static void benchmark(const char *title, const char *cmd, int len) { freeAllClients(); } -void parseOptions(int argc, const char **argv) { +/* Returns number of consumed options. */ +int parseOptions(int argc, const char **argv) { int i; + int lastarg; + int exit_status = 1; for (i = 1; i < argc; i++) { - int lastarg = i==argc-1; - - if (!strcmp(argv[i],"-c") && !lastarg) { - config.numclients = atoi(argv[i+1]); - i++; - } else if (!strcmp(argv[i],"-n") && !lastarg) { - config.requests = atoi(argv[i+1]); - i++; - } else if (!strcmp(argv[i],"-k") && !lastarg) { - config.keepalive = atoi(argv[i+1]); - i++; - } else if (!strcmp(argv[i],"-h") && !lastarg) { - config.hostip = strdup(argv[i+1]); - i++; - } else if (!strcmp(argv[i],"-p") && !lastarg) { - config.hostport = atoi(argv[i+1]); - i++; - } else if (!strcmp(argv[i],"-s") && !lastarg) { - config.hostsocket = strdup(argv[i+1]); - i++; - } else if (!strcmp(argv[i],"-d") && !lastarg) { - config.datasize = atoi(argv[i+1]); - i++; + lastarg = (i == (argc-1)); + + if (!strcmp(argv[i],"-c")) { + if (lastarg) goto invalid; + config.numclients = atoi(argv[++i]); + } else if (!strcmp(argv[i],"-n")) { + if (lastarg) goto invalid; + config.requests = atoi(argv[++i]); + } else if (!strcmp(argv[i],"-k")) { + if (lastarg) goto invalid; + config.keepalive = atoi(argv[++i]); + } else if (!strcmp(argv[i],"-h")) { + if (lastarg) goto invalid; + config.hostip = strdup(argv[++i]); + } else if (!strcmp(argv[i],"-p")) { + if (lastarg) goto invalid; + config.hostport = atoi(argv[++i]); + } else if (!strcmp(argv[i],"-s")) { + if (lastarg) goto invalid; + config.hostsocket = strdup(argv[++i]); + } else if (!strcmp(argv[i],"-d")) { + if (lastarg) goto invalid; + config.datasize = atoi(argv[++i]); if (config.datasize < 1) config.datasize=1; if (config.datasize > 1024*1024) config.datasize = 1024*1024; - } else if (!strcmp(argv[i],"-r") && !lastarg) { + } else if (!strcmp(argv[i],"-r")) { + if (lastarg) goto invalid; config.randomkeys = 1; - config.randomkeys_keyspacelen = atoi(argv[i+1]); + config.randomkeys_keyspacelen = atoi(argv[++i]); if (config.randomkeys_keyspacelen < 0) config.randomkeys_keyspacelen = 0; - i++; } else if (!strcmp(argv[i],"-q")) { config.quiet = 1; } else if (!strcmp(argv[i],"-l")) { @@ -371,30 +374,44 @@ void parseOptions(int argc, const char **argv) { config.debug = 1; } else if (!strcmp(argv[i],"-I")) { config.idlemode = 1; + } else if (!strcmp(argv[i],"--help")) { + exit_status = 0; + goto usage; } else { - printf("Wrong option '%s' or option argument missing\n\n",argv[i]); - printf("Usage: redis-benchmark [-h ] [-p ] [-c ] [-n [-k ]\n\n"); - printf(" -h Server hostname (default 127.0.0.1)\n"); - printf(" -p Server port (default 6379)\n"); - printf(" -s Server socket (overrides host and port)\n"); - printf(" -c Number of parallel connections (default 50)\n"); - printf(" -n Total number of requests (default 10000)\n"); - printf(" -d Data size of SET/GET value in bytes (default 2)\n"); - printf(" -k 1=keep alive 0=reconnect (default 1)\n"); - printf(" -r Use random keys for SET/GET/INCR, random values for SADD\n"); - printf(" Using this option the benchmark will get/set keys\n"); - printf(" in the form mykey_rand000000012456 instead of constant\n"); - printf(" keys, the argument determines the max\n"); - printf(" number of values for the random number. For instance\n"); - printf(" if set to 10 only rand000000000000 - rand000000000009\n"); - printf(" range will be allowed.\n"); - printf(" -q Quiet. Just show query/sec values\n"); - printf(" -l Loop. Run the tests forever\n"); - printf(" -I Idle mode. Just open N idle connections and wait.\n"); - printf(" -D Debug mode. more verbose.\n"); - exit(1); + /* Assume the user meant to provide an option when the arg starts + * with a dash. We're done otherwise and should use the remainder + * as the command and arguments for running the benchmark. */ + if (argv[i][0] == '-') goto invalid; + return i; } } + + return i; + +invalid: + printf("Invalid option \"%s\" or option argument missing\n\n",argv[i]); + +usage: + printf("Usage: redis-benchmark [-h ] [-p ] [-c ] [-n [-k ]\n\n"); + printf(" -h Server hostname (default 127.0.0.1)\n"); + printf(" -p Server port (default 6379)\n"); + printf(" -s Server socket (overrides host and port)\n"); + printf(" -c Number of parallel connections (default 50)\n"); + printf(" -n Total number of requests (default 10000)\n"); + printf(" -d Data size of SET/GET value in bytes (default 2)\n"); + printf(" -k 1=keep alive 0=reconnect (default 1)\n"); + printf(" -r Use random keys for SET/GET/INCR, random values for SADD\n"); + printf(" Using this option the benchmark will get/set keys\n"); + printf(" in the form mykey_rand000000012456 instead of constant\n"); + printf(" keys, the argument determines the max\n"); + printf(" number of values for the random number. For instance\n"); + printf(" if set to 10 only rand000000000000 - rand000000000009\n"); + printf(" range will be allowed.\n"); + printf(" -q Quiet. Just show query/sec values\n"); + printf(" -l Loop. Run the tests forever\n"); + printf(" -I Idle mode. Just open N idle connections and wait.\n"); + printf(" -D Debug mode. more verbose.\n"); + exit(exit_status); } int showThroughput(struct aeEventLoop *eventLoop, long long id, void *clientData) { @@ -411,6 +428,9 @@ int showThroughput(struct aeEventLoop *eventLoop, long long id, void *clientData int main(int argc, const char **argv) { int i; + char *data, *cmd; + int len; + client c; signal(SIGHUP, SIG_IGN); @@ -436,7 +456,10 @@ int main(int argc, const char **argv) { config.hostport = 6379; config.hostsocket = NULL; - parseOptions(argc,argv); + i = parseOptions(argc,argv); + argc -= i; + argv += i; + config.latency = zmalloc(sizeof(long long)*config.requests); if (config.keepalive == 0) { @@ -451,10 +474,25 @@ int main(int argc, const char **argv) { /* and will wait for every */ } - do { - char *data, *cmd; - int len; + /* Run benchmark with command in the remainder of the arguments. */ + if (argc) { + sds title = sdsnew(argv[0]); + for (i = 1; i < argc; i++) { + title = sdscatlen(title, " ", 1); + title = sdscatlen(title, (char*)argv[i], strlen(argv[1])); + } + do { + len = redisFormatCommandArgv(&cmd,argc,argv,NULL); + benchmark(title,cmd,len); + free(cmd); + } while(config.loop); + + return 0; + } + + /* Run default benchmark suite. */ + do { data = zmalloc(config.datasize+1); memset(data,'x',config.datasize); data[config.datasize] = '\0'; From 294cd536e0aeedd3d6f63f947a67bd2c08d04805 Mon Sep 17 00:00:00 2001 From: Pieter Noordhuis Date: Tue, 31 May 2011 17:38:39 -0700 Subject: [PATCH 3/3] There is no debug mode in benchmark tool --- src/redis-benchmark.c | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/src/redis-benchmark.c b/src/redis-benchmark.c index e5ce203d0..7295dc32a 100644 --- a/src/redis-benchmark.c +++ b/src/redis-benchmark.c @@ -52,7 +52,6 @@ static struct config { const char *hostip; int hostport; const char *hostsocket; - int debug; int numclients; int requests; int liveclients; @@ -370,8 +369,6 @@ int parseOptions(int argc, const char **argv) { config.quiet = 1; } else if (!strcmp(argv[i],"-l")) { config.loop = 1; - } else if (!strcmp(argv[i],"-D")) { - config.debug = 1; } else if (!strcmp(argv[i],"-I")) { config.idlemode = 1; } else if (!strcmp(argv[i],"--help")) { @@ -410,7 +407,6 @@ usage: printf(" -q Quiet. Just show query/sec values\n"); printf(" -l Loop. Run the tests forever\n"); printf(" -I Idle mode. Just open N idle connections and wait.\n"); - printf(" -D Debug mode. more verbose.\n"); exit(exit_status); } @@ -436,7 +432,6 @@ int main(int argc, const char **argv) { signal(SIGHUP, SIG_IGN); signal(SIGPIPE, SIG_IGN); - config.debug = 0; config.numclients = 50; config.requests = 10000; config.liveclients = 0; @@ -479,7 +474,7 @@ int main(int argc, const char **argv) { sds title = sdsnew(argv[0]); for (i = 1; i < argc; i++) { title = sdscatlen(title, " ", 1); - title = sdscatlen(title, (char*)argv[i], strlen(argv[1])); + title = sdscatlen(title, (char*)argv[i], strlen(argv[i])); } do {