物联网设备接入层
2023-03-15 23:21:22 时间
14.1 负载均衡
面对海量的设备接入,单台服务器作为接入层的话,存在以下的问题:
- 很容易达到性能瓶颈,无法因对海量接入和数据
- 存在单点故障
要达到高并发和高可用,必须要采用多台服务器。服务器数量变多之后,具体要怎么协作来处理请求。这个时候就需要用到负载均衡技术。我们需要在所有的服务器之前添加一个组件——负载均衡器。所有的接入请求都会发送到负载均衡器,由负载均衡器将请求发送给后端的接入服务器。
负载均衡器可以通过各种预先设置好的策略,将请求分配给后面的各个接入服务器。通常使用的策略包括:
- 轮询策略:将请求轮流发送给各个后端服务器。
- 加权轮询策略:为各个后端服务器配置权重,根据权重将请求发送给后端的服务器。
- 最小连接数策略:将请求发送给当前连接数最少的后端服务器
- 加权最小连接数策略:在最小连接数策略中引入权重系数。
- 源地址hash策略:根据请求源地址的ip地址的hash值,将请求分发给后端的服务器。
14.2 消息队列
采用负载均衡 +
多服务器的方式,能够提供接入层的高可用和高并发。这个时候压力会传递到更后面的数据库中,造成的结果就是请求响应会变慢甚至超时。因此,我们还需要采用一些方法来让设备接入层具有高性能。为了达到这个目的,我们会引入两个组件:消息队列和缓存。
消息队列
消息队列的一个常用的场景就是削峰填谷,这个功能也是我们在这里使用消息队列的原因。设备接入层在接收到数据之后,将数据发送到消息队列,就完成了自己的工作,可以给客户端发送返回消息。由于消息队列的高性能,这个过程会很快完成。后端的流处理程序和写入数据库的操作可以根据自己的节奏来从消息队列中读取数据进行消费。
常用的消息队列由:
- kafka
- RabbitMQ
- RocketMQ
缓存系统
消息队列解决了写入数据库的性能问题,还需要解决读取数据库的性能问题。解决这个问题的方式就是使用缓存系统。
常用的缓存系统包括Redis和Memcached等。同时,还有些二级缓存的框架,例如JetCache和J2Cache等。
相关文章
- Hi3861实现HTTP的Response数据解析
- 如何将 CentOS Linux 6、7、8 服务器迁移到 Oracle Linux
- HarmonyOS —十分钟教会数据库快速上手
- Gcc编译时,链接器安排的【虚拟地址】是如何计算出来的?
- GIT命令操作全攻略,请收下我的膝盖!
- 跟我学Linux:apt命令快速参考指南
- 几种常见的JSON解析器比较
- 不少电脑被迫使用Windows 10:因配置低无缘Windows 11 想升升不了
- OpenHarmony性能分析工具Bytrace
- 苹果 macOS 12.2 RC 发布,修复 Safari 浏览器泄露隐私漏洞
- Openharmony软总线之连接模块分析
- 微软终补短板!Windows 11效率更高了
- 微软终补短板:Windows 11效率更高 提高文件管理器性能
- Windows 11新预览版进一步提高文件管理器的性能
- 微软 Azure Database for MySQL Flexible Server 在中国大陆地区正式上线:完全托管的数据库服务
- Docker 系列教程:轻松在 Docker 容器中运行 MySQL 图文指南
- PageAbility跨设备迁移开发实战—问答互动
- 更换电脑不用怕,可以轻松将Windows 10密钥转移到新计算机上
- OpenHarmony 源码解析之分布式数据库
- 如何快速定位数据库消耗CPU语句?