zoukankan      html  css  js  c++  java
  • 零基础学redis

    第一个阶段:redis基本知识了解:

    1. redis的百度百科解释:

    Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。

      注意:持久化的概念:

    持久化是将程序数据在持久状态和瞬时状态间转换的机制。通俗的讲,就是瞬时数据(比如内存中的数据,是不能永久保存的)持久化为持久数据(比如持久化至数据库中,能够长久保存)。

    持久化(Persistence),即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在关系型的数据库中,当然也可以存储在磁盘文件中、XML数据文件中等等。

    持久化是将程序数据在持久状态和瞬时状态间转换的机制。
    JDBC就是一种持久化机制。文件IO也是一种持久化机制。

    redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
    Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。[1]
    Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。

    2. 数据类型支持:

      

    Redis的外围由一个键、值映射的字典构成。与其他非关系型数据库主要不同在于:Redis中值的类型[1] 不仅限于字符串,还支持如下抽象数据类型:
    字符串列表
    无序不重复的字符串集合
    有序不重复的字符串集合
    键、值都为字符串的哈希表[1]
    值的类型决定了值本身支持的操作。Redis支持不同无序、有序的列表,无序、有序的集合间的交集、并集等高级服务器端原子操作。

    3. redis提供五种数据类型:string,hash,list,set及zset(sorted set)。

    4. redis命令:

      

    就DB来说,Redis成绩已经很惊人了,且不说memcachedb和Tokyo Cabinet之流,就说原版的memcached,速度似乎也只能达到这个级别。Redis根本是使用内存存储,持久化的关键是这三条指令:SAVE BGSAVE LASTSAVE …
    当接收到SAVE指令的时候,Redis就会dump数据到一个文件里面。
    值得一说的是它的独家功能:存储列表和集合,这是它与mc之流相比更有竞争力的地方。
    不介绍mc里面已经有的东东,只列出特殊的:
    TYPE key — 用来获取某key的类型
    KEYS pattern — 匹配所有符合模式的key,比如KEYS * 就列出所有的key了,当然,复杂度O(n)
    RANDOMKEY - 返回随机的一个key
    RENAME oldkeynewkey— key也可以改名
    列表操作,精华
    RPUSH key string — 将某个值加入到一个key列表末尾
    LPUSH key string — 将某个值加入到一个key列表头部
    LLEN key — 列表长度
    LRANGE key start end — 返回列表中某个范围的值,相当于mysql里面的分页查询那样
    LTRIM key start end — 只保留列表中某个范围的值
    LINDEX key index — 获取列表中特定索引号的值,要注意是O(n)复杂度
    LSET key index value — 设置列表中某个位置的值
    LPOP key
    RPOP key — 和上面的LPOP一样,就是类似栈或队列的那种取头取尾指令,可以当成消息队列来使用了
    集合操作
    SADD key member — 增加元素
    SREM key member — 删除元素
    SCARD key — 返回集合大小
    SISMEMBER key member — 判断某个值是否在集合中
    SINTER key1 key2 ... keyN — 获取多个集合的交集元素
    SMEMBERS key — 列出集合的所有元素
    还有Multiple DB的命令,可以更换db,数据可以隔离开,默认是存放在DB 0。

                         

    第二个阶段:     

    http://www.cnblogs.com/shanyou/archive/2012/01/28/2330451.html

    redis入门文章

                                  

  • 相关阅读:
    项目计划和进度的管理之读书笔记
    美团,点评,澎湃等APP的启示
    产品曝光策略及渠道整理(一)
    产品信息架构的思考
    理解交互设计之"行为设计与对象设计"
    从市场运营角度谈Uber中国的第一批用户是怎么来的
    行业分析方向与框架
    行业分析报告的渠道和资料来源
    es6中的部分新特性
    解决微信开发工具在每次保存时自动刷新到首页的问题
  • 原文地址:https://www.cnblogs.com/blogofwyl/p/4549518.html
Copyright © 2011-2022 走看看