Redis 学习笔记 - 入门篇

本贴最后更新于 3163 天前,其中的信息可能已经沧海桑田

Redis 是什么?

Redis(REmote DIctionary Server 远程字典服务器)是一个开源的使用 ANSI C 语言编写的 、支持网络、可基于内存亦可持久化的日志型、字典型结构的数据库(非关系型)。

解释一下定义,所谓的字典型,也就是我们常见的 Key-Value 结构。允许其他应用通过 TCP 协议读写字典中的内容。Redis 数据库的所有数据都存储在内存中,因此读写速度异常迅速,每秒大约能执行 10 万次左右的键值读写,对应的也有持久化到硬盘的功能。

Redis 的特性/优点:

1、存储结构

采用字典数据类型(Key-Value).
Redis 的目前支持的数据类型共有 5 种:

  • 字符串类型(Strings)
  • 散列类型(Hashes)
  • 列表类型(Lists)
  • 集合类型(Sets)
  • 有序集合类型(Ordered Sets)

2、内存存储与持久化

Redis 数据库的所有数据都存储在内存中,由于内存相对于硬盘读写速度的差异,Redis 的读写速度相对也有了非常明显的优势。断电或程序退出时,将所有数据持久化到硬盘中。

3、功能丰富

Redis 虽然是作为数据库开发的,但是更多的是用于缓存或队列。

  • 用作缓存
    Redis 可以设置 TTL(Time To Live 生存时间),过期自动删除。也可以限制数据占用最大内存,超出后根据设定规则删除不需要的 Key-Value。

  • 用作队列
    支持阻塞式读取,也支持发布/订阅消息模式。

4、简单稳定

  • 结构简单
    Key-Value 形式。

  • 交互简单
    采用命令读写数据,如

#添加了一个 Key 为 hello,Value 为 sheng 的键值对
set hello sheng
#读取该键值对
get sheng

对比关系型数据库的SQL语句,确实方便许多。
  • 操作具有原子性
    所有 Redis 操作都是原子操作,这确保如果两个客户端并发访问,Redis 服务器能接收更新的值。

下载和安装

Redis 官方是不支持 windows 的,但是 Microsoft Open Tech group 在 GitHub 上开发了一个 Win 64 位系统上可以运行的分支版本,项目地址是:https://github.com/MSOpenTech/redis

笔者是在 win7 下学习的,具体的安装过程请参考 http://blog.csdn.net/renfufei/article/details/38474435,下载 .zip 文件,解压后有如下可执行文件,直接可用。

redis-benchmark.exe #基准测试
redis-check-aof.exe #aof 文件修复工具
redis-check-dump.exe #rdb 文件检查工具
redis-cli.exe #客户端
redis-server.exe #服务器
redis.windows.conf #配置文件

Linux 下请参考:https://redis.io/download

入门

安装成功后,接下来就开始尝试 Redis 的使用吧。

1、启动和停止

A、直接到解压的目录下双击 redis-server.exe 启动

B、笔者建议在 CMD 上采用指令操作。

cd d:/soft/redis3.2
redis-server

这样 redis 服务器就启动了,redis 还提供了 redis-cli.exe 命令行客户端。如果服务启动了,打开此客户端上就会显示现在的服务器地址和端口。

redis 提供了测试连接的命令:ping,如果连接成功,则会返回 pong

127.0.0.1:6279>ping
pong

redis 的默认端口号是 6379,要修改端口号命令:

redis-server --port 8080

端口修改后,客户端访问命令:

redis-cli -p 8080

redis 默认是没有访问密码的,要设置 redis 密码访问,命令如下:

#将 redis 的访问密码设为 123456
redis-server --requirepass 123456

修改密码后,客户端访问命令:

redis-cli -a 123456

如果密码错误,客户端上还是显示正确的服务器地址和端口,但是访问时就会收限制:

redis-cli -a 123456
(error)NOAUTH Authentication required.

此外,还有另外一种方式。我们可以发现.zip 文件解压出来的文件中有一个 redis.windows.conf 文件,启动 redis 时,也可以采用 redis.windows.conf 中的配置来启动,端口,访问密码可以在文件中修改,然后通过如下命令启动:

