redis-读懂redis

Redis是一个开源的使用C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

  1. 安装与使用

Redis可以在其官方网站上下载,解压后,进入redis目录,编译源码:




make

编译后,在src目录下,有几个可执行文件redis-server、redis-cli等,运行Redis服务:




./redis-server

在另一个终端运行Redis客户端:




./redis-cli

在Redis客户端,可以执行Redis命令,如:




set key value
get key
  1. 数据类型

Redis支持的数据类型包括字符串、列表、集合、有序集合、哈希表等。

例如,在Redis客户端执行:




# 字符串
set mykey "Hello"
get mykey
 
# 列表
lpush mylist a b c
lrange mylist 0 -1
 
# 集合
sadd myset "Hello" "World"
smembers myset
 
# 有序集合
zadd myzset 1 "one"
zrange myzset 0 -1 withscores
 
# 哈希表
hset myhash field1 "Hello"
hget myhash field1
  1. 持久化

Redis支持两种持久化方式,RDB(默认)和AOF。

RDB,在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是Snapshotting。

AOF,保存Redis服务器所执行的所有写操作命令到文件。

可以在redis.conf中配置持久化:




# RDB
save 900 1
save 300 10
save 60 10000
 
# AOF
appendonly yes
appendfsync everysec
  1. 事务

Redis的事务可以一次执行多个命令,本身是串行的,但不保证原子性。




multi
set key1 value1
set key2 value2
exec
  1. 发布/订阅

Redis的发布/订阅机制允许客户端订阅一个或多个频道,发送消息到频道,其他订阅了该频道的客户端会收到消息。




# 订阅频道
subscribe mychannel
 
# 发布消息
publish mychannel "Hello World"
  1. 主从同步

Redis支持主从同步,从服务器自动同步主服务器的数据。

在redis.conf中配置:




slaveof <master-ip> <master-port>
  1. 分片

Redis支持分片,即分布式存储数据。

可以通过Redis Cluster或者客户端分片来实现。

  1. 安全性

Redis支持使用密码和TLS/SSL来保证安全性。

在redis.conf中配置:




requirepass yourpassword
 
tls-port 6379

在客户端连接时使用AUTH命令:




auth yourpassword
  1. 性能

Redis使用了单线程模型,基于内存操作,读写速度非常快。

  1. 应用场景

Redis可以应用在缓存、排行榜、计数器、分布式会话、分布式锁等场景。

例如,使用Redis做缓存:




import redis
 
r = redis.Red
最后修改于:2024年09月03日 18:57

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日