前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >为 Redis 添加 JSON 数据类型

为 Redis 添加 JSON 数据类型

作者头像
dys
发布2018-04-04 14:27:01
12.6K0
发布2018-04-04 14:27:01
举报
文章被收录于专栏:性能与架构性能与架构

1. 简介

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

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

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

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

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

2. 示例

2.1)基础操作

代码语言:javascript
复制
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 内部操作

  • 获取某字段的值
代码语言:javascript
复制
127.0.0.1:6379> JSON.GET object .ans
"42"

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

  • 设置某字段值
代码语言:javascript
复制
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

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

  • 删除字段
代码语言:javascript
复制
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 操作

代码语言:javascript
复制
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\"}"

还可以进行乘法操作

代码语言:javascript
复制
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

代码语言:javascript
复制
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

安装依赖

代码语言:javascript
复制
yum groupinstall "Development Tools"

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

安装cmake

代码语言:javascript
复制
# 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 模块

代码语言:javascript
复制
git clone https://github.com/RedisLabsModules/rejson.git
cd rejson
./bootstrap.sh
cmake --build build --target rejson

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

启动 redis 时加载 rejson.so

代码语言:javascript
复制
redis-server --loadmodule /path/to/module/rejson.so

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

代码语言:javascript
复制
...
<ReJSON> JSON data type for Redis 
...

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

5. 小结

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

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

rejson 项目地址:

代码语言:javascript
复制
https://redislabsmodules.github.io/rejson/
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-03-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 JAVA高性能架构 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 简介
  • 2. 示例
    • 2.1)基础操作
      • 2.2)json 内部操作
      • 3. 安装
        • 3.1)安装流程
          • 3.2)详细安装过程
          • 5. 小结
          相关产品与服务
          云数据库 Redis
          腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档