各位朋友,这篇文章是针对Redis快速了解的内容,为了学好Redis在这里首先跟大家聊聊NoSQL相关内容,有了概念和方向后,我们再学习Redis大家会感觉得心应手。

【公众号dotNet工控上位机:thinger_swj】

一、NoSQL你必知的那些事儿

1、什么是NoSQL?

NoSQL是Not Only SQL的缩写,意思是“不仅仅是SQL”。也是大家通常所说的非关系型数据库的统称。NoSQL和我们熟悉的关系型数据库的作用一样,都是用来存储数据的仓库。但是在使用方法、存储特点和性能上却大相径庭。

2、为什么要使用NoSQL?

在互联网高速发展的今天,人们对网络需求日益多样化。比如我们使用的QQ、微信、抖音、快手、微博等在线互动、朋友圈、点赞、评论等。不管是在数据访问量和并发量上都是巨大的,这对服务器的数据存储和实时响应提出了更多的挑战。比如以前我们非常熟悉的12306购票网站出来的时候,为什么网站一度瘫痪呢?这个与并发的处理速度是有很大关系的。然而传统的关系型数据库在面对这些海量的数据存储,以及高访问量和高并发读写上面明显不能满足互联网的需求了。按照传统的集群部署增加服务器也难以应对超大规模、高并发、高吞吐量的需求,很多问题已经克服不了了。这时候NoSQL应运而生,从而解决了传统关系型数据库所不能解决的问题。

3、NoSQL解决的问题和特点

【1】扩展方便、数据之间没有直接的关系。

【2】数据模型非常灵活,不用像关系型数据库那样提前需要建立字段类型,随时自定义格式即可存储。

【3】适合大数据量,高性能的存取。

【4】实现了高并发读/写、高可用性。

4、大数据(big data)的定义

我们经常听说大数据,那么如何理解大数据呢?研究机构Gartner公司把大数据定义为高速、巨量且多变的数据。高速是指数据的生成或者变化速度非常快;所谓巨量是指数据的规模很大;多变是指数据类型的范围或数据中所包含的信息范围非常广泛。而NoSQL就是适应大数据时代而产生的。

二、NoSQL与传统关系型数据库对比

我们常见的传统关系型数据库(Traditional Relational DataBase,简称TRDB)有MySQL、Oracle、SQLServer、SQLite、DB2、Access等。我们将从不同方面做对比,让大家更多的了解NoSQL的特点。

1、存储形式:

【1】NoSQL的存储形式非常多样化,如键-值对、图形结构、文档形式、列族形式等。

【2】TRDB的存储都是用关系型数据模型存储,典型的就是列表结构,数据之间有强的依赖关系,用二维表的结构完成数据持久化。

2、查询速度

【1】NoSQL的数据都是在系统的缓存中,不需要专门的SQL层解析,所以查询效率非常高。

【2】TRDB的数据直接存储在硬盘中,查询的时候需要SQL专门的解析,然后进入内存实现查询,效率低。

3、扩展性

【1】NoSQL没有表间关系,可以轻松扩展,采用键-值对存储,数据之间没有耦合性。

【2】TRDB采用关系表存储,而且表间高耦合,想扩展一个表非常难,而且对其他查询影响较大。

4、ACID特性支持

【1】NoSQL一般不支持ACID特性(原子性、一致性、隔离性、持久性)它实现最终一致性。

【2】TRDB支持ACID特性,并且具有严格的数据一致性。

5、SQL语句支持

【1】NoSQL不支持SQL语句,因为没有结构性查询语言。

【2】TRDB支持SQL语句,而且可以支持很复杂的实现。

三、NoSQL数据库的分布式管理机制

为了实现高可用和高扩展、负载均衡等,NoSQL数据库在分布式处理环境下,需要对所有服务器上的数据进行处理。常见的部署方式就是通过主(Master)-从(Salve)模式的分布式方案,这类数据库软件常见的有MongoDB、Redis等。典型的架构如下:

这里的Master或一个Slave都是独立的服务器,我们称为节点(Node)。Master主要承担客户请求处理、给不同的Slave分配数据处理任务,并负责所有Slave的协调一致性等任务。Slave主要负责接收传送到本地的数据、存储和计算过程,并把结果返回给调用者。这点,大家可以先简单了解,后面我们讲解集群的时候,这些还会详细介绍。【公众号dotNet工控上位机:thinger_swj】

四、快速认识Redis的强大

1、Redis的由来

Redis是由意大利Meriza公司的创始人在2009年开发成功的产品,当时是为了解决公司内部的一个实时统计系统的性能,后来经过不断完善,到现在Redis已经非常普及的被使用。

Redis本身是用C语言开发的一款开源的、高性能的键值对存储数据库,才用BSD协议,并且支持多种数据类型:字符串、列表、哈希、有序集合、无序集合等。内置复制、Lua脚本、LRU回收、事务等,以及高性能的持久化功能。

2、Redis的特性

【1】支持多种计算机编程语言。如C#、Java、C、C++、Python、PHP、Lua、Ruby等。

【2】支持多种数据类型。如String、Hash、List、Set、SortedSet等。

【3】读/写速度快、高性能。官方给的数据是11万次/秒读取,8.1万次/秒写入。因为Redis的操作是在内存中进行的,所以速度的惊人的。实际测试也是这个速度。

【4】支持持久化。Redis每隔一段时间可以自动实现备份,在重启的时候会自动加载到内存中。主要有AOF和RDB方式,这个后面我们会详细讲到。

【5】高可用主从复制、分布式集群与负载均衡。Redis的Cluster支持分布式,可以轻松实现分布式集群,Redis Sentinel支持高可用。这个我们都在后面的课程中详细讲解。

