mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 00:28:26 -05:00
82 lines
2.5 KiB
C
82 lines
2.5 KiB
C
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <signal.h>
|
|
|
|
#include <hiredis.h>
|
|
#include <async.h>
|
|
#include <adapters/libuv.h>
|
|
|
|
void debugCallback(redisAsyncContext *c, void *r, void *privdata) {
|
|
(void)privdata; //unused
|
|
redisReply *reply = r;
|
|
if (reply == NULL) {
|
|
/* The DEBUG SLEEP command will almost always fail, because we have set a 1 second timeout */
|
|
printf("`DEBUG SLEEP` error: %s\n", c->errstr ? c->errstr : "unknown error");
|
|
return;
|
|
}
|
|
/* Disconnect after receiving the reply of DEBUG SLEEP (which will not)*/
|
|
redisAsyncDisconnect(c);
|
|
}
|
|
|
|
void getCallback(redisAsyncContext *c, void *r, void *privdata) {
|
|
redisReply *reply = r;
|
|
if (reply == NULL) {
|
|
printf("`GET key` error: %s\n", c->errstr ? c->errstr : "unknown error");
|
|
return;
|
|
}
|
|
printf("`GET key` result: argv[%s]: %s\n", (char*)privdata, reply->str);
|
|
|
|
/* start another request that demonstrate timeout */
|
|
redisAsyncCommand(c, debugCallback, NULL, "DEBUG SLEEP %f", 1.5);
|
|
}
|
|
|
|
void connectCallback(const redisAsyncContext *c, int status) {
|
|
if (status != REDIS_OK) {
|
|
printf("connect error: %s\n", c->errstr);
|
|
return;
|
|
}
|
|
printf("Connected...\n");
|
|
}
|
|
|
|
void disconnectCallback(const redisAsyncContext *c, int status) {
|
|
if (status != REDIS_OK) {
|
|
printf("disconnect because of error: %s\n", c->errstr);
|
|
return;
|
|
}
|
|
printf("Disconnected...\n");
|
|
}
|
|
|
|
int main (int argc, char **argv) {
|
|
#ifndef _WIN32
|
|
signal(SIGPIPE, SIG_IGN);
|
|
#endif
|
|
|
|
uv_loop_t* loop = uv_default_loop();
|
|
|
|
redisAsyncContext *c = redisAsyncConnect("127.0.0.1", 6379);
|
|
if (c->err) {
|
|
/* Let *c leak for now... */
|
|
printf("Error: %s\n", c->errstr);
|
|
return 1;
|
|
}
|
|
|
|
redisLibuvAttach(c,loop);
|
|
redisAsyncSetConnectCallback(c,connectCallback);
|
|
redisAsyncSetDisconnectCallback(c,disconnectCallback);
|
|
redisAsyncSetTimeout(c, (struct timeval){ .tv_sec = 1, .tv_usec = 0});
|
|
|
|
/*
|
|
In this demo, we first `set key`, then `get key` to demonstrate the basic usage of libuv adapter.
|
|
Then in `getCallback`, we start a `debug sleep` command to create 1.5 second long request.
|
|
Because we have set a 1 second timeout to the connection, the command will always fail with a
|
|
timeout error, which is shown in the `debugCallback`.
|
|
*/
|
|
|
|
redisAsyncCommand(c, NULL, NULL, "SET key %b", argv[argc-1], strlen(argv[argc-1]));
|
|
redisAsyncCommand(c, getCallback, (char*)"end-1", "GET key");
|
|
|
|
uv_run(loop, UV_RUN_DEFAULT);
|
|
return 0;
|
|
}
|