为 Redis 添加 JSON 数据类型

时间:2022-05-07
本文章向大家介绍为 Redis 添加 JSON 数据类型,主要内容包括1. 简介、2. 示例、2.2)json 内部操作、3. 安装、3.2)详细安装过程、5. 小结、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

1. 简介

Redis 本身有比较丰富的数据类型,例如 String、Hash、Set、List

JSON 是我们常用的数据类型,当我们需要在 Redis 中保存 json 数据时是怎么存放的呢?

一般是用 String 或者 Hash,但还是不太方便,无法灵活的操作 json 数据

在 Redis 4.0 中,有一个重大改进:modules 模块系统,可以让我们开发新的功能,集成到 redis 中

rejson 就是一个新的模块,为 redis 提供了 json 存储能力

2. 示例

2.1)基础操作

127.0.0.1:6379> JSON.SET object . '{"foo": "bar", "ans": 42}'
OK
127.0.0.1:6379> JSON.GET object
"{"foo":"bar","ans":42}"

先看下第一条命令的含义:

  • JSON.SET 是json设置命令
  • object 是 key
  • . 是json文档的root,后面的一串是具体的 json 数据值

第二条命令是获取 key 为 object 的json数据

2.2)json 内部操作

  • 获取某字段的值
127.0.0.1:6379> JSON.GET object .ans
"42"

命令中的 .ans 是目标路径,表示 root 下面的 ans

  • 设置某字段值
127.0.0.1:6379> json.set object .name '"bill"'
OK
127.0.0.1:6379> json.get object
"{"foo":"bar","ans":42,"hi":"hello","name":"bill"}"

这个命令是在 root 下新增了一个字段 name,值为 bill

也可以修改已有字段的值,用法相同

  • 删除字段
127.0.0.1:6379> json.del object .name
(integer) 1
127.0.0.1:6379> json.get object
"{"foo":"bar","ans":42,"hi":"hello"}"

这个命令使用 del 把 root 下的 name 字段删除了

  • 数字操作

ans 字段是数字类型,值为 42,下面对其执行 +3 操作

127.0.0.1:6379> json.numincrby object .ans 3
"45"
127.0.0.1:6379> json.get object
"{"foo":"bar","ans":45,"hi":"hello"}"

还可以进行乘法操作

127.0.0.1:6379> json.nummultby object .ans 2
"90"
127.0.0.1:6379> json.get object
"{"foo":"bar","ans":90,"hi":"hello"}"

还有很多其他操作命令,具体可以查看项目文档

3. 安装

因为使用了模块功能,所以需要 redis 4.0 以上版本

3.1)安装流程

  1. 安装 redis 4.0
  2. 安装相关系统依赖
  3. 安装 rejson 模块
  4. redis 加载 rejson 模块

3.2)详细安装过程

安装 redis 4.0

wget https://github.com/antirez/redis/archive/4.0-rc2.tar.gz
tar xzf 4.0-rc2.tar.gz
cd redis-4.0-rc2/
make

安装依赖

yum groupinstall "Development Tools"

(这是 centos 中的安装方法,ubuntu 可以使用这个命令 apt-get install build-essential )

安装cmake

# wget https://cmake.org/files/v3.8/cmake-3.8.0-rc3.tar.gz
# tar -xzvf cmake-2.8.11.2.tar.gz
# cd cmake-2.8.11.2
# ./bootstrap
# make
# make install

安装 rejson 模块

git clone https://github.com/RedisLabsModules/rejson.git
cd rejson
./bootstrap.sh
cmake --build build --target rejson

安装完成后,rejson 目录中的 lib 下便会生成 rejson.so

启动 redis 时加载 rejson.so

redis-server --loadmodule /path/to/module/rejson.so

在启动信息中会看到 rejson 的相关信息

...
<ReJSON> JSON data type for Redis 
...

安装完成,可以登录 redis 执行 json 命令了

5. 小结

rejson 让我们可以在 redis 中存储和操作 json 数据,非常方便

而且通过体验 rejson 模块,还可以感受到 redis 模块系统的强大,以后将会出现各种基于redis的强大功能

rejson 项目地址:

https://redislabsmodules.github.io/rejson/