文章 2024-10-21 来自:开发者社区

如何使用 C++ 开发 Redis 模块

在本文中,我将总结 Tair 在使用 C++ 开发 Redis 模块时遇到的一些问题,并将其提炼为最佳实践。目的是为 Redis 模块的用户和开发人员提供帮助。其中一些最佳实践也可以应用于 C 编程语言和其他编程语言。 介绍 从 Redis 5.0 开始,支持模块插件来增强 Redis 的能力。这些插件允许开发新的数据结构,实现命令侦听和过滤,以及扩展新的网络服务。可以...

如何使用 C++ 开发 Redis 模块
文章 2024-10-17 来自:开发者社区

shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。

前言 shiro学习一:了解shiro,学习执行shiro的流程。使用springboot的测试模块学习shiro单应用(demo 6个) shiro学习二:shiro的加密认证详解,加盐与不加盐两个版本。 shiro学习三:shiro的源码分析 密码专辑:对密码加盐加密,对密码进行md5加密,封装成密码工具类 代码所在地:https://github.com/fengfanli/s...

shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
问答 2024-08-19 来自:开发者社区

在常规的开发方式中,如何手动构造一个包含Redis客户端的RedisClient对象?

在常规的开发方式中,如何手动构造一个包含Redis客户端的RedisClient对象?

文章 2024-07-25 来自:开发者社区

c++开发redis module问题之对于写命令,进行主备复制和写AOF,如何解决

问题一:对于写命令,如何进行主备复制和写AOF? 对于写命令,如何进行主备复制和写AOF? 参考回答: 对于写命令,可以使用RedisModule_ReplicateVerbatim或RedisModule_Replicate进行主备复制和写AOF。其中,RedisModule_ReplicateVerbatim会原封不动地复制命令,而RedisMod...

文章 2024-07-25 来自:开发者社区

c++开发redis module问题之想实现Redis命令,如何解决

问题一:为什么RDB编码需要具有向后兼容能力? 为什么RDB编码需要具有向后兼容能力? 参考回答: RDB是二进制格式的序列化和反序列化方式,由于数据结构以后的序列化方式可能会发生改变,因此需要加上编解码的版本,这样在升级的时候可以保证兼容性,确保旧版本的RDB文件可以在新版本中正确加载。 关于本问题的更多回答可点击原文查看: ...

文章 2024-07-25 来自:开发者社区

c++开发redis module问题之module根据Redis的角色采取不同的行为,如何解决

问题一:module中维护的全局索引应注意什么? module中维护的全局索引应注意什么? 参考回答: 如果module中维护了自己的全局索引,需要谨慎处理索引中是否包含dbid、key等信息。因为Redis的move、rename、swapdb等命令会更改key的名字或交换两个dbid,如果索引没有同步更新,可能会导致意想不到的错误。 ...

文章 2024-07-25 来自:开发者社区

c++开发redis module问题之避免在fork后子进程中发生死锁,如何解决

问题一:如何避免在fork后子进程中发生死锁? 如何避免在fork后子进程中发生死锁? 参考回答: 在fork之前,需要确保所有的锁都已经被释放。因为Linux的fork只会复制调用fork的线程,如果其他线程中持有锁,在子进程中这些线程“蒸发”了,可能导致死锁。因此,解决方法是在fork之前确保所有的锁都已释放。 关于本问题的更多回...

文章 2024-07-25 来自:开发者社区

c++开发redis module问题之保证Redis在fork时没有处于inflight状态的命令,如何解决

问题一:Redis的并发处理能力如何提高? Redis的并发处理能力如何提高? 参考回答: 可以使用block机制来提高Redis的并发处理能力。这意味着在执行一些耗时的module命令时,可以让这些命令在后台运行,这样Redis可以继续读取并处理下一个客户端的命令。 关于本问题的更多回答可点击原文查看: https://de...

c++开发redis module问题之保证Redis在fork时没有处于inflight状态的命令,如何解决
文章 2024-07-25 来自:开发者社区

c++开发redis module问题之避免多个C++模块之间因重载operator new而产生的冲突,如何解决

问题一:如何避免多个C++模块之间因重载operator new而产生的冲突? 如何避免多个C++模块之间因重载operator new而产生的冲突? 参考回答: 避免多个C++模块之间因重载operator new而产生的冲突可能比较困难,特别是当这些模块由不同的开发者开发时。一种可能的解决方案是确保所有相关模块都使用相同的operator new和...

文章 2024-07-25 来自:开发者社区

c++开发redis module问题之如果Redis加载了多个C++编写的模块,并且它们都重载了operator new,会有什么影响

问题一:C++中的operator new默认使用什么函数来分配内存? C++中的operator new默认使用什么函数来分配内存? 参考回答: 默认使用glibc的malloc函数来分配内存。 关于本问题的更多回答可点击原文查看: https://developer.aliyun.com/ask/639329 ...

本页面内关键词为智能算法引擎基于机器学习所生成,如有任何问题,可在页面下方点击"联系我们"与我们沟通。

产品推荐

NoSQL数据库

阿里云NoSQL数据库提供了一种灵活的数据存储方式,可以支持各种数据模型,包括文档型、图型、列型和键值型。此外,它还提供了一种分布式的数据处理方式,可以支持高可用性和容灾备份。包含Redis社区版和Tair、多模数据库 Lindorm、MongoDB 版。

+关注