zoukankan      html  css  js  c++  java
  • 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入门指南》李子骅 著
  • 相关阅读:
    服务列表
    Tinyfool的2013年总结————在困惑和挣扎中试图前行
    支付平台程序,支付程序,网络pos程序,api接口程序,锋锐支付平台程序开发领导者!
    是新浪移动云
    Convert SVG to PNG in Python
    qrcode 4.0.4 : Python Package Index
    CairoSVG
    cairo graphics.org
    The Apache™ Batik Project
    Online SVG to PNG/JPEG/TIFF conversion
  • 原文地址:https://www.cnblogs.com/luoxiaolei/p/12823079.html
Copyright © 2011-2022 走看看