海量数据存储方案 海量数据存储redis

redis是什么型数据库REmote DIctionary Server(Redis) 是一个由 Salvatore Sanfilippo 写的 key-value 存储系统,是跨平台的非关系型数据库 。
redis是一个key-value存储系统 。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型) 。
在数据库方面,mysql是关系型数据库主要用于存放持久化数据,redis是NOSQL,即非关系型数据库,也是缓存数据库,缓存的读取速度快 , 能够大大的提高运行效率,但是保存时间有限 。
【海量数据存储方案 海量数据存储redis】关系型数据库,是指采用了关系模型来组织数据的数据库 。在关系型数据库中,数据被组织成一系列的表格,表格中的每一列被称为一个属性,每一行称为一个记录,记录表示实体的实例 。在Redis中,每个键对应一个唯一的值 。
为什么使用Redis及其产品定位(转载自http://www.infoq.com/cn/arti...Redis 通过运行多个进程(使用 Redis 集群)实现横向扩展,包括在单一云实例背景下也是如此 。在 Redis 公司 , 我们进一步拓展这个概念并建立起 Redis Enterprise 。
数据支持类型:redis在数据支持上要比memecache多的多 。使用底层模型不同:新版本的redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求 。
Redis-Cluster1、redis-cluster把所有的物理节点映射到[0-16383]个 slot 上,基本上采用平均分配和连续分配的方式 。
2、CLUSTER REPLICATE node_id 将当前节点设置为 node_id 指定的节点的从节点 。CLUSTER SAVECONFIG 将节点的配置文件保存到硬盘里面 。
3、在redis-cluster集群中,每一个主节点可以添加多个从节点,主节点和从节点遵循主从模式的特性 。当用户需要处理更多的读请求时 , 添加从节点可以扩展系统的读性能 。
4、Redis集群把所有的数据映射到16384个槽中 。每个key会映射为一个固定的槽,只有当节点分配了槽 , 才能响应和这些槽关联的键命令 。通过cluster addslots命令为节点分配槽 。
数据多的时候为什么要使用redis而不用mysql?通常来说,当数据多、并发量大的时候,架构中可以引入Redis,帮助提升架构的整体性能,减少Mysql(或其他数据库)的压力 , 但不是使用Redis,就不用MySQL 。
redis可以作为存储的扩展部分 , 但是不能直接替换掉mysql 。redis对事务的支持还是比较简单的 。但是redis的性能和扩展性比较好,使用起来比较方便 。不会的 。只能是一种互补 。
那么为什么要使用类似redis这样的Nosql数据库呢?1) 当数据量的总大小一个机器放不下时;2) 数据索引一个机器的内存放不下时;3) 访问量(读写混合)一个实例放不下时 。
mysql读写分离只是减少了服务器的并发读写时候的压力 。从而提高高并发或者大量数据读写时候的效率 。redis做缓存,类似于hibernate的三级缓存,hibernate三级缓存是用ehcache实现的 。
当数据量超过内存空间时 , 需扩充内存,但内存价格贵 。在需求方面,mysql和redis因为需求的不同 , 一般都是配合使用 。需要高性能的地方使用Redis,不需要高性能的地方使用MySQL 。存储数据在MySQL和Redis之间做同步 。
对Redis的作用的不同解读决定了你对Redis的使用方式 。互联网数据目前基本使用两种方式来存储,关系数据库或者key value 。

    推荐阅读