当前位置: 首页 > article >正文

Redis--高并发分布式结构

目录

一、引言

二、redis

1.什么是redis?

三、基础概念

1.什么是分布式?

2.应用服务和数据库服务分离

3.负载均衡

4.分库分表

5.微服务架构

四、总结


一、引言

  本篇文章就简单介绍一下什么是redis,以及一些关于高并发和分布式结构的基本概念。

二、redis

1.什么是redis?

  Redis是⼀种基于键值对(key-value)的 NoSQL 数据库,与很多键值对数据库不同的是,Redis中的值可以是由 string(字符串)、hash(哈希)、list(列表)、set(集合)、zset(有序集合)Bitmaps(位图)、HyperLogLog、GEO(地理信息定位)等多种数据结构和算法组成,因此 Redis可以满⾜很多的应用场景,⽽且因为 Redis 会将所有数据都存放再内存中,所以它的读写性能非常惊人。不仅如此,Redis 还可以将内存的数据利用快照和日志的形式保存到硬盘上,这样在发⽣类似断电或者机器故障的时候,内存中的数据不会“丢失”。除了上述功能以外,Redis 还提供了键过期、发布订阅、事务、流⽔线、Lua 脚本等附加功能。总之,如果在合适的场景使⽤号 Redis,它就会像⼀把瑞士军刀⼀样所向披靡。

三、基础概念

1.什么是分布式?

  我们平常所解除到的大部分都是单机架构的服务器,但因为数据量的庞大,一台机器已经不能够支撑那么多业务数据了,就必须引入更多的机器,把同一业务的东西分布在多台机器上就叫做分布式。

2.应用服务和数据库服务分离

  

将应用服务服务器和数据服务服务器进行分离。

3.负载均衡

当业务数据量实在是太多时,我们可以先引入一个负载均衡(本质上也是服务器),然后再将数据分配给应用服务器。

给应用服务器引入了多个服务器,那对于数据库服务器我们同样也会引入更多的服务器。

  主服务器用于写,从服务器用于读,因为读的操作是远远大于写操作的,所以这里的服务器强调一主多从。

  数据库有个天然的问题,数据库的响应是十分缓慢的,所以我们就将数据分为了冷热数据,热数据放入缓存中,也就是我们的redis中。

4.分库分表

  当数据实在是太多的时候,我们就要将数据库进行划分,例如一个数据库存用户表,一个数据库存商品表,一个存交易表。

5.微服务架构

  简单而言就是将不同的业务逻辑分为不同的部分。

引入微服务的代价:

1.系统的性能下降了,拆出来更多的服务,多个功能之间相互依赖网络通信。

2.系统复杂程度提高,可用性收到影响,服务器更多了,出现问题的可能性也更大了,这就需要监控报警系统以及运维人员来维护。

优势:

1.解决了人的问题

2.使用微服务,可以更方便于功能复用

3.可以给不同的服务进行不同的部署

四、总结

 此篇文章并未对redis进行过多讲解,只是简单介绍了一下概念,但其他概念是学习redis的基础,也是十分重要的,下篇文章就将专门讲解redis相关特性了,感谢观看!


http://www.kler.cn/a/443114.html

相关文章:

  • 关于地平线开发板使用nhwc格式的前向传播输出格式的理解
  • 信息系统项目管理-采购管理-采购清单示例
  • Java Spring Boot实现基于URL + IP访问频率限制
  • 本地手集博客id“升级”在线抓取——简陋版——(2024年终总结1.1)
  • Linux标准IOday3
  • LeetCode -Hot100 - 53. 最大子数组和
  • Blazor(.razor)+VUE+elementUI适合一起用吗
  • ArcGIS地理空间平台manager存在任意文件读取漏洞
  • 开源流程引擎技术
  • SSM餐厅点餐系统--02635(免费领源码)可做计算机毕业设计JAVA、PHP、爬虫、APP、小程序、C#、C++、python、数据可视化、大数据、全套文案
  • 【OceanBase 诊断调优】—— OceanBase 数据库网络速率配置方案
  • 一个初始化bitmap的小算法
  • flask_sqlalchemy event监听查询事件
  • 【排序算法】——选择排序
  • 如何设置代理服务器爬取商品信息?
  • C语言专题之文件操作(巨详细)
  • uniapp springboot 上传demo
  • 【深入STL:C++容器与算法】深度解析string类的使用
  • MyBatis 常见面试问题深度剖析
  • 讯飞智文丨一键生成WordPPT
  • 深度学习的下一站:解锁人工智能的新边界
  • 渗透测试之信息收集
  • Windows设置所有软件默认以管理员身份运行
  • ElasticSearch中的深度分页问题
  • 用vscode,进行vue开发
  • 对象克隆与单例模式