• Redis学习笔记(概述)


    起源

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

    定位

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

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

    • 字符串类型
    • 散列类型
    • 列表类型
    • 集合类型
    • 有序集合类型

    优势

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

    数据结构

    key-value

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

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

    post["tags"] = ["Java","JVN","JNI"]
    

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

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

    HGET post:1 title
    

    对比用SQL方式

    SELECT title FROM posts WHERE id = 1 LIMIT 1
    

    应用场景

    1. 缓存

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

    1. 队列

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

    竞品比较

    Redis

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

    Memcached

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

    参考书目

    • 《Redis入门指南》李子骅 著
  • 相关阅读:
    Jzoj4822 完美标号
    Jzoj4822 完美标号
    Jzoj4792 整除
    Jzoj4792 整除
    Educational Codeforces Round 79 A. New Year Garland
    Good Bye 2019 C. Make Good
    ?Good Bye 2019 B. Interesting Subarray
    Good Bye 2019 A. Card Game
    力扣算法题—088扰乱字符串【二叉树】
    力扣算法题—086分隔链表
  • 原文地址:https://www.cnblogs.com/luoxiaolei/p/12823079.html
Copyright © 2020-2023  润新知