Redis_非关系型数据库

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: Redis_非关系型数据库

一、 Redis介绍

1.NoSQL

也叫Not Only SQL(不仅仅是SQL, 不用 sql语言操作的数据库), 一般指非关系型数据库

关系型数据库: 以数据库表为单位存储,表与表之间存在某种关系
非关系型数据库: 数据与数据之间没有关系, 数据就是以键值对的形式存储, 通过键获取到值

在互联网发展中:
大致经历三个时期,web1.0,web2.0,web3.0

web1.0:他是静态网页, 数据在网页就写死的, 数据直接在html里,每次更新, 都要更改html代码

web2.0:这时候就是动态页面了, 数据存放在数据库里面, 页面显示的数据可以从数据里动态获取

web3.0: 由于越来越多的用户参与到信息的构建流程里, 比如:抖音,头条用户都可以自己创建自己的信息, 又或者是节假日的商品抢购,秒杀,信息量爆炸, 就会导致传统的系统架构支撑不起来, 存在问题

由于关系型数据库存储在硬盘上, 查询需要与硬盘发生IO( 读取操作 ), 在一瞬间, 有当量用户访问时, 关系型数据库就会崩溃
优点:

1.存储在内存中, 读写非常快
2.数据结构简单(键值形式)
3.高性能, 一秒可以读写数量级上万
4.支持数据持久化(就是数据备份到硬盘上, 也是键值对)

二、Linux 上安装Redis