redis-server redis.windows.conf

当然指定了配置文件后,我们也还是可以通过命令在当次服务启动时覆盖配置文件的配置,但不会修改配置文件的值,如:

#redis 的日志等级由低到高是 debug>verbose>notice>warning ,默认的日志等级是 notice,
redis-server redis.windows.conf --loglevel warning

停止 redis 服务,只要在命令客户端中输入如下命令:

127.0.0.1:6279>shutdown

此后我们的操作都通过 redis-cli.exe 命令行客户端来执行。

2、配置

上面提到了 redis 启动时可以在命令中指定配置,也可以使用配置文件中的配置。

在命令客户端中,还有一种命令可以修改 redis 配置,且无需重启 redis 服务器。命令如下:

127.0.0.1:6279>config set loglevel warning

查询配置信息的命令如下:

127.0.0.1:6279>config get configname

3、多数据库

redis 实际上默认提供了 16 个数据库来存储字典结构的数据,编号由 0-15,默认使用 0.redis 不支持自定义数据库名字,也不支持为每个数据库设置不同的密码。这些数据库并不是完全隔离的,如 flushall 命令可以清空所有数据库的数据。
因此不建议一个 redis 数据库实例用于不同的应用。
如下命令可以选择数据库:

127.0.0.1:6279>select 1
127.0.0.1:6279>get hello
(nil)
127.0.0.1:6279>select 0
127.0.0.1:6279>get hello
"sheng"

4、基础指令

1、查询当前库中所有 key。key 支持 glob 风格的通配符匹配。

?:匹配一个字符
*:匹配任意个(包括0个)字符
[]:匹配区间内的任一字符
\x:转译字符,如要匹配?则使用\?

127.0.0.1:6279>keys pattern

2、判断 key 是否存在,存在返回 1,不存在返回 0.

127.0.0.1:6279>exists key

3、删除 key

127.0.0.1:6279>del key

4、获得 key 的类型,返回的值可能为:string(字符串),list(列表),hash(散列),set(集合),zset(有序集合)

127.0.0.1:6279>type key

5、字符串类型

字符串类型是 redis 中最基本的类型,能存储任何形式的字符串,包括二进制,json 甚至图片。一个字符串类型的最大容量是 512M。

A、赋值和取值【set key/get key】

#添加一个字符串类型键值对

127.0.0.1:6279>set key val

ok

#根据 key 读取键值

127.0.0.1:6279>get key

val

B、数字递增/递减【incr key/decr key】

如果字符串是整数形式,redis 提供了指定键值递增/递减的命令:

#如果 key 不存在,则默认值为 0,然后执行递增操作,返回的值为 1

127.0.0.1:6279>incr key

(integer)1

#如果值不是整数,则提示错误

127.0.0.1:6279>set key test

127.0.0.1:6279>incr key

(error) ERR value is not an integer or out of range

这里值得一提的是,因为 redis 的原子性,如果有多个应用同时对一个 key 执行递增操作,则会各自自增一次,两个应用得到的分别是 1 和 2.

C、整数加法/减法【incrby key num/ decr key num】

127.0.0.1:6279>set num 1

127.0.0.1:6279>incrby num 3

(integer) 4

D、浮点数加法/减法【incrbyfloat key float/decrbyfloat key float】

127.0.0.1:6279>set num 1

127.0.0.1:6279>incrbyfloat num 2.22

"3.22"

E、字符串拼接【append key val】

127.0.0.1:6279>set string a

127.0.0.1:6279>append string ppend

"append"

#拼接多个单词或需要空格隔开的,需要加上引号

127.0.0.1:6279>append string " with many words"

"append with many words"

F、获取字符串长度【strlen key】

127.0.0.1:6279>set string sheng

(integer) 5

127.0.0.1:6279>set string 盛

#redis 中中文用 utf-8 编码,一个中文的长度是 3 字节

(integer) 2

对于中文读写,可能会遇到显示的是如下的 16 进制字符串:

