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

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis通常将全部数据存储在内存中,会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,但只是用于重启后将数据加载回内存,相当于一个数据备份作用。

前言


个人网站:https://linzyblog.netlify.app/


一、Redis概述


1、什么是Redis?


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


0363e38eb233422f90805ddc33e1e231.png


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等客户端,使用很方便。


972bfdc981aa4e92ba99dbfa30ac95ab.png


3. Redis支持主从同步:数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。


5b58d9af5226498c91e33ab34760a05d.png


4、Redis发展简史


2d86aedec0584c03ac5e57351e497588.png


Redis的作者Salvatore Sanfilippo,意大利程序员,他最早使用传统数据库做了一个实时的Web日志分析器,因为对其性能不够满意,开发了Redis。


2020年6月,Salvatore Sanfilippo辞去了Redis维护者的职位。


二、Redis安装


官方安装文档点击跳转


1、windows下安装Redis


这边选择windows下载只是方便学习测试,后续可能会转到Linux上。


下载地址:  点击跳转.


c9c795ae4a644dcab80839d467e95320.png


我的建议是直接下载.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"

86d36d9512da42fb84bf8905bb7a2c28.png


三、基本操作


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

e97d18d244a142f4a4ad64b2181100ec.png


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

ca798d05dd644b4d929fdde615bffeb4.png


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"


c5e944c825b742199587bf05af37ef02.png、、


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


2074d0111267450d89358e71c8789851.png


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


c409649b25da41aa8f7db88eec6e5a22.png

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
7天前
|
NoSQL Linux 测试技术
Redis的安装(Linux版)
Redis的安装(Linux版)
150 1
|
17天前
|
NoSQL Linux Redis
linux 下和win下安装redis 并添加开机自启 图文详解
linux 下和win下安装redis 并添加开机自启 图文详解
17 0
|
1天前
|
存储 NoSQL Linux
Redis入门到通关之Redis5种网络模型详解
Redis入门到通关之Redis5种网络模型详解
|
1天前
|
存储 NoSQL 算法
Redis入门到通关之Redis数据结构-Hash篇
Redis入门到通关之Redis数据结构-Hash篇
10 1
|
1天前
|
存储 NoSQL Redis
Redis入门到通关之Redis数据结构-List篇
Redis入门到通关之Redis数据结构-List篇
|
1天前
|
存储 NoSQL 安全
Redis入门到通关之Redis数据结构-String篇
Redis入门到通关之Redis数据结构-String篇
|
1天前
|
存储 NoSQL Redis
Redis入门到通关之数据结构解析-SkipList
Redis入门到通关之数据结构解析-SkipList
|
1天前
|
存储 NoSQL 安全
Redis入门到通关之数据结构解析-动态字符串SDS
Redis入门到通关之数据结构解析-动态字符串SDS
|
1天前
|
NoSQL Redis
Redis入门到通关之Redis主从数据同步原理
Redis入门到通关之Redis主从数据同步原理
|
1天前
|
存储 NoSQL Java
Redis入门到通关之数据结构解析-Dict
Redis入门到通关之数据结构解析-Dict

热门文章

最新文章