Redis 入门教程

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis 入门教程

Redis 安装

  • 安装依赖
yum install -y gcc tcl
  • 上传安装包并解压
tar -zxvf redis-6.2.6.tar.gz
链接: https://pan.baidu.com/s/1uBw8qC2JMcbagrX7U9mlOA 提取码: wbs6
  • 编译
make && make install

Redis 启动

  • 前台启动
redis-server
  • 指定配置文件启动

    • 备份
    cp redis.conf redis.conf.bck
    • 修改配置文件
    # 允许访问地址
    bind 0.0.0.0
    # 日志输出
    logfile "redis.log"
    # 密码
    requirepass ruochen666
  • 使用 systemctl 配置
vim /etc/systemd/system/redis.service

# 写入内容如下
[Unit]
Description=redis-server
After=network.target

[Service]
Type=forking
ExecStart=/usr/local/bin/redis-server /usr/local/src/redis-6.2.6/redis.conf
PrivateTmp=true

[Install]
WantedBy=multi-user.target

# 重载系统服务
systemctl daemon-reload

Redis 命令

通用命令(generic)

  • keys:查看符合模板的所有 key,不建议在生产环境设备上使用
  • del:删除指定的 key
  • exists:判断 key 是否存在
  • expire:给 key 设置有效期,有效期到期时该 key 会被自动删除
  • ttl:查看 key 的剩余有效期

String 类型

  • set:添加/修改已经存在的一个 String 类型的键值对
  • get:根据 key 获取 String 类型的 value
  • mset:批量添加
  • mget:批量获取
  • incr:让一个整型的 key 自增 1
  • incrby:让一个整型的 key 自增并指定步长 incrby num 2:num 自增 2
  • incrbyfloat:浮点数自增长(必须指定增长步长)
  • setnx:添加一个 String 类型的键值对(前提是这个 key 不存在,否则不执行)
  • setex:添加一个 String 类型的键值对,并且指定有效期

Key 的层级结构

  • Redis 的 key 允许有多个单词形成层级结构,多个单词之间用 : 隔开,例如 项目名:业务名:类型:id
  • 例如项目名称为 ruochen,有 userproduct 两种不同类型的数据,我们可以这样定义 key:

    • user 相关的 key:ruochen:user:1
    • product 相关的 key:ruochen:product:1
set ruochen:user:1 '{"id":1, "name":"Jack", "age": 21}'
set ruochen:user:2 '{"id":2, "name":"Rose", "age": 18}'
set ruochen:product:1 '{"id":1, "name":"小米11", "price": 4999}'
set ruochen:product:2 '{"id":2, "name":"荣耀6", "price": 2999}'

在这里插入图片描述

Hash 类型

  • Value 是一个无序字典,类似于 Java 中的 HashMap 结构
  • String 结构存储的是对象序列化后的 json 数据,修改某个字段很不方便
  • Hash 结构可以将对象中的每个字段独立存储,可以针对单个字段做 CRUD(相对于 String 结构更加灵活)
  • 常用命令

    • hset key field value:添加/修改 hash 类型 key 的 field 的值,eg:hset ruochen:user:3 name Lucy
    • hget key field:获取一个 hash 类型 key 的 field 值,eg:hget ruochen:user:3 name
    • hmset:批量新增,eg:hmset ruochen:user:4 name Tom age 22 sex man
    • hmget:批量获取,eg:hmget ruochen:user:4 name age sex
    • hgetall:获取一个 hash 类型的 key 中的所有的 field 和 value,eg:hgetall ruochen:user:4
    • hkeys:获取一个 hash 类型的 key 中所有的 field,eg:hkeys ruochen:user:4
    • hvals:获取一个 hash 类型的 key 中所有的 value,eg:hvals ruochen:user:4
    • hincrby:让一个 hash 类型 key 的字段值自增长并指定步长,eg:hincrby ruochen:user:4 age 2
    • hsetnx:添加一个 hash 类型的 key 的 field 值(前提是这个 field 不存在,否则不执行)

List 类型

  • Redis 中的 List 类型与 Java 中的 LinkedList 类似,可以看作是一个双向链表架构(既支持正向检索,也支持反向检索)
  • 特征

    • 有序
    • 元素可以重复
    • 插入和删除快
    • 查询速度一般
  • 使用场景:朋友圈点赞列表,评论列表等
  • 常用命令

    • lpush key element ...:向列表左侧插入一个或多个元素(队首),eg:lpush users 1 2 3
    • lpop key:移除并返回列表左侧的第一个元素,没有则返回 nil,eg:lpop users 1
    • rpush key element ...:向列表右侧插入一个或多个元素(队尾),eg:rpush users 4 5 6
    • rpop key:移除并返回列表右侧的第一个元素,没有则返回 nil,eg:rpop users 1
    • lrange key start end:返回一段角标范围内的所有元素(角标从 0 开始),eg:lrange users 1 2
    • blpop 和 brpop:与 lpop 和 rpop 类似,只不过在没有元素时等待指定时间,而不是直接返回 nil,eg:blpop users2 100 lpush users2 jack
  • 如何利用 list 结构模拟一个栈?

    • 入口和出口在同一边
    • lpush + lpop 或者 rpush + rpop
  • 如何利用 list 结构模拟一个队列?

    • 入口和出口在不同边
    • lpush + rpop 或者 rpush + lpop
  • 如何利用 list 结构模拟一个阻塞队列?

    • 入口和出口在不同边
    • 出对时采用 blpopbrpop

