Redis的一点入门了解

Redis

NoSql概述

1、单机MySQL的时代

90年代,一个网站的访问量一般不会太大,单个数据库完全足够应付,技术上更多的会去使用静态页面html,对此服务器压根没多少压力;

但即使在这样的情况下,也会存在着一些当时难以解决的问题:

  1. 数据量如果太大,一个机器无法承受
  2. 数据的索引太多,一台机器内存的无法处理
  3. 访问量如果过多,一台服务器也无法承受

在当时,如果有三种情况的其中一种,那么就面临会崩溃的结局。

  1. Memcached(缓存) + MySQL + 垂直拆分(读写分离)

网站80%的情况都是在读数据,每一次都要去查询数据库的话就会非常麻烦,所以如果想要减轻数据库的压力,就可以选择使用缓存来保证效率。

发展历程:优化数据库和索引 ->文件缓存(IO) -> Memcached(当时最热门的技术)

  1. 分库分表 + 水平拆分 +MySQL集群

在这一时期,技术和业务都在急速发展,对人的要求也越来越高

本质上来说还是:数据库的读和写的问题

早些年MySAM:锁表,十分影响效率,高并发下会出现严重的锁问题

转战Innodb:行锁

慢慢的就开始使用分库分表来解决写的压力!MySQL在这是就已经推出了表分区,但并没有引起太多的重视

MySQL的集群,非常好的满足了那个时代的所有需求,成为最优解。

  1. 当今时代
  1. -2020这十年间,世界飞速发展,已经发生了翻天覆地的变化;(定位,音乐,热门榜单也是一种数据)

在这时的MySQL等关系型数据库就已经不够用了,数据量太大太大,变化也非常非常快

MySQL有的使用它来存储一些比较大的文件,博客以及图片,数据库的表一旦变大,效率就急剧下降。如果有一种数据库专门去处理这些数据,MySQL的压力就会得到减轻(怎样去解决这个问题变成当务之急),而在大数据的IO压力下,数据库的表几乎没法承担更大的数据。

目前一个基本的互联网项目需要具备的东西:

为什么要用NoSQL

用户的个人信息,社交网络,地理位置……等,用户自己产生的数据,用户日志等数据在爆发式的增长,这时候我们就需要NoSQL数据库了,因为它能很好的处理以上情况,具体怎么解决,继续往下看。

什么是NoSQL

NoSQL = Not Only SQL(不仅仅是SQL 而不是说非SQL!)

关系型数据库基本都是:表、行、列组成

泛指非关系型数据库的,随着web2.0互联网的诞生,传统的关系型数据库很难对付web2.0时代,尤其是超大规模的高并发的社区,渐渐暴露出很多难以克服的问题,而NoSQL在当今大数据环境下发展的十分迅速,Redis是发展的最快的,而且是我们当下必须要掌握的一门技术。

很多的数据类型-用户的个人信息、社交网络、地理位置等,这些数据类型的存储不需要一个固定的格式,也不需要多余的操作就可以横向扩展。Map<String, Object>使用键值对来控制。

NoSQL特点

解耦

  1. 方便扩展(数据之间没有任何关系,可以直接扩展数据)
  2. 大数据量的情况下也可以高性能运作(Redis一秒可以写8万次,可以读取11万次,NoSQL的缓存记录级,是一种细粒度的缓存,性能会比较高)
  3. 数据类型是多样性的(不需要通过实现设计数据库再使用,只要做到随去随用,如果数据量非常大的表,很多情况下就很难设计一个合格的数据库)
  4. 传统RDBMS和NoSQL

传统的RDBMS

- 结构化组织

- SQL

- 数据和关系都存在单独的表中

- 存在操作语言和数据定义语言

- 非常严格的一致性

- 基础的事务

- ……

NoSQL

- 不仅仅是数据

- 没有固定的查询语言

- 键值对存储,列存储,文档存储,图形数据库(社交关系)

- 最终一致性

- CAP定理和BASE(狡兔三窟)

- 高性能、高可用、高可扩

- ……

扩展:3V+3高

