Redis
 sql >> база данни >  >> NoSQL >> Redis

Хиредис чака съобщение

Не е нужно да казвате на hiredis, че трябва да изчакате на канала:цикълът на събитията просто ще изчака на връзката Redis, която е била регистрирана преди това.

Ето пълен пример:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <signal.h>
#include "hiredis.h"
#include "async.h"
#include "adapters/libevent.h"

void subCallback(redisAsyncContext *c, void *r, void *priv) {
    redisReply *reply = r;
    if (reply == NULL) return;
    if ( reply->type == REDIS_REPLY_ARRAY && reply->elements == 3 ) {
        if ( strcmp( reply->element[0]->str, "subscribe" ) != 0 ) {
            printf( "Received[%s] channel %s: %s\n",
                    (char*)priv,
                    reply->element[1]->str,
                    reply->element[2]->str );
        }
    }
}

void connectCallback(const redisAsyncContext *c, int status) {
    if (status != REDIS_OK) {
        printf("Error: %s\n", c->errstr);
        return;
    }
    printf("Connected...\n");
}

void disconnectCallback(const redisAsyncContext *c, int status) {
    if (status != REDIS_OK) {
        printf("Error: %s\n", c->errstr);
        return;
    }
    printf("Disconnected...\n");
}

int main (int argc, char **argv) {
    signal(SIGPIPE, SIG_IGN);
    struct event_base *base = event_base_new();

    redisAsyncContext *c = redisAsyncConnect("127.0.0.1", 6379);
    if (c->err) {
        /* Let *c leak for now... */
        printf("Error: %s\n", c->errstr);
        return 1;
    }

    redisLibeventAttach(c,base);
    redisAsyncSetConnectCallback(c,connectCallback);
    redisAsyncSetDisconnectCallback(c,disconnectCallback);
    redisAsyncCommand(c, subCallback, (char*) "sub", "SUBSCRIBE foo");

    event_base_dispatch(base);
    return 0;
}

Можете да го тествате, като просто използвате следната команда, за да публикувате нещо:

redis-cli publish foo something

Функцията event_base_dispatch е тази, която действително стартира цикъла на събитията и го кара да чака при абонамент за Redis.



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Получаване на всички python-rom обекти в списък

  2. Поведение на Redis с множество едновременни програми, извършващи четене/делене на един и същ хеш ключ

  3. Грешка в Django Channels - Не може да се импортира BACKEND 'asgi_redis.RedisChannelLayer'

  4. персонализирана компилация на redis-client е неуспешна

  5. Грешка при зареждане на споделени библиотеки, не може да се отвори файл на споделен обект:Няма такъв файл или директория (hiredis)