前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis学习笔记(概述)

Redis学习笔记(概述)

作者头像
编程随想曲
发布2022-04-21 14:04:45
2720
发布2022-04-21 14:04:45
举报
文章被收录于专栏:编程随想曲

起源

2008年,意大利的一家创业公司Merzia推出了一款基于MySQL的网站实时统计系统LLOOGG,然而没过多久该公司的创始人Salvatore Sanfilippo便开始对MySQL的性能感到失望,于是他决定亲自为LLOOGG量身定做一个数据库,并于2009年开发完成,这个数据库就是Redis。

定位

Redis是REmoteDIctionaryServer(远程字典服务器)的缩写,它以字典结构存储数据,并允许其他应用通过TCP协议读写字典中的内容。

Redis支持的键值数据类型如下:

•字符串类型

•散列类型

•列表类型

•集合类型

•有序集合类型

优势

内存存储与持久化,读写速度快

数据结构

key-value键值对的形式

基于key-value的数据结构,结合丰富的键值类型,查询更简单。

以存储博客及博客标签为例,关系型数据库需要三张表,分别是博客表,标签表,博客与标签关联的中间表。我们要根据标签查询博客时,需要关联三张表。而如果改用Redis,存储结构如下。

代码语言:javascript
复制
post["tags"] = ["Java","JVN","JNI"]

只需要根据tags字段进行检索即可。

Redis通过命令进行查询,以查询posts表内id为1的title字段为例

代码语言:javascript
复制
HGET post:1 title

对比用SQL方式

代码语言:javascript
复制
SELECT title FROM posts WHERE id = 1 LIMIT 1

应用场景

1. 缓存

Redis可以为每个键设置生存时间(Time To Live,TTL),生存时间到期后键会自动被删除。

2. 队列

Redis的列表类型键可以用来实现队列,并且支持阻塞式读取,可以很容易地实现一个高性能的优先级队列。同时在更高层面上,Redis还支持“发布/订阅”的消息模式,可以基于此构建聊天室等系统

竞品比较

Redis

•单线程

•支持高级的数据类型或是持久化等功能

Memcached

•多线程

•多核服务器上性能更高一些

参考书目

•《Redis入门指南》李子骅 著

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-05-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编程随想曲 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 起源
  • 定位
  • 优势
  • 数据结构
  • 应用场景
  • 竞品比较
  • 参考书目
相关产品与服务
云数据库 Redis®
腾讯云数据库 Redis®(TencentDB for Redis®)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档