Redis_非关系型数据库

这篇具有很好参考价值的文章主要介绍了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通过官网下载
Redis_非关系型数据库,redis,nosql,数据库

  1. 解压源码包
    进入到源码包的下载目录opt后, 再解压源码包
    使用命令:
    tar -zxvf redos-6.0.8.tar.gz来解压源码包`
  2. 编译源码包Redis_非关系型数据库,redis,nosql,数据库

进入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_非关系型数据库,redis,nosql,数据库

三、Redis里的基本设置

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

如图启动之后,Ctr+C进入命令操作Redis就会结束进程
Redis_非关系型数据库,redis,nosql,数据库

命令:
cd /opt/redis-6.0.8/ 进入到源码包里
Redis_非关系型数据库,redis,nosql,数据库

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

redis.conf文件图示:
Redis_非关系型数据库,redis,nosql,数据库

接下来注意修改的位置:

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

Redis_非关系型数据库,redis,nosql,数据库
redis已运行成功

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

四、Redis的数据类型

redis有五种数据类型

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

Redis_非关系型数据库,redis,nosql,数据库

  1. String类型

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

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

2>对象缓存(不对对象里的值进行操作时使用)
Redis_非关系型数据库,redis,nosql,数据库

keys * 列出所有 键
Redis_非关系型数据库,redis,nosql,数据库

3>计数器

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

Redis_非关系型数据库,redis,nosql,数据库
注意: 计数器后面的值必须是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键对应的所有 键值对
Redis_非关系型数据库,redis,nosql,数据库

hincrby key file 改变值 改变field对应的值
如果是减小,改变值就是负数
Redis_非关系型数据库,redis,nosql,数据库

  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, stopRedis_非关系型数据库,redis,nosql,数据库

列表实现栈和队列:

栈: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_非关系型数据库,redis,nosql,数据库

五、设置数据的失效时间

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

Redis_非关系型数据库,redis,nosql,数据库
EX 表示秒
PX表示毫秒 (PX,EX不区分大小写)
如: set name jim ex 30 30 秒失效文章来源地址https://www.toymoban.com/news/detail-596548.html

到了这里,关于Redis_非关系型数据库的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 非关系型数据库之Redis 持久化

    目录 一 Redis 高可用  1redis高可用技术 2 持久化的功能: 3 Redis 提供两种方式进行持久化: 二 持久化之RDB 1. 触发条件 (1)手动触发 (2)自动触发 (3)其他自动触发机制 2. 执行流程 3. 启动时加载 三 AOF 持久化之AOF 1. 开启AOF配置 2. 执行流程 AOF的执行流程包括: (1)命令

    2024年04月10日
    浏览(46)
  • 非关系型数据库Redis的安装【Linux】及常用命令

     Redis(Remote Dictionary Server)是一种开源的内存数据库管理系统,它以键值存储方式来存储数据,并且支持多种数据结构,如字符串、哈希、列表、集合、有序集合等。Redis最初由Salvatore Sanfilippo开发,并于2009年首次发布。它被广泛用于缓存、会话管理、消息队列等应用,因为

    2024年02月05日
    浏览(47)
  • Redis基于内存的key-value结构化NOSQL(非关系型)数据库

    Redis基于内存的key-value结构的NOSQL(非关系型)数据库 非关系型数据库:表与表之间没有复杂的关系 基于内存存储,读写性能高 – Redis读的速度是110000次/S 适合存储热点数据(商品、新闻资讯) 它存储的value类型比较丰富,也称为结构化NoSQL数据库 直接解压windows版压缩包就

    2024年02月11日
    浏览(63)
  • 关系型数据库和非关系型数据库

     关系型数据库是以 关系(表格) 为基础的数据库,它采用了 SQL(Structured Query Language)作为数据操作语言,常见的关系型数据库包括 MySQL、Oracle、SQL Server 等。 非关系型数据库则是基于 文档、键值、列族 等方式存储数据的数据库,它通常没有固定的表结构,因此也被称为

    2024年02月09日
    浏览(45)
  • 关系型数据库与非关系型数据库类比

    关系型数据库和非关系型数据库都有多种不同类型,每种类型都针对不同的数据存储需求和使用场景。以下是一些常见的关系型数据库和非关系型数据库类型: 关系型数据库类型: MySQL: 一种开源的关系型数据库管理系统,用于处理结构化数据,适用于各种规模的应用。

    2024年02月11日
    浏览(40)
  • 重学MySQL之关系型数据库和非关系型数据库

    1.1 关系型数据库的特性 1.1.1 事务的特性 事务,是指一个操作序列,这些操作要么都执行,或者都不执行,而且这一序列是无法分隔的独立操作单位。也就是符合原子性(Atomicity)、 一致性(Consistency)、 隔离性(Isolation)和持久性(Durability)的一组操作。 原子性:指一个

    2024年02月02日
    浏览(73)
  • 关系型和非关系型数据库的区别

    关系型数据库,是指采用了关系模型来组织数据的数据库,关系型数据库的最大特点就是事务的一致性。关系型数据天然就是表格式的,因此数据存储在数据表的行和列中。数据表可以彼此关联协作存储,也很容易提取数据。 优点 易于维护:都是使用表结构,格式一致。 使

    2024年02月13日
    浏览(90)
  • 关系型数据库设计

    目录 1.数据库设计的重要性及定义 1.1 数据库设计的重要性 1.1.1 失败的数据库设计造成的后果  1.1.2 优秀的数据库设计带来的好处  1.2 数据库设计的定义  2.数据库需求分析  2.1 需求分析的步骤 2.1.1 收集信息 2.1.2 标识实体 2.1.3 标识每个实体的详细信息  2.1.4 标识实体之

    2024年04月10日
    浏览(66)
  • 非关系型数据库

    一、什么是非关系型数据库? 随着互联网的飞速发展,人们对数据存储和管理的需求越来越高,传统的关系型数据库遇到了越来越多的挑战。为了满足海量数据存储和高性能查询的需求,非关系型数据库(NoSQL)应运而生。 非关系型数据库是指不使用关系模型进行数据组织和

    2024年02月07日
    浏览(48)
  • 数据库介绍-非关系型数据库

    NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库。 NoSQL 不依赖业务逻辑方式存储,数据存储的类型不需要一个固定形式。因此大大的增加了数据库的扩展能力。 不遵循 SQL 标准 不支持 ACID 远超于 SQL 的性能 易扩展 大读写量,高性能 数据模型灵活 高可用

    2024年02月16日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包