Set 类型

  • Redis 的 Set 结构与 Java 中的 HashSet 类似,可以看作是一个 value 为 null 的 HashMap。因为也是一个 hash 表,因此具备与 HashSet 类似的特征

    • 无序
    • 元素不可重复
    • 查找快
    • 支持交集、并集、差集等功能
  • 常用命令

    • sadd key member ... :向 set 中添加一个或多个元素,eg:sadd s1 a b c
    • srem key member ... :移除 set 中的指定元素,eg:srem s1 a
    • scard key:返回 set 中元素的个数,eg:scard s1
    • sismember key member:判断一个元素是否存在于 set 中,eg:sismember s1 a
    • smembers:获取 set 中的所有元素,eg:smembers s1
    • sinter key1 key2 ... :求 key1 和 key2 的交集
    • sdiff key1 key2 ... :求 key1 和 key2 的差集
    • sunion key1 key2 ... :求 key1 和 key2 的并集

SortedSet 类型

  • 可排序集合,与 Java 中的 TreeSet 有些类似,但底层数据结构却差别很大。SortedSet 中的每一个元素都带有一个 score 属性,可以基于 score 属性对元素排序,底层的实现是一个跳表(SkipList)加 hash 表
  • 特性

    • 可排序
    • 元素不重复
    • 查询速度快
  • 应用场景:排行榜
  • 常用命令

    • zadd key score member:添加一个或多个元素到 sorted set,如果已经存在则更新其 score 值,eg:zadd stus 85 Jack 89 Lucy 82 Rose 95 Tom 78 Jerry 92 Amy 76 Miles
    • zrem key member:删除 sorted set 中的一个指定元素,eg:zrem stus Tom
    • zscore key member:获取 sorted set 中的指定元素的 score 值
    • zrank key member:获取 sorted set 中指定元素的排名,eg:zrevrank stus Rose
    • zcard key:获取 sorted set 中的元素个数,eg:zcard stus
    • zcount key min max:统计 score 值在给定范围内的所有元素的个数,eg:zcount stus 0 80
    • zincrby key increment member:让 sorted set 中的指定元素自增,步长为指定的 increment 值,eg:zincrby stus 2 Amy
    • zrange key min max:按照 score 排序后,获取指定排名范围内的元素,eg:zrevrange stus 0 2
    • zrangebyscore key min max:按照 score 排序后,获取指定 score 范围内的元素,eg:zrangebyscore stus 0 80
    • zdiff、zinter、zunion:求差集、交集、并集
所有的排名默认都是升序,如果要降序则命令的 z后面添加 rev即可
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
4月前
|
存储 消息中间件 NoSQL
百度搜索:蓝易云【超详细Redis入门教程—Redis分布式系统详解】
这些是Redis入门教程的主要内容,涵盖了Redis的基本使用和分布式系统的详解。通过学习和实践,你可以进一步深入了解Redis的各种功能和用法,为实际应用场景做
143 0
|
XML NoSQL 数据可视化
Spring boot整合Redis(入门教程)
jedis:采用直连,多个线程操作的话,是不安全的。如果想要避免不安全的,使用jedis pool连接池!更像BIO模式 lettuce:采用netty,实例可以在多个线程中进行共享,不存在线程不安全的情况,可以减少线程数据,更像NIO模式
222 0
Spring boot整合Redis(入门教程)
|
存储 监控 负载均衡
Redis主从复制详解(入门教程)
主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(master/leader),后者称为从节点(slave/follower) ; <font color='blue'>数据的复制是单向的,只能由主节点到从节点。</font>Master以写为主,Slave以读为主。
261 0
Redis主从复制详解(入门教程)
|
存储 NoSQL JavaScript
|
存储 缓存 NoSQL
很详细Redis入门教程
这篇文章主要介绍了很详细Redis入门教程,本文详细介绍了Redis数据库各个方面的知识,需要的朋友可以参考下 【redis是什么】 redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库。 redis的官网地址,非常好记,是redis.io。(特意查了一下,域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地) 目前,Vmware在资助着redis项目的开发和维护。 【redis的作者何许人也】 开门见山,先看照片: 是不是出乎了你的意料,嗯,高手总会有些地方与众不同的。 这
186 0
|
NoSQL C# 数据库
Redis入门教程(C#)
Redis是什么? Redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库。 补充概念: 持久化:是将程序数据在持久状态和瞬时状态间转换的机制。通俗的讲,就是瞬时数据(比如内存中的数据,是不能永久保存的)持久化为持久数据(比如持久化至数据库中,能够长久保存) Redis的安装、启动: 下载地址:https://github.com/MSOpenTech/redis/releases,可根据需要选择下载32位或者64位 这里我选择的是64位安装包: 然后解压安装包到指定目录。
1711 0
|
17天前
|
NoSQL Linux Redis
06- 你们使用Redis是单点还是集群 ? 哪种集群 ?
**Redis配置:** 使用哨兵集群,结构为1主2从,加上3个哨兵节点,总计分布在3台Linux服务器上,提供高可用性。
251 0

热门文章

最新文章