轮询--一起学习吧之架构

一、定义

轮询(Polling)是一种CPU决策如何提供周边设备服务的方式,又称“程控输出入”(Programmed I/O)。这种方式是由CPU定时发出询问,依序询问每一个周边设备是否需要其服务,有即给予服务,服务结束后再问下一个周边,接着不断周而复始。轮询法的优点是实用且较易实现,缺点在于效率偏低。

在分布式系统中,轮询也可以用于检查某个任务的状态。例如,一个任务可能被分配到多个节点上进行处理,客户端可以定期向这些节点发送轮询请求,以获取任务的最新状态。这种方式可以保证客户端能够及时了解任务的处理情况,从而做出相应的处理或反馈。

此外,在计算机网络中,轮询还可以用于动态限定轮询多址协议(DPBQ),该协议基于队长参数来动态调整轮询周期,以提高网络带宽利用率和系统吞吐量。

总之,轮询是一种重要的机制,可以用于解决分布式系统中的一些问题,如设备服务、任务状态检查和网络通信等。

二、缺点

轮询的缺点主要包括以下几个方面:

  1. 效率偏低:因为轮询是定期向所有节点发送请求,无论这些节点是否真正需要服务,都会导致大量的无效请求和带宽浪费。这不仅增加了服务器的负载,还可能导致网络拥堵。
  2. 实时性有限:轮询只能在固定的时间间隔内获取更新,这对于需要实时响应的应用来说可能不够高效。
  3. 服务器压力:由于轮询产生的请求数量可能非常大,服务器需要处理这些请求并返回响应,这增加了服务器的负载。如果服务器无法承受这种压力,可能会导致性能下降或宕机。
  4. 兼容性问题:不同浏览器对于长连接的支持程度不同,这可能导致轮询在某些浏览器上无法正常工作。
  5. 无法处理故障转移:当某个节点出现故障时,轮询策略无法自动将请求转移到其他可用的节点上,这可能导致部分请求失败或延迟。

综上所述,轮询虽然在一些场景中仍然被广泛使用,但也存在许多缺点需要注意和解决。在设计分布式系统或网络通信协议时,需要根据具体的需求和场景来选择合适的机制,以最大限度地提高效率和性能。

三、优缺点适用场景

轮询的优点和缺点适用于不同的场景,具体如下:

优点适用场景

  1. 实现简单:对于需要快速搭建和部署的系统,轮询是一个很好的选择,因为它不需要复杂的设置和配置。
  2. 兼容性好:由于轮询只使用常规的HTTP请求和响应,因此它与大多数现有的网络和服务器技术兼容。
  3. 易于后期弹性伸缩:当业务增长时,可以通过增加节点来扩展系统能力;当业务减少时,可以减少节点以节省资源。这种弹性伸缩的特性使得轮询适用于需要灵活调整系统规模的场景。

缺点适用场景

  1. 频繁的HTTP请求可能增加服务器和网络的负载:这在高并发或大规模分布式系统中尤为明显。当系统需要处理大量请求时,轮询可能导致服务器和网络资源被过度消耗。
  2. 实时性有限:对于需要实时响应的应用,如在线聊天、实时交易等,轮询可能无法满足要求。因为它只能在固定的时间间隔内获取更新,无法保证实时性。
  3. 无法动态调整权重:轮询策略无法根据服务器的实时负载情况动态调整权重,这可能导致某些性能较差的服务器承受过大的负载,而性能较好的服务器则处于轻载状态。
  4. 无法照顾不同配置的服务器:轮询算法不考虑服务器的配置差异,无法将高配置的服务器性能充分发挥出来。

综上所述,轮询的优点适用于简单、快速部署和兼容性好的场景;而轮询的缺点则在高并发、大规模分布式系统、需要实时响应以及需要动态调整权重的场景中更为明显。在实际应用中,需要根据具体的需求和场景来选择合适的机制以最大限度地提高效率和性能。

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

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

相关文章

html--3D爱心

