1. Redis 是什么

Redis是一个开源的使用ANSI C语言编写的基于内存的key/value存储系统,与memcache类似,但它支持的value类型更多,包括:字符串(string)、链表(list)、集合(set)、有序集合(sorted set)和hash tablehttp://blog.nosqlfan.com/html/2235.html等,这些数据类型支持push/pop、add/remove、交集并集差集及其他更丰富的操作,且这些操作均是原子性的。

按照分布式领域的CAP理论,Consisency、Availability、Tolerance to network Partitions这三个部分在任何系统架构实现时,只能同时满足其中两点,没法三者兼顾。Redis是一个数据库,它将重点放在了Consisency和Availability上,因而Redis只是一个单机的key/value系统,并不直接支持分布式,同时考虑到Tolerance to network Partitions,它支持将数据同步到多台从库上。

2. Redis 有哪些优点

与memcache和MySQL等类似产品比较,Redis有以下几个优点:

(1) 非常丰富的数据结构,且这些数据结构的常见操作均是原子性的;

(2) 高速读写。Memcached提供了CAS命令,可以保证多个并发访问操作同一份数据的一致性问题。 Redis没有提供CAS命令,不过Redis提供了事务的功能,可以保证一串 命令的原子性,中间不会被任何操作打断。MYSQL使用了锁,而memcache未使用锁,进而效率极高。总之,Redis用自己实现的事件分离器,代码量很短,没有CAS,没有lock,因而效率非常高。

关于memcache与redis的比较,可参考这篇文章:《Redis与Memcached的比较》http://tech.it168.com/a2011/0818/1234/000001234403_1.shtml

3. Redis 有哪些缺点

Redis主要缺点有两个:

(1) 持久化。 Redis直接将数据存储到内存中,可通过两种方式持久化:定时快照(snapshot)和基于语句的追加(AppendOnlyFile,aof)。Snapshot的方法是指每隔一段时间将整个数据库的数据写到磁盘上,很明显,每次均是写全部数据,代价非常高;而aof方法只追踪变化的数据,这类似于mysql的binlog方法,但追加log可能过大,同时所有操作均要重新执行一遍,恢复速度慢。

(2) 耗内存。尽管Redis对一些数据结构采用了压缩算法存储,但占用内存量还是过高。

4. Redis 的应用场景

Redis的作者antirez曾笑称其为一个数据结构服务器(data structures server),的确,利用Redis灵活多变的数据结构和数据操作,我们可以很容易的实现各种功能,下面列举几个典型的操作:

(1) 计数器

Redis的命令均是原子性的,可以很容易使用INCR、DECR命令来构建计数器系统

(2) 获取最新的N个数据操作

可使用list何种的LPUSH和LTRIM操作。

(3) 排行榜应用,取TOP N操作

上面一个操作是按时间就行排序,而这个则是用于自定义的一个条件,比如点击次数等,这时候可使用sorted set这种数据结构。

更多应用场景,可参考一下几篇文章:

【1】《redis 点滴》:http://www.jeffkit.info/2011/05/994/

【2】 Redis中7种集合类型应用场景:http://blog.prosight.me/index.php/2011/08/802

【3】  Redis作者谈Redis应用场景:http://blog.nosqlfan.com/html/2235.html

5. Redis 使用体验

(1)选定某个数据库select

对于SQL类的数据库,我们可以创建n个数据库,且每个数据库都对应一个名字,我们通常会先选择一个数据库,再对数据库中的表操作,而Redis则不同,在Redis中,数据库被赋以一个整数编号(从0开始),默认情况下是对数据库0进行操作,数据库的数目可以在配置文件redis.conf中databases属性指定。

(2)数据库存储和检索

直接使用http://redis.io/commands上的命令完成数据存储和检索即可

1. Redis 是什么

Redis是一个开源的使用ANSI C语言编写的基于内存的key/value存储系统,与memcache类似,但它支持的value类型更多,包括:字符串(string)、链表(list)、集合(set)、有序集合(sorted set)和hash tablehttp://blog.nosqlfan.com/html/2235.html等,这些数据类型支持push/pop、add/remove、交集并集差集及其他更丰富的操作,且这些操作均是原子性的。

按照分布式领域的CAP理论,Consisency、Availability、Tolerance to network Partitions这三个部分在任何系统架构实现时,只能同时满足其中两点,没法三者兼顾。Redis是一个数据库,它将重点放在了Consisency和Availability上,因而Redis只是一个单机的key/value系统,并不直接支持分布式,同时考虑到Tolerance to network Partitions,它支持将数据同步到多台从库上。

2. Redis 有哪些优点

