也叫Not Only SQL(不仅仅是SQL, 不用 sql语言操作的数据库), 一般指非关系型数据库
关系型数据库: 以数据库表为单位存储,表与表之间存在某种关系
非关系型数据库: 数据与数据之间没有关系, 数据就是以键值对的形式存储, 通过键获取到值
在互联网发展中:
大致经历三个时期,web1.0,web2.0,web3.0
web1.0:他是静态网页, 数据在网页就写死的, 数据直接在html里,每次更新, 都要更改html代码
web2.0:这时候就是动态页面了, 数据存放在数据库里面, 页面显示的数据可以从数据里动态获取
web3.0: 由于越来越多的用户参与到信息的构建流程里, 比如:抖音,头条用户都可以自己创建自己的信息, 又或者是节假日的商品抢购,秒杀,信息量爆炸, 就会导致传统的系统架构支撑不起来, 存在问题
由于关系型数据库存储在硬盘上, 查询需要与硬盘发生IO( 读取操作 ), 在一瞬间, 有当量用户访问时, 关系型数据库就会崩溃
优点:
1.存储在内存中, 读写非常快
2.数据结构简单(键值形式)
3.高性能, 一秒可以读写数量级上万
4.支持数据持久化(就是数据备份到硬盘上, 也是键值对)
首先在网上下载redis.tar.gz的源码包
可以点击这里直接下载
下载源码包有两种方式
1>由传输根据xftp-7工具来传输
2>由linux通过网站来直接下载
进入到opt目录,opt目录是linux安装软件的文件夹
使用命令:
cd /opt
进入到opt目录
wget https://download.redis.io/releases/redis-6.2.4.tar.gz
通过官网下载
进入opt目录后,进入解压后的redis里进行编译
命令:
cd redis-6.0.8
进入源码包
make
进行编译
安装指定位置
命令:
mkdir -p /opt/redis
创建安装目录
make install PEOFIX=/opt/redis
安装指定目录
启动redis服务
命令:
cd /opt/redis/bin
进入到redis的bin目录里
./redis-server
启动redis数据库
cp redis.conf /opt/redis/bin
复制源码里的配置文件到安装的位置里
vim redis.conf
编辑redisconf文件(此时是修改安装Redis里的配置文件)
接下来注意修改的位置:
cd /opt/redis/bin
去安装redis目录下的bin文件里./redis-server redis.conf
ps -ef | grep redis
检查一下redis是否运行kill -9 进程号
结束进程操作./redis-cli
aurth 密码
输入密码ping
redis有五种数据类型
String , Hash ,List , set , zset五种
redis是以键值对存储, 键都是String类型的, 值是所说的5种
虽然名叫String , 但是他可以存储图片(base64格式) ,对象(json格式)
set 键 值
存值
get 键 值
获取值
del 键 值
删值
1>单值缓存
set user {name:tom,age:20}
3>计数器
新闻点赞时, 使用计数器来计数
set newsid:1 0
存值, 键是newsid:1 ,值是0
incr newsid:1
值+1
decr newsid:1
值-1
get newsid:1
获取键newsid:1的值
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键对应的所有 键值对
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
Set类型的数据没有无顺序,不可重复
sadd key member [member]
往key集合存储值
srem key member [member]
删除key集合里的member值
smembers key
获取集合key的所有元素
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可以通过一些命令, 能够设置数据的过期时间, 过期后数据自动删除