前言
个人网站:https://linzyblog.netlify.app/
一、Redis概述
1、什么是Redis?
Redis(Remote Dictionary Server),即远程字典服务。是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
Redis通常将全部数据存储在内存中,会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,但只是用于重启后将数据加载回内存,相当于一个数据备份作用。
为什么Redis会将数据存储在内存中?
因为内存的读写速度比硬盘快一个数量级!这样数据库的性能就会大大提高。也是这个优点,Redis是当下最热门的 NoSQL 技术之一!也被人们称之为结构化数据库!
2、NoSQL
1)什么是NoSQL?
NoSQL 数据库(意即"不仅仅是SQL")并非表格格式,其存储数据的方式与关系表不同。NoSQL 数据库的类型因数据模型而异。主要类型包括文档、键值、列式和图形。它们提供了灵活的模式,可以随大量数据和高用户负载而轻松扩展。
3、Redis的定义
1.Redis是一个key-value存储系统:支持存储的value类型多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。
2.Redis 是一个高性能的key-value数据库:在部分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。
3. Redis支持主从同步:数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。
4、Redis发展简史
Redis的作者Salvatore Sanfilippo,意大利程序员,他最早使用传统数据库做了一个实时的Web日志分析器,因为对其性能不够满意,开发了Redis。
2020年6月,Salvatore Sanfilippo辞去了Redis维护者的职位。
二、Redis安装
官方安装文档:点击跳转
1、windows下安装Redis
这边选择windows下载只是方便学习测试,后续可能会转到Linux上。
下载地址: 点击跳转.
我的建议是直接下载.msi的安装包,电脑会自动给我们配置好环境变量,这样就不用自己启动redis的服务端redis-server了,直接用redis-cli启动redis客户端了。
如果下的是zip压缩包也没事,自己手动配置环境变量就行或者先启动redis-server再启动redis-cli即可。
注意:Redis官方文档不建议我们在Widows环境下搭建Redis服务。因为只有 Redis 3,且上次更新是2016。不推荐!
2、测试操作
PS C:\Users\sly> redis-cli 127.0.0.1:6379> ping #查看当前连接是否正常,正常连接返回PONG PONG 127.0.0.1:6379> set name linzy OK 127.0.0.1:6379> keys * 1) "name"
三、基本操作
1、数据库操作
1)数据库基本操作
Redis默认有16个数据库,编号为0~15,默认访问为0号数据库。
命令 | 描述 |
select 数据库编号 | 选择访问指定数据库 |
dbsize | 返回当前数据库的键值对数量 |
flushdb | 清空当前数据库 |
flushall | 清空所有数据库 |
127.0.0.1:6379> select 6 OK 127.0.0.1:6379[6]> dbsize (integer) 0 127.0.0.1:6379[6]> set name linzy OK 127.0.0.1:6379[6]> dbsize (integer) 1 127.0.0.1:6379[6]> flushdb OK 127.0.0.1:6379[6]> dbsize (integer) 0
2)数据库保存操作
命令 | 描述 |
save | 将数据保存到磁盘 |
bgsave | 将后台数据异步保存到磁盘(默认每两秒保存一次) |
lastsave | 查看最近一次成功保存的 Unix 秒(1970年1月1日00:00:00到现在经过的总秒数) |
127.0.0.1:6379[6]> save OK 127.0.0.1:6379[6]> lastsave (integer) 1663070951 127.0.0.1:6379[6]> bgsave Background saving started 127.0.0.1:6379[6]> lastsave (integer) 1663070960
2、 通用数据操作
1)对当前数据库进行基本操作
命令 | 描述 |
set key value | 在当前数据库保存一个键值对,如果key存在则直接将原来的value值覆盖 |
mset key1 value1 [key2 value2…] | 在当前数据库保存多个键值对,与set一样,key存在也会覆盖原来的value |
keys 格式 | 查看符合指定格式的 key ,*为通配符 |
exists key1 [key2…] | 查看一个或多个指定的 key |
type key | 按指定的 key 查看 value 的数据类型 |
del key1 [key2…] | 删除一个或多个指定的键值对 |
127.0.0.1:6379[6]> set name linzy OK 127.0.0.1:6379[6]> mset k1 v1 k2 v2 k3 v3 OK 127.0.0.1:6379[6]> keys * 1) "k3" 2) "name" 3) "k2" 4) "k1" 127.0.0.1:6379[6]> keys k* 1) "k3" 2) "k2" 3) "k1" 127.0.0.1:6379[6]> keys k (empty list or set) 127.0.0.1:6379[6]> exists k1 k5 (integer) 1 127.0.0.1:6379[6]> type k1 string 127.0.0.1:6379[6]> type name string 127.0.0.1:6379[6]> del name k3 (integer) 2 127.0.0.1:6379[6]> keys * 1) "k2" 2) "k1"
、、
2)对当前数据库重命名操作
命令 | 描述 |
rename key1 key2 | key1 重命名为 key2 ,如果 key2 已经存在,其对应的值会被覆盖为 key1 的值 |
renamenx key1 key2 | key1 只有在 key2 不存在时才会重命名为 key2 |
127.0.0.1:6379[6]> rename k1 k2 OK 127.0.0.1:6379[6]> keys * 1) "k2" 127.0.0.1:6379[6]> get k2 #获取key对应的值,如果key不存则返回nil,get只处理字符串类型数据 "v1" 127.0.0.1:6379[6]> set k1 v1 OK 127.0.0.1:6379[6]> renamenx k1 k2 (integer) 0
3)对当前数据库移动操作
命令 | 描述 |
move key 数据库编号 | 将指定的键值对移动到指定的数据库 |
127.0.0.1:6379[6]> move k1 0 (integer) 1 127.0.0.1:6379[6]> keys * 1) "k2" 127.0.0.1:6379[6]> select 0 OK 127.0.0.1:6379> keys * 1) "k1" 127.0.0.1:6379> set k2 v2 OK