与memcache和MySQL等类似产品比较,Redis有以下几个优点:

(1) 非常丰富的数据结构,且这些数据结构的常见操作均是原子性的;

(2) 高速读写。Memcached提供了CAS命令,可以保证多个并发访问操作同一份数据的一致性问题。 Redis没有提供CAS命令,不过Redis提供了事务的功能,可以保证一串 命令的原子性,中间不会被任何操作打断。MYSQL使用了锁,而memcache未使用锁,进而效率极高。总之,Redis用自己实现的事件分离器,代码量很短,没有CAS,没有lock,因而效率非常高。

关于memcache与redis的比较,可参考这篇文章:《Redis与Memcached的比较》http://tech.it168.com/a2011/0818/1234/000001234403_1.shtml

3. Redis 有哪些缺点

Redis主要缺点有两个:

(1) 持久化。 Redis直接将数据存储到内存中,可通过两种方式持久化:定时快照(snapshot)和基于语句的追加(AppendOnlyFile,aof)。Snapshot的方法是指每隔一段时间将整个数据库的数据写到磁盘上,很明显,每次均是写全部数据,代价非常高;而aof方法只追踪变化的数据,这类似于mysql的binlog方法,但追加log可能过大,同时所有操作均要重新执行一遍,恢复速度慢。

(2) 耗内存。尽管Redis对一些数据结构采用了压缩算法存储,但占用内存量还是过高。

4. Redis 的应用场景

Redis的作者antirez曾笑称其为一个数据结构服务器(data structures server),的确,利用Redis灵活多变的数据结构和数据操作,我们可以很容易的实现各种功能,下面列举几个典型的操作:

(1) 计数器

Redis的命令均是原子性的,可以很容易使用INCR、DECR命令来构建计数器系统

(2) 获取最新的N个数据操作

可使用list何种的LPUSH和LTRIM操作。

(3) 排行榜应用,取TOP N操作

上面一个操作是按时间就行排序,而这个则是用于自定义的一个条件,比如点击次数等,这时候可使用sorted set这种数据结构。

更多应用场景,可参考一下几篇文章:

【1】《redis 点滴》:http://www.jeffkit.info/2011/05/994/

【2】 Redis中7种集合类型应用场景:http://blog.prosight.me/index.php/2011/08/802

【3】  Redis作者谈Redis应用场景:http://blog.nosqlfan.com/html/2235.html

5. Redis 使用体验

(1)选定某个数据库select

对于SQL类的数据库,我们可以创建n个数据库,且每个数据库都对应一个名字,我们通常会先选择一个数据库,再对数据库中的表操作,而Redis则不同,在Redis中,数据库被赋以一个整数编号(从0开始),默认情况下是对数据库0进行操作,数据库的数目可以在配置文件redis.conf中databases属性指定。

(2)数据库存储和检索

直接使用http://redis.io/commands上的命令完成数据存储和检索即可

(3)支持事务

MULTI, EXEC, DISCARD 和 WATCH 命令是Redis事务的基石。一个Redis事务允许一组Redis命令单步执行,并提供下面两个重要保证:一个事务中的所有命令串行执行;要么全部命令要么没有任何命令被处理。具体可参开这篇文章:http://blog.xiping.me/2010/12/transaction-in-redis.html

(4) Redis客户端

Redis支持非常各种语言的客户端,具体参:http://redis.io/clients

原创文章,转载请注明: 转载自董的博客

本文链接地址: http://dongxicheng.org/nosql/redis-code-basic-points/

作者:Dong,作者介绍:http://dongxicheng.org/about/

本博客的文章集合:http://dongxicheng.org/recommend/

(3)支持事务

MULTI, EXEC, DISCARD 和 WATCH 命令是Redis事务的基石。一个Redis事务允许一组Redis命令单步执行,并提供下面两个重要保证:一个事务中的所有命令串行执行;要么全部命令要么没有任何命令被处理。具体可参开这篇文章:http://blog.xiping.me/2010/12/transaction-in-redis.html

(4) Redis客户端

Redis支持非常各种语言的客户端,具体参:http://redis.io/clients

原创文章,转载请注明: 转载自董的博客

本文链接地址: http://dongxicheng.org/nosql/redis-code-basic-points/

作者:Dong,作者介绍:http://dongxicheng.org/about/

本博客的文章集合:http://dongxicheng.org/recommend/