大数据时代的3V:主要是描述问题的

  1. 海量Volume
  2. 多样Variety
  3. 实时Velocity

大数据时代的3高:主要是对程序的要求

  1. 高并发
  2. 高可扩
  3. 高性能

实际上,在公司中去工作的时候,一般都是:NoSQL + RDBMS一同使用,这样子的状态才是最强的状态,阿里巴巴的架构演进就是如此

技术没有高低之分,贵贱之别,只有正确的结合各个技术的闪光点,才能发挥出最大作用。

NoSQL的四大分类

KV键值对:

新浪-Redis

美团-Redis + Tair

阿里、百度-Redis + memecache

文档型数据库(bson格式和json一样):

MongoDB(一般必须要掌握)

MongoDB是一个基于分布式文件存储的数据库,C++编写,主要用来处理大量的文档

MongoDB是一个介于关系型数据库和非关系型数据库中间的产品,MongoDB是非关系型数据库中,种类最丰富,最像关系型数据库的

ConthDB

列存储数据库

HBase

分布式文件系统

图关系数据库:

他不是存图片的,存的是关系,比如:朋友圈社交图,广告推荐

例如:Neo4j, infoGrid

Redis入门

概述

Redis是什么?

Redis(Remote Dictionary Server),即远程字典服务

是一个开源的使用ANSI C语音编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。且免费开源,是当下最热门的NoSQL技术之一,也被人们称之为结构化数据库。

与其他同类型有所区别的是:redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步

Redis能干嘛
  1. 内存存储、持久化,内存中是断电即失,所以说持久化很重要(rdb、aof)
  2. 效率高,可以用于高速缓存
  3. 发布订阅系统
  4. 地图信息分析
  5. 计时器、计数器(记录浏览量)
  6. ……

NoSQL有什么特性
  1. 多样的数据类型
  2. 持久化
  3. 集群
  4. 事务

基础的知识
Redis是单线程的

Redis的性能瓶颈不是CPU,而是根据机器的内存和网络带宽,既然单线程可以实现,那就干嘛要去用复杂一点的多线程?

Redis是C语音写的,官方提供的数据为100000+的QPS,完全不比同样是使用key-value的Memecache差

那么另一个问题,既然是单线程的,为什么还会这么快?
  1. 思维误区1:高性能的服务器一定是多线程的
  2. 思维误区2:多线程(CPU上下文会切换)一定比单线程效率高

首先要理解基本的计算机组成原理,CPU>内存>硬盘的处理速度的

核心:redis是将所有的数据全部放在内存中,所以说使用单线程去操作效率就是最高的,多线程(CPU上下文切换消耗的时间相对就比较多),对于内存系统来说,如果没有上下文切换,效率就是最高的,多次读写都在一个CPU上,怎能不快呢

五大数据类型

Redis 是一个开源( BSD许可)的,内存中的数据结构存储系统,它可以用作数据库缓存消息中间件MQ

它支持多种类型的数据结构,如字符串(strings),散列(hashes),列表(lists),集合(sets),有序集合(sorted sets)与范围査询bitmaps ,hyperloglogs和地理空间(geospatial)索引半径査询。

Redis 内置了复制(replication),LUA脚本(Luascripting),LRU驱动事件(LRU eviction),事务(transactions)和不同级别的磁盘持久化(persistence),并通过 Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(high availability)。

Redis-Key

String

数据结构是相同的

String类似的使用场景:value除了是字符串,还可以是数字

计数器

统计多单位的数量

粉丝数

对象缓存存储

List

Set

Hash

Zset

三种特殊数据类型

Geospatial

Hyperloglog

Bitmaps

事务

①原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。

②一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。

③隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

④持久性(durability)。持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

在Redis事务没有没有隔离级别的概念!

在Redis单条命令式保证原子性的,但是事务不保证原子性!

乐观锁

①当程序中可能出现并发的情况时,就需要保证在并发情况下数据的准确性,以此确保当前用户和其他用户一起操作时,所得到的结果和他单独操作时的结果是一样的。

②没有做好并发控制,就可能导致脏读、幻读和不可重复读等问题。

在Redis是可以实现乐观锁的!

