【Redis】——NoSql与Redis之间的XXOO

NoSql概念

NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,它泛指非关系型的数据库

分类

Redis概念

Redis 是一个高性能开源C语言写的Nosql非关系型数据库),数据保存在内存中。

Redis 是以key-value形式存储,和传统的关系型数据库不一样。不一定遵循传统数据库的一些基本要求,比如说,不遵循sql标准,事务,表结构等等,非关系型数据库严格上不是一种数据库,应该是一种数据结构化存储方法的集合。

特点

1.数据保存在内存,存取速度快,并发能力强

2.它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、 zset(sorted set --有序集合)和hash(哈希类型)。

3.redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部分场合可以对关系数据库(如MySQL)起到很好的补充作用。

4.它提供了Java,C/C++,C#,PHP,JavaScript等客户端,使用很方便。

5.Redis支持集群主从同步、负载均衡)。数据可以主服务器向任意数量从的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。

6.支持持久化,可以将数据保存在硬盘的文件中

7.支持订阅/发布(subscribe/publish)功能 QQ群

1、数据存放:存放到内存中,还能不定期持久化到磁盘。存取速度快,并发能力强,断电后数据不丢失。

2、支持Value类型更多。

3、多种客户端(语言 java php c# js)

4、支持集群来扩展空间 8G+8G+16G

5、开源(免费还有很多人维护)

补充

Mysql、Memcached和Redis的比较

 

mysql

redis

memcached

类型

关系型

非关系型

非关系型

存储位置

磁盘

磁盘和内存

内存

存储过期

不支持

支持

支持

读写性能

非常高

非常高

使用场景

1.缓存(新闻列表)

经常查询数据,放到读速度很快的空间(内存),以便下次访问减少时间。减轻数据库压力,减少访问时间.而redis就是存放在内存中的。

Hibernte二级缓存(ehcache)

2.计数器应用

网站通常需要统计注册用户数网站总浏览次数等

新浪微博转发数、点赞数

3.实时防攻击系统

暴力破解:使用工具不间断尝试各种密码进行登录。防:ip--->num,到达10次以后自动锁定IP,30分钟后解锁

解决方案:

     1、存数据库

 2、static Map<String,int> longinFailNumMap;

          Map存储空间有限,大批量就不行,并且断电以后数据丢失。

问题:Redis能解决

    1、每次查询数据库,查询速度慢,多次写 内存

    2、断电会丢失数据,多个节点,不能共用   redis集群,容量可以无限大,可以共享数据、、

Key  value  time  企业手法(封ip)

192.   1      1s

 0.2 1 1.9 15次

并且支持过期  

4.排行榜

总积分榜,今日积分榜,周积分,月积分,季度积分

方案:从数据库中查出来计算.

5.设置有效期的应用

设定一个数据,到一定的时间失效。 自动解锁,购物券

6.自动去重应用

Uniq 操作,获取某段时间所有数据排重值 这个使用 Redis 的 set 数据结构最合适了,只需要不断地将数据往 set 中扔就行了,set 意为 集合,所以会自动排重。

7.队列

构建队列系统 使用 list 可以构建队列系统,使用 sorted set 甚至可以构建有优先级的队列系统。

秒杀可以把名额放到内存队列(redis),内存就能处理高并发访问。限流

8.消息订阅系统

Pub/Sub 构建实时消息系统 Redis 的 Pub/Sub 系统可以构建实时的消息系统,比如很多用 Pub/Sub 构建的实时聊天系统 的例子。

比如QQ群消息

 

 

 

猜你喜欢

转载自blog.csdn.net/qq_43097451/article/details/84846508
今日推荐