来源:http://t.cn/EUNMtiM
Redis 本身有比较丰富的数据类型,例如 String、Hash、Set、List
JSON 是我们常用的数据类型,当我们需要在 Redis 中保存 json 数据时是怎么存放的呢?
一般是用 String 或者 Hash,但还是不太方便,无法灵活的操作 json 数据
在 Redis 4.0 中,有一个重大改进:modules 模块系统,可以让我们开发新的功能,集成到 redis 中
rejson
就是一个新的模块,为 redis 提供了 json 存储能力
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数据
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\"}"
还有很多其他操作命令,具体可以查看项目文档
因为使用了模块功能,所以需要 redis 4.0 以上版本
安装 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 命令了
rejson 让我们可以在 redis 中存储和操作 json 数据,非常方便
而且通过体验 rejson 模块,还可以感受到 redis 模块系统的强大,以后将会出现各种基于redis的强大功能
rejson 项目地址:
https://redislabsmodules.github.io/rejson/