总结:乐观锁和悲观锁的区别。

悲观锁: 什么时候都会出问题,所以一直监视着,没有执行当前步骤完成前,不让任何线程执行,十分浪费性能!一般不使用!

乐观锁: 只有更新数据的时候去判断一下,在此期间是否有人修改过被监视的这个数据,没有的话正常执行事务,反之执行失败!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/27946.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】程序地址空间之动态库的加载

我们先进行一个整体轮廓的了解&#xff0c;随后在深入理解细节。 在动态库加载之前还要说一下程序的加载&#xff0c;因为理解了程序的加载对动态库会有更深的理解。 轮廓&#xff1a; 首先&#xff0c;不管是程序还是动态库刚开始都是在磁盘中的&#xff0c;想要执行对应的可…

IT入门知识博客文章大纲第一部分《IT基础知识》(1/10)

目录 IT入门知识博客文章大纲第一部分《IT基础知识》&#xff08;1/10&#xff09; 1.引言 2.第一部分&#xff1a;IT基础知识 2.1 计算机硬件 CPU&#xff1a;计算机的心脏 内存&#xff1a;数据的临时居所 存储设备&#xff1a;数据的长期仓库 输入输出设备&#xff1…

PostgreSQL基础(十四):PostgreSQL的数据迁移

文章目录 PostgreSQL的数据迁移 PostgreSQL的数据迁移 PostgreSQL做数据迁移的插件非常多&#xff0c;可以从MySQL迁移到PostgreSQL也可以基于其他数据源迁移到PostgreSQL。 这种迁移的插件很多&#xff0c;这里只说一个&#xff0c;pgloader&#xff08;非常方便&#xff0…

Coursera耶鲁大学金融课程:Financial Markets 笔记Week 01

Financial Markets 本文是学习 https://www.coursera.org/learn/financial-markets-global这门课的学习笔记 这门课的老师是耶鲁大学的Robert Shiller https://en.wikipedia.org/wiki/Robert_J._Shiller Robert James Shiller (born March 29, 1946)[4] is an American econ…

SQL Server Management Studio (SSMS) 20.1 - 微软数据库管理工具

SQL Server Management Studio (SSMS) 20.1 - 微软数据库管理工具 请访问原文链接&#xff1a;https://sysin.org/blog/ssms/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;sysin.org 笔者注&#xff1a;SQL Server 2014 及之前版本内置…

基于负相关误差函数的4集成BP神经网络matlab建模与仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 MATLAB2022a 3.部分核心程序 ...............................................................…

植物大战僵尸杂交版 v2.0.88 mac版 Plants vs. Zombies 杂交版下载

特别注意&#xff1a;该游戏最低系统要求为macOS Sonoma 14.X&#xff0c;低于此系统版本的请勿下载&#xff01; 游戏介绍 植物大战僵尸杂交版是由B站UP主“潜艇伟伟迷”制作的一款结合了《植物大战僵尸》原有元素与创新玩法的游戏。这款游戏以其独特的“杂交”植物概念在B站…

等待 chrome.storage.local.get() 完成

chrome.storage.local.get() 获取存储处理并计数&#xff0c;内部计数正常&#xff0c;外部使用始终为0&#xff0c;百思不得其解。 如何在继续执行之前等待异步chrome.storage.local.get()完成-腾讯云开发者社区-腾讯云 (tencent.com) 原来我忽略了异步问题&#xff0c;最简…

mybatis中SQL语句运用总结

union 连接查询 连接两个表后会过滤掉重复的值 <resultMap id"BaseResultMap" type"com.sprucetec.pay.etl.model.BillDetail"><id column"id" jdbcType"INTEGER" property"id"/><result column"pay_…

SSM 基于大数据技术的创业推荐系统-计算机毕业设计源码02979

摘 要 科技进步的飞速发展引起人们日常生活的巨大变化&#xff0c;电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流&#xff0c;人类发展的历史正进入一个新时代。在现实运用中&#xff0c;应用软件的工作…

cocos creator如何使用cryptojs加解密(及引入方法)