文章目录 代码效果 代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>爱心</title><style type"text/css">*{margin: 0px;border: 0px;}body{overflow: hidden;background-…

Docker-部署若依项目

文章目录 后端一、搭建局域网二、redis安装测试 三、MySQL安装四、后端项目放入位置及使用Dockerfile自定义镜像后端项目放入位置 前端配置检查各个端口是否启动nginx部署 首先得先把内部的文件给删除清空 docker images–查看有哪些文件 docker rmi -f ID–删除ID 后端 一、…

腾讯QQ推出AI聊天搭子;零一万物01AI宣布开源Yi-9B模型

&#x1f989; AI新闻 &#x1f680; 腾讯QQ推出AI聊天搭子&#xff0c;进军AI对话领域 摘要&#xff1a;腾讯QQ合作筑梦岛和混元助手&#xff0c;推出了AI对话功能“AI聊天搭子”&#xff0c;提供多种虚拟角色与用户实时互动&#xff0c;目前已开启测试。此外&#xff0c;抖…

STM32/GD32——I2C通信协议

芯片选型 Ciga Device — GD32F470系列 通讯规则 I2C协议&#xff08;或称IIC&#xff09;是由飞利浦&#xff08;现在的恩智浦半导体&#xff09;公司开发的一种通用的总线协议。它使用两根线&#xff08;时钟线和数据线&#xff09;来传输数据&#xff0c;支持多个设备共享…

智能设备 app 设计 —— 蓝蓝 UI 设计公司

今天给大家推荐是智能设备app设计&#xff0c;随着智能设备的逐渐普及随之操作app也越来越多&#xff0c;希望能给大家带来灵感 #日常灵感 #创意设计#UI提升#ui设计#app #设计案例分享|#设计 #产品设计#产品设计#设计灵感 #B端产品经理 #ui #产品 #美工 #交互 #产品经理 #开发 …

乐优商城(九)数据同步

1. 项目问题分析 现在项目中有三个独立的微服务&#xff1a; 商品微服务&#xff1a;原始数据保存在 MySQL 中&#xff0c;从 MySQL 中增删改查商品数据。搜索微服务&#xff1a;原始数据保存在 ES 的索引库中&#xff0c;从 ES 中查询商品数据。商品详情微服务&#xff1a;做…

python75-Python的函数参数,关键字(keyword)参数

在定义Python函数时可定义形参(形式参数的意思)这些形参的值要等到调用时才能确定下来,由函数的调用者负责为形参传入参数值。简单来说,就是谁调用函数,谁负责传入参数值。 关键字(keyword)参数 Python函数的参数名不是无意义的,Python 允许在调用函数时通过名字来传入参…

mysql 查看数据库、表的命令

查看所有的数据库 1.show databases; 2.select schema_name from information_schema.schemata\G \G 。以纵向报表的形式显示结果&#xff0c;方便查看。 查看mysql数据库的运行状态 status 选择数据库 use 库名 例 use TestDb 查看数据库中的表 show tables 查看表结构 de…

怎么在图片上直接编辑文字?3个方法教你轻松编辑

怎么在图片上直接编辑文字&#xff1f;随着技术的飞速发展&#xff0c;图片编辑已经成为我们日常生活和工作中不可或缺的一部分。在图片上直接编辑文字&#xff0c;不仅能够添加说明和标注&#xff0c;提高信息的传达效率&#xff0c;还能够增强图片的美观和设计感&#xff0c;…

qt练习案例

记录一下qt练习案例&#xff0c;方便学习qt知识点 基本部件 案例1 需求&#xff0c;做一个标签&#xff0c;显示"你好"知识点&#xff0c;QLabel画面 4. 参考&#xff0c;Qt 之 QLabel 案例2 需求&#xff0c;做一个标签&#xff0c;显示图片 知识点&#xff0c;…

在Linux/Ubuntu/Debian中用fdisk分区mkfs格式化

fdisk 是一个命令行实用程序&#xff0c;用于在类 Unix 操作系统&#xff08;包括 Linux&#xff09;中对磁盘进行分区。 如果你想使用“fdisk”格式化 USB 驱动器&#xff0c;通常会先对驱动器进行分区&#xff0c;然后使用特定的文件系统格式化分区。 以下是有关如何在 Linu…

c++初阶------类和对象(六大默认构造函数的揭破)

作者前言 &#x1f382; ✨✨✨✨✨✨&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f382; ​&#x1f382; 作者介绍&#xff1a; &#x1f382;&#x1f382; &#x1f382; &#x1f389;&#x1f389;&#x1f389…

1.JavaWebJava基础加强[万字长文]-Junit、反射、注解核心知识点梳理

导语&#xff1a; 一、Junit单元测试 1.Junit测试概述 2.Junit使用步骤 3.Junit_Before&After 二、反射 1.反射概述 2.反射获取字节码Class对象的三种方式 3.Class对象功能概述 4.Class对象功能_获取Field 5.Class对象功能_获取Constructor 6.Class对象功能_获取…

20个实操保姆级副业项目

这边免费给到大家很多项目资料和工具&#xff0c;主要的就是为了消除信息壁垒&#xff0c;在互联网创业或兼职的路上不再被割&#xff0c;不再多花冤枉钱&#xff0c;相信人间有真爱&#xff0c;有不懂的问题可咨询博主&#xff01;为了帮助到更多的创业者&#xff0c;资料欢迎…

极狐GitLab 16.3 重磅发布,极致的 DevOps 体验等你来【一】

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 极狐GitLab 在去年 8 月份发布了 16.3 版本。此次发布带来了合…

ElasticSearch为什么快?

ElasticSearch是一个高性能&#xff0c;分布式搜索引擎&#xff0c;它之所以快&#xff0c;主要有以下几个原因&#xff1a; 1.分布式存储&#xff1a;ElasticSearch使用分布式存储技术&#xff0c;将数据存储在多个节点上从而减少单个节点的压力&#xff0c;提高整体性能。 …

Kakarot:当今以太坊的未来

1. 引言 前序博客&#xff1a; Kakarot&#xff1a;部署在Starknet上的ZK-EVM type 3 随着 Kakarot zkEVM 即将发布测试网&#xff0c;想重申下 Kakarot zkEVM 的愿景为&#xff1a; 为什么在rollup空间中还需要另一个 zkEVM&#xff1f; 开源代码见&#xff1a; https:/…

Anaconda prompt运行打开jupyter notebook 指令出错

一、打不开jupyter notebook网页 报错如下&#xff1a; Traceback (most recent call last): File “D:\anaconda3\lib\site-packages\notebook\traittypes.py”, line 235, in _resolve_classes klass self._resolve_string(klass) File “C:\Users\DELL\AppData\Roaming\Py…

oracle数据库通过sql实现blob类型字段转字符串

最近遇到一个问题&#xff0c;数据表tabA中有一个字段content是blob类型。现在需要通过sql把这个字段的内容展示出来。一般情况我们都是通过后端实现blob转string。但是通过sql查询出blob类型的内容还没遇到过&#xff0c;今天把解决这个问题的心理路程记录下。 首先&#xff0…

软考 系统分析师系列知识点之系统性能评估(3)

接前一篇文章&#xff1a;软考 系统分析师系列知识点之系统性能评估&#xff08;2&#xff09; 所属章节&#xff1a; 第6章. 系统配置与性能评价 第8节. 系统性能评估 6.8.2 经典评估方法 在计算机技术的发展过程中&#xff0c;性能评估的常用方法有&#xff1a;时钟频率法、…