127.0.0.1:6279>set key 你好

127.0.0.1:6279>get key

"\xc4\xe3\xba\xc3"

遇到这种情况,可使用如下命令,解决中文字符的问题:

redis-cli --raw

G、批量读取/批量赋值【mget key1 key2 .../mset key1 val1 key2 val2...】

127.0.0.1:6279>mset one 1 two 2 three 3

ok

127.0.0.1:6279>mget one two

1

2

H、位操作

redis 中提供了 4 个命令用于二进制位操作。redis 存储的是 ASCII 二进制码。

#获取指定二进制位的值(0/1),如果指定的位数超过 key 值的二进制总长度,则返回 0

getbit key offset

#设置指定二进制位的值,返回修改位的旧值

setbit key offset val

#获取指定字节范围的 1 的数量

bitcount key begin end

#二进制与、或、非、异或操作

bitop and/or/not/xor result key1 key2

下面我们来看几个例子:

#a 的 ASCII 码为 97,二进制码为 01100001,b 的 ASCII 码为 98,二进制码为 01100010

127.0.0.1:6279>mset key1 a key2 b

127.0.0.1:6279>getbit key1

(integer) 3

#修改 a 的左起第七位,将 0 改为 1,即将 a 改为 c

127.0.0.1:6279>setbit key1 6 1

(integer) 0

127.0.0.1:6279>get key1

"c"

127.0.0.1:6279>bitcount key1

(integer) 4

#对 c 和 b 的二进制进行与操作,结果(二进制结果为 01100010)存在 key0 中

127.0.0.1:6279>bitop and key0 key1 key2

127.0.0.1:6279>get key0

"b"

6、散列操作

散列适合用于存储对象,一个 key 下可以设有多个字段和对应的字段值。需要注意的是散列的字段只能是字符串类型。

一个散列类型的 key 最多可以有 2E32-1 个字段。

A、赋值与取值【hset key field value/hget get field】

#当 key 中没有字段时,赋值返回值为 1,如果存在,则更新字段值,返回 0

127.0.0.1:6279>hset key car color white

(integer) 1

127.0.0.1:6279>hset key car color black

(integer) 0

B、批量赋值与取值【hmset key field1 val1 field1 val2/hmget key field1 field2/hgetall key】

127.0.0.1:6279>hmset key car color white brand ford

ok

127.0.0.1:6279>hget key car color brand

"color"

"black"

"brand"

"ford"
#查询散列健的所有字段值
127.0.0.1:6279>hgetall car

"color"

"black"

"brand"

"ford"

持续更新中......

  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    285 引用 • 248 回帖 • 2 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • smart

    2、内存存储与持久化

    Redis 数据库的所有数据都存储在内存中,由于内存相对于硬盘读写速度的差异,Redis 的读写速度相对也有了非常明显的优势。断电或程序退出时,* 将所有数据持久化到硬盘中* 这个测试过吗?

  • someone

    程序退出测试过,断电没测过,具体没有详细研究,目前了解到的redis是有断电数据保护的机制

推荐标签 标签

  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 133 关注
  • CodeMirror
    2 引用 • 17 回帖 • 197 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 55 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 662 关注
  • Folo

    Folo 是一个 RSS 阅读和信息聚合应用,整合多种内容源到统一时间线。

    项目地址:https://github.com/RSSNext/Folo

    1 引用 • 3 回帖 • 2 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 650 关注
  • 千千插件

    千千块(自定义块 css 和 js)
    可以用 ai 提示词来无限创作思源笔记

    32 引用 • 69 回帖
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    5 引用 • 16 回帖 • 3 关注
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    285 引用 • 1988 回帖
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    43 引用 • 130 回帖 • 259 关注
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 17 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    168 引用 • 598 回帖
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 193 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    213 引用 • 2044 回帖
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 669 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 152 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    176 引用 • 544 回帖
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 429 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖 • 1 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 548 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    25 引用 • 373 回帖 • 4 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    79 引用 • 431 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 443 关注
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 548 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    28446 引用 • 119790 回帖