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分钟完成数据库上云实战!/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1天前
|
缓存 NoSQL 算法
17- 数据库有1000万数据 ,Redis只能缓存20w数据, 如何保证Redis中的数据都是热点数据 ?
保证Redis中的20w数据为热点数据,可以通过设置Redis的LFU(Least Frequently Used)淘汰策略。这样,当数据库有1000万数据而Redis仅能缓存20w时,LFU会自动移除使用频率最低的项,确保缓存中的数据是最常使用的。
67 8
|
1天前
|
存储 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(下)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
8 1
|
1天前
|
监控 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(上)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
22 0
|
1天前
|
存储 NoSQL 调度
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(下)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
7 0
|
1天前
|
NoSQL 安全 Unix
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(中)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
15 0
|
1天前
|
存储 NoSQL API
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(上)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
15 1
|
1天前
|
消息中间件 NoSQL OLAP
doris数据库是否可以替代redis
【4月更文挑战第20天】doris数据库是否可以替代redis
288 0
|
1天前
|
NoSQL MongoDB Redis
Python与NoSQL数据库(MongoDB、Redis等)面试问答
【4月更文挑战第16天】本文探讨了Python与NoSQL数据库(如MongoDB、Redis)在面试中的常见问题,包括连接与操作数据库、错误处理、高级特性和缓存策略。重点介绍了使用`pymongo`和`redis`库进行CRUD操作、异常捕获以及数据一致性管理。通过理解这些问题、易错点及避免策略,并结合代码示例,开发者能在面试中展现其技术实力和实践经验。
320 8
Python与NoSQL数据库(MongoDB、Redis等)面试问答
|
1天前
|
存储 缓存 NoSQL
Redis 服务器指南:高性能内存数据库的完整使用指南
Redis 服务器指南:高性能内存数据库的完整使用指南
|
1天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
19 0
http://www.vxiaotou.com