`

使用Redis之前5个必须了解的事情

 
阅读更多

使用Redis开发应用程序是一个很愉快的过程,但是就像其他技术一样,基于Redis的应用程序设计你同样需要牢记几点。在之前,你可能已经对关 系型数据库开发的那一整个套路了然如胸,而基于Redis的应用程序开发也有许多相似的地方,但是你必须牢记以下两点——Redis是个内存数据库,同时 它是单线程的。因此,在使用Redis时,你需要注意以下几点:

1. 掌控储存在Redis中的所有键

数据库的主要功能是储存数据,但是对于开发者来说,因为应用程序需求或者数据使用方法的改变,忽略存储在数据库中的某些数据是非常正常的,在Redis中同样如此。你可能忽视期满某些键,也可能因为应用程序的某个模块弃用而忘掉这些数据。

无论哪种情况,Redis都存储了一些不再使用的数据,平白无故的占用了一些空间。Redis的弱结构数据模式让集中储存的内容很难被弄清,除非你 为键使用一套非常成熟的命名法则。使用合适的命名方法会简化你的数据库管理,当你通过你的应用程序或者服务做键的命名空间时(通常情况下是使用冒号来划分 键名),你就可以在数据迁移、转换或者删除时轻松的识别。

Redis另一个常见用例是作为热数据项作的第二数据存储,大部分的数据被保存在其他的数据库中,比如PostgreSQL或MongoDB。在这 些用例中,当数据从主存储移除时,开发者经常会忘记删除Redis中对应的数据。这种存在跨数据存储的情况下,通常需要做级联删除,这种情况下,可以通过 在Redis配置保存特定数据项的所有识别符来实现,从而保证数据在主数据库被删除后,系统会调用一个清理程序来删除所有相关副本和信息。

2. 控制所有键名的长度

在上文我们说过要使用合适的命名规则,并且添加前缀来识别数据走向,因此这一条看起来似乎与之违背。但是,请别忘记,Redis是个内存数据库,键越短你需要的空间就越少。理所当然,当数据库中拥有数百万或者数十亿键时,键名的长度将影响重大。

举个例子:在一个32位的Redis服务器上,如果储存一百万个键,每个值的长度是32-character,那么在使用6-character长 度键名时,将会消耗大约96MB的空间,但是如果使用12-character长度的键名时,空间消耗则会提升至111MB左右。随着键的增多,15%的 额外开销将产生重大的影响。

3. 使用合适的数据结构

不管是内存使用或者是性能,有的时候数据结构将产生很大的影响,下面是一些可以参考的最佳实践:

取代将数据存储为数千(或者数百万)独立的字符串,可以考虑使用哈希数据结构将相关数据进行分组。哈希表是非常有效率的,并且可以减少你的内存使用;同时,哈希还更有益于细节抽象和代码可读。

合适时候,使用list代替set。如果你不需要使用set特性,List在使用更少内存的情况下可以提供比set更快的速度。

Sorted sets是最昂贵的数据结构,不管是内存消耗还是基本操作的复杂性。如果你只是需要一个查询记录的途径,并不在意排序这样的属性,那么轻建议使用哈希表。

Redis中一个经常被忽视的功能就是bitmaps或者bitsets(V2.2之后)。Bitsets允许你在Redis值上执行多个bit-level操作,比如一些轻量级的分析。

4. 使用SCAN时别使用键

从Redis v2.8开始,SCAN命令已经可用,它允许使用游标从keyspace中检索键。对比KEYS命令,虽然SCAN无法一次性返回所有匹配结果,但是却规避了阻塞系统这个高风险,从而也让一些操作可以放在主节点上执行。

需要注意的是,SCAN 命令是一个基于游标的迭代器。SCAN 命令每次被调用之后, 都会向用户返回一个新的游标,用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数, 以此来延续之前的迭代过程。同时,使用SCAN,用户还可以使用keyname模式和count选项对命令进行调整。

SCAN相关命令还包括SSCAN 命令、HSCAN 命令和 ZSCAN 命令,分别用于集合、哈希键及有续集等。

5. 使用服务器端Lua脚本

在Redis使用过程中,Lua脚本的支持无疑给开发者提供一个非常友好的开发环境,从而大幅度解放用户的创造力。如果使用得当,Lua脚本可以给 性能和资源消耗带来非常大的改善。取代将数据传送给CPU,脚本允许你在最接近数据的地方执行逻辑,从而减少网络延时和数据的冗余传输。

在Redis中,Lua一个非常经典的用例就是数据过滤或者将数据聚合到应用程序。通过将处理工作流封装到一个脚本中,你只需要调用它就可以在更短的时间内使用很少的资源来获取一个更小的答案。

专家提示:Lua确实非常棒,但是同样也存在一些问题,比如很难进行错误报告和处理。一个明智的方法就是使用Redis的Pub/Sub功能,并且让脚本通过专用信道来推送日志消息。然后建立一个订阅者进程,并进行相应的处理。

分享到:
评论

相关推荐

    Redis使用教程,详解

    Redis 使用教程详解 Redis 是一个高性能的 NoSQL 键值存储数据库,广泛应用于缓存、任务列表、网站访问统计数据、过期处理、应用...通过本教程,我们可以快速了解 Redis 的使用方法和特点,并将其应用于实际项目中。

    java中spring框架使用redis所需的5个jar包

    下面我们将详细讲解Java中Spring框架使用Redis所需的五个关键jar包及其作用。 1. **spring-data-redis** 这是Spring Data Redis项目的核心包,提供了对Redis的全面支持。它包含了一组针对Redis操作的模板类和...

    【ASP.NET编程知识】.net core使用redis基于StackExchange.Redis.docx

    在使用 Redis 之前,需要在项目中添加 StackExchange.Redis NuGet 包。可以通过 NuGet 包管理器来安装该包。安装完成后,在项目中可以使用 Redis 客户端来访问和操作 Redis。 二、修改配置文件 appsettings.json ...

    redis++使用说明,windows下编译redis-plus-plus

    通过这篇文章,我们可以了解Redis++的组件结构和编译过程,从而更好地掌握Redis++的使用方法。 Redis++是Redis的C++版本,它提供了Redis的所有功能,并且可以与Redis服务器集成。Redis++可以用于各种应用场景,包括...

    windows中使用Redis整理vs

    windows中使用Redis 里面包含Redis在页面中的使用说明和dll的代码引用说明

    C#使用redis需要用到dll

    10. **Redis持久化和主从复制**: 考虑到Redis的数据安全性,开发者还需要了解Redis的RDB和AOF两种持久化方式,以及如何配置主从复制来提高可用性。 总的来说,C#通过引入合适的DLL并与StackExchange.Redis库配合,...

    WPF操作Redis简单实例

    通过这个简单的实例,开发者可以了解到如何在WPF应用中有效地使用Redis,实现高效的数据存储和检索,同时也能够学习到如何在C#中处理Redis的各种操作和异常情况。这对于提升C#开发者的技能和理解分布式数据存储具有...

    阿里巴巴Redis使用规范

    阿里巴巴建议使用整数对象共享池来节省内存空间, Redis内部维护了0到9999个整数对象,并把这些整数作为一个共享池使用。 规范五:使用Redis保存热数据 阿里巴巴建议使用Redis保存热数据,以提高数据的访问速度。 ...

    docker拉取redis镜像并run一个容器,使用redis服务

    `docker run -p 6379:6379 -v /media/redis/data:/data -v /media/redis/conf/redis.conf/:/usr/local/etc/redis/redis.conf/ -d redis:3.2 redis-server /usr/local/etc/redis/redis.conf --appendonly yes` ...

    在Delphi环境下使用Redis

    在Delphi中,通常会创建一个新的单元,导入Redigo的头文件,并使用`CreateClient`函数创建一个Redis连接。连接参数包括服务器地址、端口、超时时间等。例如: ```pascal uses Redigo; var RedisConn: IRedis; ...

    在ASP.NET MVC中使用Redis 的Demo:通过Redis实现用户登陆,并保持登陆状态。

    在ASP.NET MVC框架中,Redis常被用作一个高效的缓存和会话存储解决方案,以提升网站性能并处理用户登录状态。本示例将详细解释如何利用Redis来实现在ASP.NET MVC应用程序中用户登录功能,并保持用户的登录状态,同时...

    C# 使用 ServiceStack.Redis 必须的4个dll

    这个标题“C# 使用 ServiceStack.Redis 必须的4个dll”表明我们将探讨使用C#集成ServiceStack.Redis时所需的四个核心组件。下面我们将详细介绍这四个组件及其在实际开发中的作用。 1. **ServiceStack.Text.dll**: ...

    REDIS_redis的工具包_redisinlabview_labviewredis_labview调用redis_redis

    5. **错误处理**:在使用过程中,应该添加适当的错误处理机制,以应对可能出现的网络问题、命令执行失败等情况。 ### 子VI和自定义功能 `SubVIs`文件夹中可能包含了工具包中一些常用操作的子VI,如数据序列化和反...

    redis简单使用实例

    然而,由于全内存特性,Redis的数据持久化是必须考虑的问题。它提供了RDB(Redis Database Backup)和AOF(Append Only File)两种持久化策略。RDB会在特定时间点生成数据快照,而AOF则记录每次写操作,确保数据安全...

    c++ 操作redis数据库

    在IT行业中,C++与Redis的结合使用是一个常见的实践,特别是在需要高性能数据存储和处理的场景下。Redis是一个开源的、基于内存的数据结构存储系统,它支持多种数据类型,如字符串、哈希、列表、集合、有序集合等,...

    Qt 应用Redis 实现消息队列

    在Qt应用中集成Redis,我们通常会使用第三方库如`QRedis`,这是一个基于Qt的Redis客户端库,它提供了一系列方便的API来操作Redis。首先,你需要将`QRedis`库添加到你的Qt项目中,可以通过配置项目文件.pro或使用...

    使用Redis存放Session RedisManager

    使用Redis存放Session RedisManager

    C#操作Redis明细内容 C#调用redis c#使用redis业务 C# Redis操作类 C#中Redis封装的类 C#

    谈下你对 Redis 的了解? 1)Redis是一种基于键值对的NoSQL数据库(非关系型数据库);是一个key-value存储系统 2)高性能、可靠性 Redis将数据存储在内存中,读写性能高;Redis提供了 RDB和AOF持久化,可将内存...

    redis程序及使用说明

    Redis是一款高性能的键值数据库,常用于数据缓存、...以上是对Redis程序及其使用的基本介绍,深入掌握Redis需要实践和对数据结构、数据库设计有深入了解。在实际应用中,合理利用Redis能极大提升系统的性能和响应速度。

Global site tag (gtag.js) - Google Analytics