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

目录
相关文章
|
存储 缓存 NoSQL
Redis 服务器全方位介绍:从入门到核心原理
Redis是一款高性能内存键值数据库,支持字符串、哈希、列表等多种数据结构,广泛用于缓存、会话存储、排行榜及消息队列。其单线程事件循环架构保障高并发与低延迟,结合RDB和AOF持久化机制兼顾性能与数据安全。通过主从复制、哨兵及集群模式实现高可用与横向扩展,适用于现代应用的多样化场景。合理配置与优化可显著提升系统性能与稳定性。
248 0
|
4月前
|
关系型数据库 应用服务中间件 nginx
Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)
本系列脚本提供RocketMQ、Nginx、MySQL、MinIO、Jenkins和Redis的Docker一键安装与配置方案,适用于快速部署微服务基础环境。
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
320 6
|
7月前
|
NoSQL 数据可视化 关系型数据库
安装 Redis
本文主要介绍了Linux系统下Redis的安装步骤,包括卸载旧版本、下载新版本、编译安装以及配置启动等详细操作,并解释了Redis默认端口6379的由来。同时,文章还简要说明了Windows环境下Redis的下载与服务安装方法。最后,推荐了几款Redis可视化管理工具,如RedisView、QuickRedis、AnotherRedisDesktopManager和RedisPlus,提供了它们的功能特点及下载链接,方便用户根据需求选择合适的工具进行数据库管理。
550 1
|
6月前
|
消息中间件 NoSQL Linux
Redis的基本介绍和安装方式(包括Linux和Windows版本),以及常用命令的演示
Redis(Remote Dictionary Server)是一个高性能的开源键值存储数据库。它支持字符串、列表、散列、集合等多种数据类型,具有持久化、发布/订阅等高级功能。由于其出色的性能和广泛的使用场景,Redis在应用程序中常作为高速缓存、消息队列等用途。
913 16
|
6月前
|
JSON NoSQL Redis
在Rocky9系统上安装并使用redis-dump和redis-load命令的指南
以上步骤是在Rocky9上使用redis-dump和redis-load命令顺利出行的秘籍。如果在实行的过程中,发现了新的冒险和挑战,那么就像一个勇敢的航海家,本着探索未知的决心,解决问题并前进。
237 14
|
8月前
|
NoSQL Ubuntu 网络安全
在 Ubuntu 20.04 上安装和配置 Redis
在 Ubuntu 20.04 上安装和配置 Redis 的步骤如下:首先更新系统包,然后通过 `apt` 安装 Redis。安装后,启用并启动 Redis 服务,检查其运行状态。可选配置包括修改绑定 IP、端口等,并确保防火墙设置允许外部访问。最后,使用 `redis-cli` 测试 Redis 功能,如设置和获取键值对。
366 1
|
8月前
|
NoSQL Java Redis
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Redis 安装
本教程介绍在 VMware 虚拟机(CentOS 7)或阿里云服务器中安装 Redis 的过程,包括安装 gcc 编译环境、下载 Redis(官网或 wget)、解压安装、修改配置文件(如 bind、daemonize、requirepass 等设置)、启动 Redis 服务及测试客户端连接。通过 set 和 get 命令验证安装是否成功。适用于初学者快速上手 Redis 部署。
231 0
|
11月前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
310 14
|
10月前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
361 7