Redis_非关系型数据库

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
应用实时监控服务-用户体验监控,每月100OCU免费额度
简介: 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
相关文章
|
4月前
|
canal 缓存 NoSQL
Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案
根据对一致性的要求程度,提出多种解决方案:同步删除、同步删除+可靠消息、延时双删、异步监听+可靠消息、多重保障方案
Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案
|
6月前
|
缓存 NoSQL Java
Redis 缓存与数据库数据不一致问题
Redis 缓存与数据库数据不一致问题
118 3
|
4月前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
729 2
|
5月前
|
SQL 存储 NoSQL
Redis6入门到实战------ 一、NoSQL数据库简介
这篇文章是关于NoSQL数据库的简介,讨论了技术发展、NoSQL数据库的概念、适用场景、不适用场景,以及常见的非关系型数据库。文章还提到了Web1.0到Web2.0时代的技术演进,以及解决CPU、内存和IO压力的方法,并对比了行式存储和列式存储数据库的特点。
Redis6入门到实战------ 一、NoSQL数据库简介
|
5月前
|
存储 缓存 NoSQL
Redis内存管理揭秘:掌握淘汰策略,让你的数据库在高并发下也能游刃有余,守护业务稳定运行!
【8月更文挑战第22天】Redis的内存淘汰策略管理内存使用,防止溢出。主要包括:noeviction(拒绝新写入)、LRU/LFU(淘汰最少使用/最不常用数据)、RANDOM(随机淘汰)及TTL(淘汰接近过期数据)。策略选择需依据应用场景、数据特性和性能需求。可通过Redis命令行工具或配置文件进行设置。
111 2
|
5月前
|
JSON NoSQL Redis
Redis 作为向量数据库快速入门指南
Redis 作为向量数据库快速入门指南
246 1
|
6月前
|
缓存 NoSQL 数据库
Redis问题之在高并发场景下,保证Redis缓存和数据库的一致性如何解决
Redis问题之在高并发场景下,保证Redis缓存和数据库的一致性如何解决
186 3
|
5月前
|
网络协议 NoSQL 网络安全
【Azure 应用服务】由Web App“无法连接数据库”而逐步分析到解析内网地址的办法(SQL和Redis开启private endpoint,只能通过内网访问,无法从公网访问的情况下)
【Azure 应用服务】由Web App“无法连接数据库”而逐步分析到解析内网地址的办法(SQL和Redis开启private endpoint,只能通过内网访问,无法从公网访问的情况下)
|
5月前
|
存储 缓存 NoSQL
基于SpringBoot+Redis解决缓存与数据库一致性、缓存穿透、缓存雪崩、缓存击穿问题
这篇文章讨论了在使用SpringBoot和Redis时如何解决缓存与数据库一致性问题、缓存穿透、缓存雪崩和缓存击穿问题,并提供了相应的解决策略和示例代码。
86 0
|
6月前
|
存储 消息中间件 NoSQL
Redis 和 数据库区别
【7月更文挑战第12天】
68 0