Redis(二)入门:概述与安装

本文最后更新于:1 年前

一、Redis概述

1、什么是Redis?

Redis(Remote Dictionary Server),即远程字典服务。是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

Redis通常将全部数据存储在内存中,会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,但只是用于重启后将数据加载回内存,相当于一个数据备份作用。

为什么Redis会将数据存储在内存中?

因为内存的读写速度比硬盘快一个数量级!这样数据库的性能就会大大提高。也是这个优点,Redis是当下最热门的 NoSQL 技术之一!也被人们称之为结构化数据库!

2、NoSQL

1)什么是NoSQL?

NoSQL 数据库(意即”不仅仅是SQL”)并非表格格式,其存储数据的方式与关系表不同。NoSQL 数据库的类型因数据模型而异。主要类型包括文档、键值、列式和图形。它们提供了灵活的模式,可以随大量数据和高用户负载而轻松扩展。

参考文章:《NoSQL OR SQL,看完这篇你就懂了》

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、测试操作

1
2
3
4
5
6
7
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 清空所有数据库
1
2
3
4
5
6
7
8
9
10
11
12
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到现在经过的总秒数)
1
2
3
4
5
6
7
8
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…] 删除一个或多个指定的键值对
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
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
1
2
3
4
5
6
7
8
9
10
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 数据库编号 将指定的键值对移动到指定的数据库
1
2
3
4
5
6
7
8
9
10
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


Redis(二)入门:概述与安装
https://gopherlinzy.github.io/2022/09/19/redis-begin/
作者
孙禄毅
发布于
2022年9月19日
许可协议