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_非关系型数据库_第1张图片

  1. 解压源码包
    进入到源码包的下载目录opt后, 再解压源码包
    使用命令:
    tar -zxvf redos-6.0.8.tar.gz来解压源码包`
  2. 编译源码包Redis_非关系型数据库_第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_非关系型数据库_第3张图片

三、Redis里的基本设置

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

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

命令:
cd /opt/redis-6.0.8/ 进入到源码包里
Redis_非关系型数据库_第5张图片

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

redis.conf文件图示:
Redis_非关系型数据库_第6张图片

接下来注意修改的位置:

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

Redis_非关系型数据库_第10张图片
redis已运行成功

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

四、Redis的数据类型

redis有五种数据类型

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

Redis_非关系型数据库_第11张图片

  1. String类型

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

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

2>对象缓存(不对对象里的值进行操作时使用)
Redis_非关系型数据库_第12张图片

keys * 列出所有 键
Redis_非关系型数据库_第13张图片

3>计数器

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

Redis_非关系型数据库_第14张图片
注意: 计数器后面的值必须是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_非关系型数据库_第15张图片

hincrby key file 改变值 改变field对应的值
如果是减小,改变值就是负数
Redis_非关系型数据库_第16张图片

  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_非关系型数据库_第17张图片

列表实现栈和队列:

栈: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_非关系型数据库_第18张图片

五、设置数据的失效时间

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

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

你可能感兴趣的:(redis,nosql,数据库)