cocos creator如何使用cryptojs加解密&#xff08;及引入方法&#xff09; 如果想转请评论留个言并注明原博 Sclifftop 13805064305 阿浚 cocos creator如何使用cryptojs加解密&#xff08;及引入方法&#xff09; 步骤 获取库 1. npm install crypto-js -g&#xff0c;加不加…

除了英伟达,这些AI概念公司在2024年还有巨大的投资价值(五)

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 猛兽财经在英伟达还没拆股前&#xff0c;股价还是100多美元时&#xff08;2019年&#xff09;就曾多次公开发布文章呼吁大家关注并投资英伟达&#xff0c;以下是猛兽财经在2019年到2022年间公开发布的关于英伟达的部分文…

ARM32开发--PWM高级定时器

目录 文章目录 前言 目标 学习内容 需求 高级定时器通道互补输出 开发流程 通道配置 打开互补保护电路 完整代码 练习题 总结 前言 在嵌入式软件开发中&#xff0c;PWM&#xff08;脉冲宽度调制&#xff09;技术被广泛应用于控制各种电子设备的亮度、速度等参数。…

训练营第三十八天 | 309.最佳买卖股票时机含冷冻期动态规划系列七总结714.买卖股票的最佳时机含手续费股票问题总结篇!

309.最佳买卖股票时机含冷冻期 力扣题目链接(opens new window) 给定一个整数数组&#xff0c;其中第 i 个元素代表了第 i 天的股票价格 。 设计一个算法计算出最大利润。在满足以下约束条件下&#xff0c;你可以尽可能地完成更多的交易&#xff08;多次买卖一支股票&#x…

最实用的 LeetCode 刷题指南

暑期实习基本结束了&#xff0c;校招即将开启。当前就业环境已不再是那个双向奔赴时代了。求职者在变多&#xff0c;岗位在变少&#xff0c;要求还更高了&#xff0c;最近社群又开始活跃起来了&#xff0c;各种讨论、各种卷。 为方便大家快手入手、节省时间&#xff0c;我整理…

基于vue的游戏网站设计与实现-计算机毕业设计源码02473

摘要 随着计算机科学技术日渐成熟&#xff0c;人们已经深刻认识到了计算机功能的强大&#xff0c;计算机已经进入到了人类社会发展的各个领域&#xff0c;并且发挥着十分重要的作用。通过管理系统在电脑上的应用&#xff0c;人们能更好的管理信息&#xff0c;储存数据。为了能够…

Django REST framework关联序列化器详解:掌握复杂关系的序列化与反序列化艺术

系列文章目录 Django入门全攻略&#xff1a;从零搭建你的第一个Web项目Django ORM入门指南&#xff1a;从概念到实践&#xff0c;掌握模型创建、迁移与视图操作Django ORM实战&#xff1a;模型字段与元选项配置&#xff0c;以及链式过滤与QF查询详解Django ORM深度游&#xff…

【仪器仪表/电源专题】浮地信号的测试的四种方案对比

接地信号和浮地信号区别 所有的电压测量都是差分测量&#xff0c;差分测量定义为两点之间的电压差。所以会分成两类&#xff1a; 1.参考地电平测量&#xff08;有时也叫接地信号&#xff09; 2.非参考地电平测量&#xff08;也称为浮地测量&#xff09; 测试信号可以分为接地信…

海外仓系统如何让海外仓受益,WMS海外仓系统使用指南

随着跨境电商业务的快速发展&#xff0c;海外仓面临着需要更加高速运转的巨大挑战。 当海外仓出现因为手动作业导致效率低下&#xff0c;成本不断飙升或者出现库存管理问题的时候&#xff0c;意味着是时候引入一套合适的海外仓管理系统了。 对于寻求海外仓业务流程优化的企业…

flask部署mtcnn

目录 打印人脸检测信息 输出结果 保存检测结果 浏览器查看nginx&#xff08;nginx配置这里就不多介绍了&#xff09; url图片检测人脸 输出结果 Flask hello-world Flaskmtcnn python调flaskmtcnn 打印人脸检测信息 import cv2 from mtcnn.mtcnn import MTCNNimg cv2.c…