3、Redis的使用场景

【1】做缓存。这个是使用最多的场景。Redis的缓存速度和查询速度非常快,使用方便。比如缓存商品信息、购物车等数据。

【2】实现消息队列系统。Redis运行稳定、速度快,可以实现消息订阅发布。Redis还有阻塞队列的命令,使得轻松完成队列,比如秒杀、抢购等。

【3】做实时系统、消息系统。比如实现在线聊天系统。

【4】实现排行榜应用。Redis实现了有序集合。可以轻松对百万级的用户实现排名。

【5】数据过期处理。我们可以设置数据的过期时间,从而实现过期数据的查找和删除等。

【6】做大型社交平台。各种社交APP都可以用Redis做缓存和实时数据处理。

【7】分布式集群架构中的Session分离。采用分布式集群部署,可以满足web应用系统大规模访问量的需求。而实现分布式集群部署,就要解决Session的统一问题。而Redis可以实现Session共享机制。

常哥带你认识NoSQL和Redis的强大的更多相关文章

  1. 一篇文章带你了解NoSql数据库——Redis简单入门

    一篇文章带你了解NoSql数据库--Redis简单入门 Redis是一个基于内存的key-value结构数据库 我们会利用其内存存储速度快,读写性能高的特点去完成企业中的一些热门数据的储存信息 在本篇 ...

  2. NoSQL 之 Redis配置与优化

    NoSQL 之 Redis配置与优化 1.关系数据库与非关系型数据库概述 2.关系数据库与非关系型数据库区别 3.非关系型数据库产生背景 4.Redis简介 5.Redis安装部署 6.Redis 命 ...

  3. NoSQL和Redis简介及Redis在Windows下的安装和使用教程

    转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/103.html?1455869099 NoSQL简介 介绍redis前,我 ...

  4. NoSQL之Redis配置与优化

    NoSQL之Redis配置与优化 目录 NoSQL之Redis配置与优化 一.关系数据库和非关系数据库 1. 关系型数据库 2. 非关系型数据库 3. 非关系型数据库产生背景 4. 关系型数据库和非关 ...

  5. 【NoSql】Redis

    [NoSql]Redis 一. 文档 1. 官网 2. Windows 安装包 3. C# Driver a. ServiceStack.Redis 最新版本是收费的 b. StackExchange ...

  6. 【凯子哥带你学Framework】Activity启动过程全解析

    It’s right time to learn Android’s Framework ! 前言 学习目标 写作方式 主要对象功能介绍 主要流程介绍 zygote是什么有什么作用 SystemSer ...

  7. NoSQL之Redis高级实用命令详解--安全和主从复制

    Android IOS JavaScript HTML5 CSS jQuery Python PHP NodeJS Java Spring MySQL MongoDB Redis NOSQL Vim ...

  8. NoSQL:redis缓存数据库

    一 Redis介绍 Redis和Memcached类似,也属于key-value nosql 数据库 Redis官网redis.io, 当前最新稳定版4.0.1 和Memcached类似,它支持存储的 ...

  9. 【凯子哥带你学Framework】Activity界面显示全解析(下)

    咱们接着上篇继续讲,上篇没看的请戳:[凯子哥带你学Framework]Activity界面显示全解析(上) 如何验证上一个问题 首先,说明一下运行条件: //主题 name="AppThem ...

随机推荐

  1. HotSpot的对象模型(6)

    接着上一篇,我们继续来讲oopDesc相关的子类. 3.instanceOopDesc类 instanceOopDesc类的实例表示除数组对象外的其它对象.在HotSpot中,对象在内存中存储的布局可 ...

  2. day5:isinstance&代码块&分支&while循环

    1.判断类型 isinstance语法:用法一: isinstance(要判断的值,要判断的类型) 返回True 或者 False用法二: isinstance(要判断的值,(可能的类型1,可能的类型 ...

  3. java中同步异步阻塞和非阻塞的区别

    同步 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回. 按照这个定义,其实绝大多数函数都是同步调用(例如sin, isdigit等).但是一般而言,我们在说同步.异步的时候,特 ...

  4. Python3 生成器解析

    第6章 函数 6.1 函数的定义和调用 6.2 参数传递 6.3 函数返回值 6.4 变量作用域 6.5 匿名函数(lambda) 6.6 递归函数 6.7 迭代器 6.8 生成器 6.9 装饰器 6 ...

  5. 【C#】根据开始时间和结束时间筛选存在的信息

    背景 业务需求中,需要根绝开始时间和结束时间筛选一段时间内的任务存在个数. 示例图片 根据开始时间 9:00到 结束时间11:00 筛选信息 总共有这么四种情况可能出现 插入测试数据 CREATE T ...

  6. STL源码剖析:算法

    启 算法,问题之解法也 算法好坏的衡量标准:时间和空间,单位是对数.一次.二次.三次等 算法中处理的数据,输入方式都是左闭又开,类型就迭代器, 如:[first, last) STL中提供了很多算法, ...

  7. consul++ansible+shell批量下发注册node_exporter

    --日期:2020年7月21日 --作者:飞翔的小胖猪  文档功能说明: 文档通过ansible+shell+consul的方式实现批量下发安装Linux操作系统监控的node_exporter软件, ...

  8. DJANGO-天天生鲜项目从0到1-008-列表页

    本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...

  9. vue+springboot文件下载

    //vue element-ui <el-button size="medium" type="primary" @click="downloa ...

  10. flask中的endpoint是什么

    app.view_functions 是一个字典,里面是存储的是 endpoint 与 视图函数的键值对,如果没指名函数视图的endpoint,默认是函数名,而 url_map 是一个列表,里面是ur ...