再说Redis之前,想先说一下NoSQL。在最早的单机时代,随着数据的增加一台机器可能放不下了。同时索引占用的内存空间也会越来越大。对请求的读写操作影响很大。于是就在数据库之前增加了一层保护层 — 缓存。另外由于关系型数据库MySQL、Oracle等在某些场景下读写效率较差,灵活性较低,I/O瓶颈限制。使得NoSQL应用的越来越广泛。

  NoSQL

  NoSQL, Not Only SQL,也就是我们所说的非关系型数据库。常用的有Redis、Memcached、MongoDB等。

  NoSQL数据库具有强大的读写性能,主要原因还是因为它的无关系性,数据结构相对简单。比如MySQL这样的关系型数据库我们需要实现建立好表结构,如果需要增加字段还需要通过alert table来进行新增。但是非关系型数据库就没有这么麻烦。我们可以随时自定义数据格式。

  

  数据库比较

  关系型数据库

  结构化查询语言(SQL语句)

  严格的一致性

  基础事物非关系型数据库

  没有特定的查询语言

  有K-V存储,列存储,文档存储,图形数据库

  最终一致性

  非结构化和不可预知的数据

  高性能,高可用和伸缩性

  CAP原则,指的是在一个分布式系统中,Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性)NoSQL四大分类

  KV键值对,如Redis。用于内容缓存,主要用于处理大数据的高访问负载,也用于一些日志系统等.

  列存储数据库,如HBase。分布式的文件系统。

  文档性数据库,如MongoDB。主要用于WEB应用。也是k-v结构的。

  图形数据库,如Neo4J。主要用于社交网络,推荐系统等.Redis

  Redis:Remote Dictionary Server (远程字典服务器)。

  是一个用C语言编写的,开源的,高性能的(K/V)分布式内存数据库。

  特点:

  支持数据的持久化

  支持丰富的数据类型,String、List、Hash、Set、Zset

  支持数据备份,即master-slave

  单线程且支持事物应用场景:

  由于可以持久化,因此可以用来存储数据。

  消息队列系统

  社交关系(如,共同关注的人,粉丝列表等)

  排行榜、热点新闻列表

  秒杀系统为什么那么快:

  Redis是纯内存操作,需要的时候需要我们手动持久化到硬盘中

  Redis是单线程,从而避开了多线程中上下文频繁切换的操作。

  Redis数据结构简单、对数据的操作也比较简单

  使用底层模型不同,它们之间底层实现方式以及与客户端之间通信的应用协议不一样,Redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求

  使用多路I/O复用模型,非阻塞I/OI/O 多路复用技术是为了解决进程或线程阻塞到某个 I/O 系统调用而出现的技术,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪,就是这个文件描述符进行读写操作之前),能够通知程序进行相应的读写操作

  Redis的数据类型

  Redis支持丰富的数据类型

  String

  字符串是最基本的一个数据类型,String是二进制安全的,也就是说String可以包含任何数据,因此我们可以存放序列化之后的对象或者是图片内容。

  一条redis数据可以存放最大的字符串为512M。

  Hash

  我们可以把他理解为Java中的map,Python中的dict。是一个键值对的集合。适合于存储对象

  List

  是一个字符串的集合,默认按照插入顺序排序,我们也可以通过不同的命令将数据插入到集合的头部或者尾部

  Set

  用于存放无序不重复的集合,集合中最大的成员数为 232 - 1 (4294967295,每个集合可存储40多亿个成员)。

  Zset

  即 sorted set ,有序不重复集合。每个元素都会有一个对应的double类型的分数(score),通过这个分数进行排序。元素不允许重复,但是分数可以。

