为什么要学Redis(NoSQL数据库)

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,经济版 1GB 1个月
简介: 为什么要学Redis(NoSQL数据库)

🍖 NoSQL数据库引入

🥩 为什么要学NoSQL

 回顾之前的java后端学习历程,我们可以发现以往学习的技术可以被大致分为以下两种类型:其一,解决功能性问题:Java、Jsp、RDBMS、Tomcat、HTML、Linux、JDBC、SVN,通过这几门技术的学习就可以实现基础的业务逻辑编写;其二,解决扩展性问题:Struts、Spring、SpringMVC、Hibernate、Mybatis,以上几种框架或者说是技术可以增加我们程序的可扩展性,在对功能进行更改的时候就会简化操作

 当然,你可能会疑惑这些技术是不是就已经完全足够我们使用了,为什么还要学习Redis呢?那是因为,程序最终的功能是面向用户,但是用户群体肯定不止几个人而是一个很大的概念,当你的程序投入使用的时候也就代表着它要面临性能所带来的诸多问题。而以下技术就是用来解决性能问题:NoSQL、Java线程、Hadoop、Nginx、MQ、ElasticSearch


🥩 web时代发展的问题及解决方案

image.png

如何解决CPU及内存压力?

 解决web 2.0 时代存在的CPU及内存压力问题,方案就是将原本的一台服务器采用分布式的方式部署在许多台服务器上,分布式部署需要在所有服务器之前使用负载均衡技术平均分配发送过来的所有请求,一般这个技术就是Nginx。但是分布式服务器就会存在一个关于session对象的问题,那就是如果同一个用户发送两次请求但是却被分配给了两个不同的服务器,那么这个时候如何正确读取到该用户的session对象就显得异常重要 image.png 上图就画出了分布式服务器的组件图,并给出了session存储的四个方案,其中NoSQL数据库存储session对象就是很好的一个解决方案,因为NoSQL中的数据都存储在内存中,数据读取速度很快且无需经过IO操作


如何解决IO压力?

 我们可以对数据库和表中的数据进行水平切分、垂直切分、读写分离等操作,在破坏一定的业务逻辑的基础上提高数据的IO性能;或者将频繁查询的数据拿出来放到缓存数据库中,由此减少IO的读操作提高查询速度;再或者将一些特殊的数据拿出来进行文档数据库或者列式数据库等的存储。通过这些方式来减少IO的压力



🍖 初识NoSQL数据库

🥩 NoSQL数据库简介

 NoSQL(Not Only SQL)意思是“不仅仅是SQL”,这一概念被用来泛指非关系型数据库(相对于关系型数据库的严格标准而言的一种概念)。NoSQL并不依赖业务逻辑方式进行存储,不遵循SQL标准,不支持ACID,且远超于SQL的性能

 NoSQL数据库大致上可分为四种,而我们要学的Redis就是其中一种典型的键值对数据库

image.png

NoSQL数据库的适用场景

对数据高并发的读写

海量数据的读写

对数据高可扩展性的

NoSQL数据库不适用的场景

需要事务支持

基于sql的结构化查询存储,处理复杂的关系,需要即席查询(用户根据自己的需求灵活选择查询条件,系统能够根据用户的选择生成相应的统计报表)

用不着sql的和用了sql也不行的情况,请考虑用NoSql

🥩 初识Redis

 Redis是一个开源的key-value存储系统,它和Memcached数据库类似,同样支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。

 在此基础上,Redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中,区别的是Redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

 在初步认识过Redis之后,下一步就是要学习Redis的下载安装和使用了


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
22天前
|
缓存 NoSQL Java
Redis 缓存与数据库数据不一致问题
Redis 缓存与数据库数据不一致问题
48 3
|
4天前
|
JSON NoSQL Redis
Redis 作为向量数据库快速入门指南
Redis 作为向量数据库快速入门指南
10 1
|
21天前
|
存储 SQL NoSQL
NoSQL数据库与传统关系型数据库的比较
【7月更文挑战第29天】NoSQL数据库与传统关系型数据库各有其独特的优势和适用场景。关系型数据库在复杂查询、事务处理和一致性方面表现出色,但在扩展性和处理大规模数据集时可能受到限制。而NoSQL数据库则以高扩展性、高性能和高可用性为目标,适用于处理大规模数据集和高并发读写场景。在选择数据库时,开发者应根据具体的应用场景和需求进行权衡和选择。
|
22天前
|
存储 SQL NoSQL
现代数据库技术:从关系型到NoSQL的演进与比较
随着信息技术的飞速发展,数据库技术也在不断演进和创新。本文将探讨现代数据库技术的发展历程,重点比较了传统的关系型数据库和新兴的NoSQL数据库,分析它们在不同场景下的优缺点及应用推荐。
|
26天前
|
缓存 NoSQL 数据库
Redis问题之在高并发场景下,保证Redis缓存和数据库的一致性如何解决
Redis问题之在高并发场景下,保证Redis缓存和数据库的一致性如何解决
|
4天前
|
存储 缓存 NoSQL
基于SpringBoot+Redis解决缓存与数据库一致性、缓存穿透、缓存雪崩、缓存击穿问题
这篇文章讨论了在使用SpringBoot和Redis时如何解决缓存与数据库一致性问题、缓存穿透、缓存雪崩和缓存击穿问题,并提供了相应的解决策略和示例代码。
13 0
|
5天前
|
存储 关系型数据库 MySQL
MySQL——数据库备份上传到阿里云OSS存储
MySQL——数据库备份上传到阿里云OSS存储
18 0
|
8天前
|
SQL 存储 关系型数据库
"MySQL增列必锁表?揭秘InnoDB在线DDL,让你的数据库操作飞一般,性能无忧!"
【8月更文挑战第11天】在数据库领域,MySQL凭借其稳定高效的表现深受开发者喜爱。对于是否会在给数据表添加列时锁表的问题,MySQL的行为受版本、存储引擎等因素影响。从5.6版起,InnoDB支持在线DDL,可在改动表结构时保持表的可访问性,避免长时间锁表。而MyISAM等则需锁表完成操作。例如,在使用InnoDB的表上运行`ALTER TABLE users ADD COLUMN email VARCHAR(255);`时,通常不会完全锁表。虽然在线DDL提高了灵活性,但复杂操作或大表变更仍可能暂时影响性能。因此,进行结构变更前应评估其影响并择机执行。
29 6
|
5天前
|
缓存 NoSQL Redis
一天五道Java面试题----第九天(简述MySQL中索引类型对数据库的性能的影响--------->缓存雪崩、缓存穿透、缓存击穿)
这篇文章是关于Java面试中可能会遇到的五个问题,包括MySQL索引类型及其对数据库性能的影响、Redis的RDB和AOF持久化机制、Redis的过期键删除策略、Redis的单线程模型为何高效,以及缓存雪崩、缓存穿透和缓存击穿的概念及其解决方案。
|
7天前
|
Oracle 关系型数据库 MySQL
Mysql和Oracle数据库死锁查看以及解决
【8月更文挑战第11天】本文介绍了解决MySQL与Oracle数据库死锁的方法。MySQL可通过`SHOW ENGINE INNODB STATUS`查看死锁详情,并自动回滚一个事务解除死锁;也可手动KILL事务。Oracle则通过查询V$LOCK与V$SESSION视图定位死锁,并用`ALTER SYSTEM KILL SESSION`命令终止相关会话。预防措施包括遵循ACID原则、优化索引及拆分大型事务。