1:redis简介:

redis是Nosql数据库中使用较为广泛的非关系内存数据库,redis内部是一个key-value存储系统。它支持存储的value类型相对更多,包括string(字符串),list(链表),set(集合),zset(sorted set-有序集合)和hash(哈希类型,类似java中的map)。redis基于内存运行并持久化的NoSQL数据库之一,也被人们称为数据库结构服务器。

2:互联网时代背景下,为什么使用NoSQL?

1)当数据量的总大小一个机器放不下时。

2)数据索引一个机器的内存放不下时。

3)访问量(读写混合)一个实例放不下

单时代模型:

项目中yarn init_Redis

如果每次存储成千上万条数据,这样会导致Mysql的性能很差,存储以及读取速度很慢,然后就演变成缓存+mysql+垂直拆分的方式。

项目中yarn init_redis_02

cache作为中间缓存:

将所有的数据先保存到缓存中,然后再存入mysql中,减少数据库压力,提高效率。但是当数据再次增加到又一个量级,上面的方式也不能满足需求,由于数据库的写入压力增加,Memcached只能缓解数据库的读取压力。读写集中在一个数据库不堪重负,大部分网站开始使用主从复制技术来达到读写分离,以提高读写性能和读写的可扩展性。Mysql的master-slave模式成为这个时候的网站标配。

项目中yarn init_Redis_03

主从离模式

在redis的高速缓存,mysql的主从复制,读写分离的基础之上,这是mysql主库的写压力开始出现瓶颈,而数据量的持续猛增,由于MyISAIM使用表锁,在高并发下会出现严重问题,大量的高并发mysql应用开始使用InnobDB引擎代替MyISAM。

项目中yarn init_Redis_04

memcached和redis的比较:

项目中yarn init_数据结构_05

redis的数据结构:

2.5Redis的数据结构:

前言:Redis中存储的数据都为字符串格式的。下面来分别介绍Redis中常用的数据结构。

  • string数据结构

太简单了,略过。

  •  list数据结构

概述: 什么是list ,list是一种数据结构,可以当做队列和栈来使用。

项目中yarn init_数据结构_06

当你从左边添加数据,再从左边取数据,就模拟出栈;当你从右边添加数据,再从左边取数据,就模拟出队列。因此Redis真的很强大,看到栈和队列这样的数据结构,你难道就不激动吗?这样的数据结构太TM好了,能帮我们处理很多棘手的问题。这里我先卖个关子,下面会介绍我在项目中是如何使用Redis解决棘手的问题。

  • set集合

和list结构差不多,这里不再啰嗦。

下面就是操作set的一些命令。

项目中yarn init_Redis_07

  • hash数据结构

项目中yarn init_Redis_08

图中的"user:100"就相当于key,而它所指向的类似于表结构的数据就是value,这样的数据结构有利于存储对象数据。也是非常常用的方法。

 

 

注意:

redis指令不区分大小写,但是出于规范考虑,应该使用大写
redis中存放的键是区分大小写的.

 Redis常用命令文档:http://redis.readthedocs.io/en/2.6/