首先在网上下载redis.tar.gz的源码包
可以点击这里直接下载

  1. 下载源码包

    下载源码包有两种方式

    1>由传输根据xftp-7工具来传输

    2>由linux通过网站来直接下载

    进入到opt目录,opt目录是linux安装软件的文件夹
    使用命令:
    cd /opt 进入到opt目录
    wget https://download.redis.io/releases/redis-6.2.4.tar.gz通过官网下载
    在这里插入图片描述

  1. 解压源码包
    进入到源码包的下载目录opt后, 再解压源码包
    使用命令:
    tar -zxvf redos-6.0.8.tar.gz来解压源码包`
  2. 编译源码包在这里插入图片描述

进入opt目录后,进入解压后的redis里进行编译
命令:
cd redis-6.0.8 进入源码包
make 进行编译

  1. 安装指定位置
    命令:
    mkdir -p /opt/redis 创建安装目录
    make install PEOFIX=/opt/redis 安装指定目录

  2. 启动redis服务

命令:
cd /opt/redis/bin进入到redis的bin目录里
./redis-server启动redis数据库

在这里插入图片描述

三、Redis里的基本设置

  1. 首先启动Redis后如果要输入指令, 就按Ctr+c
    之后Redis就会关闭, 不会在后天启动
    所以就要设置Redis启动后, 放在后台

如图启动之后,Ctr+C进入命令操作Redis就会结束进程
在这里插入图片描述

命令:
cd /opt/redis-6.0.8/ 进入到源码包里
在这里插入图片描述

cp redis.conf /opt/redis/bin 复制源码里的配置文件到安装的位置里
vim redis.conf编辑redisconf文件(此时是修改安装Redis里的配置文件)

redis.conf文件图示:
在这里插入图片描述

接下来注意修改的位置:

  1. 注释bind 127.0.01
    在这里插入图片描述
  2. 设置远程访问
    daemonize on改为 daemonize yes在这里插入图片描述
  3. 设置密码在这里插入图片描述
    注意: 由于密码在下方, 配置文件又特别长, 所以可以在编辑器里通过搜索模式来查
    在命令模式里
    /查找单词 再点击回车 就可以直接到搜索的那个单词的地方
    点击n是下一个关键单词,N是上一个单词
  1. 配置完成之后就可以开启Redis服务器了
    命令:
    cd /opt/redis/bin 去安装redis目录下的bin文件里
    ./redis-server redis.conf
    ps -ef | grep redis 检查一下redis是否运行

在这里插入图片描述
redis已运行成功

  1. 结束redis进程
    命令:
    kill -9 进程号 结束进程操作
  2. 进入数据库
    命令:
    ./redis-cli
    aurth 密码 输入密码
    ping
    当返回PONG时就说明进入数据库成功

四、Redis的数据类型

redis有五种数据类型

String , Hash ,List , set , zset五种
redis是以键值对存储, 键都是String类型的, 值是所说的5种

在这里插入图片描述

1) String类型

虽然名叫String , 但是他可以存储图片(base64格式) ,对象(json格式)
set 键 值 存值
get 键 值 获取值
del 键 值 删值

1>单值缓存
set user {name:tom,age:20}

2>对象缓存(不对对象里的值进行操作时使用)
在这里插入图片描述

keys * 列出所有 键
在这里插入图片描述

3>计数器

新闻点赞时, 使用计数器来计数
set newsid:1 0 存值, 键是newsid:1 ,值是0
incr newsid:1 值+1
decr newsid:1 值-1
get newsid:1 获取键newsid:1的值

在这里插入图片描述
注意: 计数器后面的值必须是int类型

  1. Hash类型

    Redis里的Hash类型存储的是String 类型的 field value 的映射表, 存储的是(可修改的)对象,存的是字符串与字符串之间的映射信息
    用我的来说就是, 键 : (键: 值), 值又是一个键值对

hset key field value 储存一个哈希表key的键值
hmset key field value [field value...] 存储多个键值对
hget key field获取单个键的值
hget key field [field ...]获取多个键的值
hdel key field [field ...]删除哈希表key的field键值
hlen users 获取users的键对应的field value 的数量
hgetall users 获取users键对应的所有 键值对
在这里插入图片描述

hincrby key file 改变值 改变field对应的值
如果是减小,改变值就是负数
在这里插入图片描述

  1. List类型
    Ridis里的List是最简单的字符串列表

lpush key value [value...] 插入一个或多个value到列表的表头
rpush key value [value...] 插入一个或多个value到列表的表尾
lpop key value 移除返回列表key的头元素
rpop key value 移除返回列表key的尾元素
lrange key start stop 返回区间start stop的元素, 包括start, stop在这里插入图片描述

列表实现栈和队列:

栈:Stack=lpush+lpop
Queue= lpush+rpop

  1. Set类型
    Set类型的数据没有无顺序,不可重复

sadd key member [member]往key集合存储值
srem key member [member]删除key集合里的member值
smembers key 获取集合key的所有元素

  1. Zset

    Zset集合的数据有序,不可重复
    Zset集合会为每一个数据关联一个分数, 按照这个分数从小到大来排序
    zset的集合元素时唯一的, 关联分数可以重复

zadd key scord member[score member...]向集合key添加分数score的元素member
zrem key member[member...]删除集合key的元素
zscore key member 查询集合key里的元素member的分数score
zincrrby key num member向集合key里的元素member的score添加num,并返回score
zcard key 查询集合key的元素总数
zrange key start stop 查询集合key 从start 到stop的元素
在这里插入图片描述

五、设置数据的失效时间

有时候, 我们需要给数据设置失效时间, 数据存着只会占用空间
例如:验证码...
redis可以通过一些命令, 能够设置数据的过期时间, 过期后数据自动删除

在这里插入图片描述
EX 表示秒
PX表示毫秒 (PX,EX不区分大小写)
如: set name jim ex 30 30 秒失效

相关实践学习
基于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
相关文章
|
18天前
|
NoSQL 安全 Unix
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(中)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
23 0
|
2天前
|
存储 NoSQL 关系型数据库
redis 数据库的安装及使用方法
redis 数据库的安装及使用方法
|
5天前
|
存储 缓存 NoSQL
Redis与数据库同步指南:订阅Binlog实现数据一致性
本文由开发者小米分享,探讨分布式系统中的一致性问题,尤其是数据库和Redis一致性。文章介绍了全量缓存策略的优势,如高效读取和稳定性,但也指出其一致性挑战。为解决此问题,提出了通过订阅数据库的Binlog实现数据同步的方法,详细解释了工作原理和步骤,并分析了优缺点。此外,还提到了异步校准方案作为补充,以进一步保证数据一致性。最后,提醒在实际线上环境中需注意日志记录、逐步优化和监控报警。
32 3
|
10天前
|
NoSQL 关系型数据库 数据库
Redis -- 数据库管理
Redis -- 数据库管理
20 0
|
18天前
|
存储 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(下)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
233 1
|
18天前
|
监控 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(上)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
281 0
|
18天前
|
存储 NoSQL 调度
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(下)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
18 0
|
18天前
|
存储 NoSQL API
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(上)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
26 1
|
18天前
|
消息中间件 NoSQL OLAP
doris数据库是否可以替代redis
【4月更文挑战第20天】doris数据库是否可以替代redis
305 0
|
16天前
|
关系型数据库 MySQL API
实时计算 Flink版产品使用合集之可以通过mysql-cdc动态监听MySQL数据库的数据变动吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
124 0