NoSQL&&Redis介绍的更多相关文章

  1. NoSQL & Redis 介绍、缓存穿透 & 击穿 & 雪崩

    1. NoSql 简介 2. Redis 简介 2.1 Redis 的起源 2.2 缓存过期 & 缓存淘汰 3. 缓存异常 1)缓存穿透 2)缓存击穿 3)缓存雪崩 4)总结 1. NoSQL ...

  2. [NOSQL] Redis介绍

    Redis概述 Redis是Salvatore Sanfilippo在2009年为其初创公司LLOOGG开发的,眼下仍是独立项目.但VMWare赞劣了项目(作者是其雇员).它採用C语言实现.因此性能非 ...

  3. Redis介绍以及安装(Linux)

    Redis介绍以及安装(Linux) redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcached类似,但很大程度补偿了memcached的不足,它支持存储的 ...

  4. redis笔记总结之redis介绍

    一.Redis介绍: redis的发展历史简单的理解为因为使用类似MySql这类关系型数据库不方便进而开发的开源的.轻量级的.非关系型的,直到现在一直不断完善的一款NoSql数据库.具体的介绍大家可以 ...

  5. Redis介绍以及安装(Linux)

    Redis介绍以及安装(Linux) redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcached类似,但很大程度补偿了memcached的不足,它支持存储的 ...

  6. NoSQL -- Redis使用

    NoSQl简介: ubuntun CTRL+alt+F1 图形切换到命令行 CTRL+alt+F7  命令行切换到图形界面 redis介绍 + 实践 Redis是什么? Redis 安装 edis是当 ...

  7. Redis介绍及部署在CentOS7上(一)

    0.Redis目录结构 1)Redis介绍及部署在CentOS7上(一) 2)Redis指令与数据结构(二) 3)Redis客户端连接以及持久化数据(三) 4)Redis高可用之主从复制实践(四) 5 ...

  8. redis 介绍

    缓存数据库介绍 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库,随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是 ...

  9. 基于Python操作redis介绍

    (注:本文部分内容摘自互联网,由于作者水平有限,不足之处,还望留言指正.) 毕业前的最后一个学期(2016.03),龙哥结婚了.可是总有些人喜欢嘲笑别人,调侃我.当时我就理直气壮的告诉他们,等龙哥孩子 ...

随机推荐

  1. 1. testNG+Maven 环境搭建

    一:使用的工具 : TestNG 6.9.10 Maven 3.5 IDEA 二:创建maven项目,在pom.xml添加依赖 <?xml version="1.0" enc ...

  2. 0606-Zuul构建API Gateway-Zuul过滤器以及禁用Zuul过滤器

    一.概述 针对Spring Cloud的Zuul配备了许多在代理和服务器模式下默认启用的ZuulFilter bean. 有关启用的可能过滤器,请参阅zuul过滤器包. 二.Zuul过滤器使用 2.1 ...

  3. strtoul函数的使用

    函数原型: unsigned long strtoul(const char *nptr,char **endptr,int base ) 参数1:字符串起始地址参数2:返回字符串有效数字的结束地址, ...

  4. 在eclipse添加第一次添加Python项目时,提示: Project interpreter not specified

    按图片操作,添加Python的路径,就能解决该问题

  5. Jmeter+jenkins如何快速搭建接口和性能测试持续集成解决方案-[基于windows篇]

    最近在用Jmeter本来想写一个详细的使用教程,突然看到有前辈已经写好了不错的教程,特此"借花献佛"整理出来分享给大家! Jenkins + Jmeter 构建接口.性能测试持续集 ...

  6. [golang note] 内建类型

    基础类型 √ golang内建基础类型有布尔类型.整数类型.浮点类型.复数类型.字符串类型.字符类型和错误类型. 复合类型 √ golang支持的复合类型有指针.数组.数组切片.字典.通道.结构体和接 ...

  7. opencart 单入口文件简单分析

    opencart 单入口文件简单分析   opencart是基于mvcl的商城系统,据说是一个外国有人单独开发.比较牛叉.但是又不大符合国人习惯,目前国内opencart社区也是不少. 简单分析了下单 ...

  8. 【android】来电悬浮窗

    先看下效果图 说下思路: 1:监听来电广播 2:根据来电号码,和本地数据库做匹配,有记录的,则提取出头像.名字.职位,生成悬浮窗 3:监听来电广播,如果当前行为是空闲的(没有任何通话行为),则删除掉悬 ...

  9. rootpw密码生成方法/c-exit

    linux kickstart文件里rootpw密码可以使用明文,也可以使用加密过的值,这里主要介绍下三种加密方法:md5.sha256.sha512 使用明文的方法 rootpw "pas ...

  10. 自我管理--拖延 vs 心理

    案例1:你在销售公司产品,需要更多客户,这时你收到一条短信,说对你们产品感兴趣,让你马上发送详细资料看看,语气颇为傲慢.你有点恼火,这个人一点都不客气,于是两小时后你才发送过去.   案例2:这个月的 ...