Redis模块化基本介绍

概要

  1. Redis Modules System基本概念
  2. 基本应用
  3. 参考资料

1. Redis Modules System基本概念

Redis Modules System是4.0出现一大改动点,使得能够经过外部模块对Redis进行功能性扩展。 Redis的模块采用的是动态连接库的方式,能够启动的时候加载,也能够在运行时加载(MODULE LOAD),在Linux系统里面,能够经过dlopen,dlsym等实现动态加载库,在业务系统里面,常常用于将业务代码和框架代码进行分离,以实现插件化开发。在Redis里面也是一样的道理。要实现分离,首先须要的是初始化,以便让框架能够找到对应的方法,这就须要进行注册,Redis经过RedisModule_Init方法进行注册模块,和RedisModule_CreateCommand注册自定义方法。
Redis进行模块化,能够扩大Redis的生态圈,知足一些扩展性功能需求,如今就有一个Hub用于收集Redis模块的插件。如:http://redismodules.com/redis

2. 基本应用

Redis导出了redismodule.h头文件,经过实现该头文件相关API函数,而后编译为so动态库,便可。api

2.1 加载方式

能够在配置文件中使用loadmodule指明,也能够在运行时使用命令动态加载(MODULE LOAD)。框架

2.2 模块化命令

  • MODULE LOAD
  • MODULE LIST
  • MODULE UNLOAD

2.3 开发

2.3.1 示例

实现RedisModule_OnLoad方法,在里面调用RedisModule_Init初始化模块,而后使用RedisModule_CreateCommand建立命令。dom

最后编译:gcc simple.c –fPIC –shared -o simple.so模块化

客户端链接,动态加载:

服务端输出日志:

执行命令:
函数

基于4.0.1 stable版本开发的:插件

#include "redismodule.h"
#include <stdlib.h>

int SimpleRand_RedisCommand(RedisModuleCtx *ctx, RedisModuleString **argv, int argc) {
    RedisModule_ReplyWithLongLong(ctx,rand());
    return REDISMODULE_OK;
}

int RedisModule_OnLoad(RedisModuleCtx *ctx, RedisModuleString **argv, int argc) {
    if (RedisModule_Init(ctx,"simplemodule",1,REDISMODULE_APIVER_1)
            == REDISMODULE_ERR) return REDISMODULE_ERR;

// (RedisModuleCtx *ctx, const char *name, RedisModuleCmdFunc cmdfunc, const char *strflags, int firstkey, int lastkey, int keystep);
    if (RedisModule_CreateCommand(ctx,"simple.rand",
                                  SimpleRand_RedisCommand, "readonly", 1, 1, 1) == REDISMODULE_ERR)
        return REDISMODULE_ERR;

    return REDISMODULE_OK;
}

2.4 API说明

RedisModule_OnLoad

每个Redis Module里面都必需要有该方法,模块加载的时候会调用,该方法用于初始化模块的相关信息。如建立Redis自定义命令等。通常来讲,都是以:《模块名.方法》 来进行命名。如(SIMPLE.RAND)
API原型:
int RedisModule_OnLoad(RedisModuleCtx *ctx, RedisModuleString **argv, int argc);日志

RedisModule_Init

在RedisModule_OnLoad方法里面调用,必须第一个调用,由于要初始化一些信息。出错返回REDISMODULE_ERR
API 原型:
int RedisModule_Init(RedisModuleCtx *ctx, const char *modulename, int module_version, int api_version);code

RedisModule_CreateCommand

注册自定义方法。
API原型:
int RedisModule_CreateCommand (RedisModuleCtx *ctx, const char *name, RedisModuleCmdFunc cmdfunc, const char *strflags, int firstkey, int lastkey, int keystep);
自定义API原型:
int mycommand(RedisModuleCtx *ctx, RedisModuleString **argv, int argc);ip

注:
Strflags能够取值:
write readonly admin deny-oom deny-script allow-loading pubsub random allow-stale no-monitor fast getkeys-api no-cluster

3. 参考资料

Redis官方文档:https://redis.io/topics/modules-intro

相关文章
相关标签/搜索