Redis源码研究—基础知识相关推荐

  1. 转载一篇《Redis源码研究—哈希表》重点是如何重新哈希

    <Redis源码研究-哈希表>来自:董的博客 网址:http://dongxicheng.org/nosql/redis-code-hashtable/ 转载于:https://www.c ...

  2. jQuery源码的基础知识

    序言:DOM addEventListener attachEvent与addEventListener区别 适应的浏览器版本不同,同时在使用的过程中要注意 attachEvent方法         ...

  3. WebRTC源码研究(4)web服务器工作原理和常用协议基础

    文章目录 WebRTC源码研究(4)web服务器工作原理和常用协议基础 前言 做WebRTC 开发为啥要懂服务器开发知识 1. Web 服务器简介 2. Web 服务器的类型 3. Web 服务器的工 ...

  4. WebRTC源码研究(4)web服务器工作原理和常用协议基础(转载)

    前言 前面3篇博客分别对WebRTC框架的介绍,WebRTC源码目录,WebRTC的运行机制进行了介绍,接下来讲解一点关于服务器原理的知识.后面博客会写关于WebRTC服务器相关的开发,目前git上面 ...

  5. Redis源码分析:基础概念介绍与启动概述

    Redis源码分析 基于Redis-5.0.4版本,进行基础的源码分析,主要就是分析一些平常使用过程中的内容.仅作为相关内容的学习记录,有关Redis源码学习阅读比较广泛的便是<Redis设计与 ...

  6. redis源码剖析(3):基础数据结构dict

    目录 1.dict概述 2.字典的定义 3.哈希算法 4.字典的初始化及新增键值对 4.1 字典初始化 4.2 新增键值对 5.rehash(重新散列)操作 5.1 rehash操作方式 5.2 re ...

  7. Redis源码学习(20),学习感悟

      最近学习Redis源码也有半个月的时间了,有不少收获也有不少感悟,今天来好好聊聊我学习的感悟. 1 发现问题   人非圣贤孰能无过,只要是人难免会犯错,回顾我之前的学习历程,其实是可以发现不少的问 ...

  8. Redis源码解析——字典基本操作

    有了<Redis源码解析--字典结构>的基础,我们便可以对dict的实现进行展开分析.(转载请指明出于breaksoftware的csdn博客) 创建字典 一般字典创建时,都是没有数据的, ...

  9. 【Redis学习笔记】2018-05-30 Redis源码学习之Ziplist、Server

    作者:施洪宝 顺风车运营研发团队 一. 压缩列表 压缩列表是Redis的关键数据结构之一.目前已经有大量的相关资料,下面几个链接都已经对Ziplist进行了详细的介绍. http://origin.r ...

最新文章

  1. BZOJ 2157 「国家集训队」旅游(树链剖分,线段树,边权转点权)【BZOJ计划】
  2. CS8900A网络驱动程序移植
  3. .net 考试系统人一多就断开了_2020年银行从业资格考试成绩查询入口已开放
  4. 【Java 泛型】泛型用法 ( 泛型编译期擦除 | 上界通配符 <? extends T> | 下界通配符 <? super T> )
  5. shell实例第15讲:俄罗斯方块游戏
  6. 基于FPGA的DES加解密系统开发(5000字详细介绍欢迎订阅)
  7. 如何保障消息中间件 100% 消息投递成功?如何保证消息幂等性?
  8. python完全支持面向对象编程_Python面向对象编程
  9. 【APICloud系列|12】ios真机调试时如何添加新设备的udid?
  10. 机器学习的重新思考:人工智能如何学习“失忆”?
  11. Python数据预处理:使用Dask和Numba并行化加速
  12. slr1文法_SLR的完整形式是什么?
  13. SHELL $RANDOM产生的随机数范围是0到32767
  14. Android接口测试工具Apizza,自定义API请求返回值,自定义请求相对路径
  15. 程序设计原则之SOLID原则
  16. 如何使用shell限制指定用户shell程序的网络带宽
  17. delphi android 蓝牙,Android实例-Delphi开发蓝牙官方实例解析(XE10+小米2+小米5)
  18. z变换判断稳定性和因果性_判断因果性.PPT
  19. 《我们赖以生存的隐喻》文学中的面向对象
  20. 常见电机分类和驱动原理动画

热门文章

  1. 进程间通信 —— 命名管道
  2. nodejs繁琐地自建路由
  3. Feflow 源码解读
  4. swift开发之--UISearchBar的使用/UISearchController的使用
  5. 【ASM学习】普通数据库向ASM实例的迁移(二)
  6. linux之LAMP架构优化
  7. 在树莓派中开发 opencv 大型程序
  8. 简洁送货单打印软件的使用意义
  9. iOS开发小知识之正则表达式的简单用法
  10. 解决由于DNS解析导致Emacs启动巨慢的问题