对比分析法

2024-04-13 15:48
文章标签 分析法 对比

本文主要是介绍对比分析法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

序言

    花时间处理重要的事,而不是紧急的事。。。


    紧急的事处理了就过去了,然而并不一定有什么长远的价值,或许在一瞬间体验了各种不同的感觉;而重要的事则不一样,事处于长远的考虑。。。

风言风语

    本篇文章主要提供一种解决问题的思路:也就是对比分析法,熟悉测试的人都知道,在测试中经常会有基线,也就是对比的标准。。。基准测试,maybe。。。


    1、 离线任务无法完成

    在进行离线任务的时候,发现任务一直不能结束。


    查看相关的监控,发现业务没有流量洪峰,数据量根据相关人员的反馈也是正常的数据量,查看计算存储资源,发现还剩余很多。


    在正常情况下,一般运行的时间也就几个小时,今天这次任务居然跑了N个小时还未结束。


    离线任务是从数据库中拉取数据,然后进行统计分析,打开出问题的任务,发现数据量在几亿条,查看相关的日志,也是正常的,未发现明显的问题,主要耗费时间的地方在join的操作。


    查看以前的历史任务,发现数据量的条数只有千万级别,数据量增长了十倍之多,再次询问业务方,上层调用出现问题,从而导致数据重复,最后就是任务无法继续。


    总结:对比成功的案例和失败的案例,找出不一样的地方,从而能更快的排查问题,当然,业务监控还是需要进行改进,能明显的看到历史的相关曲线图,从而能大大减少排查的时间。。。。说的都是不可靠的,查出来的日志等相关信息才是可靠的。


    2、 同城异地业务延迟

    在进行同城异地搭建服务集群的时候,业务方总是要求进行双活,使用分布式存储的时候,不可避免的会造成相关的延迟,但是。。。正常的延迟时间应该不过是几毫秒而已,毕竟相互之间是高速互联的网络。。。


    业务是否能接受这种延迟?这种延迟带来的后果是不是会影响业务的正常运转,都是需要进行测试的。


    跨机房访问,会跨几次,如何来避免跨机房的操作,这个时候就需要进行相关的测试了,将不跨机房的操作,做为基准,统计相关的业务耗时情况;然后可以进行测试,跨机房一次需要的时间;跨机房两次需要的时间。。。


    同城异地,如果不是关键的核心业务,那就应该接受这种延迟,如果不能满足,就只能进行业务改造了。。。


    总结:将就近访问的时间作为基准,从而可以统计出最大的延时情况,最后结合业务的情况,从而进行相关的优化操作。


    3、 谨慎使用对比

    在使用对比分析的时候,不是所有的情况都满足这种条件,在进行对比分析的时候,因为是基于测试来做,从而在测试的时候,尽量保证只有一个变量在变化,从而才能得出尽可能正确的结果。


    在一般的测试的时候,可能分为平台的不同导致测试的结果不一致,使用的linux操作系统,或者windows操作系统;也可能因为数据量的不同而造成结果不一致,例如有的数据量很大,有的数据量很小。。。在不同的时候,选择不同的方法,要结合相关的实际业务情况来进行思考。


    拿着弱点和强点进行比较,可能会有促进的作用。。。但是你也需要考虑的是,这种对比对你来说,你一种拉伸的动力还是一种摧毁的动力。。。如果是拉伸的动力,那么你可能进步很快,但是如果是摧毁的东西,可能就是从入门到放弃。。。


    人嘛,总是喜欢对比。。。。然而,又有什么意思。。。

    

640?wx_fmt=jpeg

    有的时候,觉得思考过程更加重要,而所谓的一些操作步骤,随地一找,遍地都是。。。弄懂为什么更加重要


    例如在python之中,list和tuple有什么区别?都是线性存储,但是区别在于一个是可变的,一个不可变的,而这种区别体现在哪儿?为什么要选择tuple而不选择list。。。


    区别体现在操作上,list有各种增删改查的方法,而tuple则没有,对于使用方来说,区别又在哪儿。。。当你不希望别人修改你的数据的时候,可以使用tuple,当需要经常变化内容的时候,你可以选择list。。。两者之间的转化也很简单


    弄懂为什么?到底是要靠自己思考,还是别人的指引。。。靠别人的指引,那肯定是飞速的进步,不过也可能让自己的思维无法转动。。。靠自己思考,过程也是很艰难,但是却能训练你的逻辑思维。。。没有绝对的对,也没有绝对的错。。。

    

    瞎说什么大实话。。。心好慌。。。所有文章只是带动你的思考,打开你的思维。。。想象的空间是无限的。。。

这篇关于对比分析法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/900557

相关文章

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

exfat和ntfs哪个好? U盘格式化选择NTFS与exFAT的详细区别对比

《exfat和ntfs哪个好?U盘格式化选择NTFS与exFAT的详细区别对比》exFAT和NTFS是两种常见的文件系统,它们各自具有独特的优势和适用场景,以下是关于exFAT和NTFS的详细对比... 无论你是刚入手了内置 SSD 还是便携式移动硬盘或 U 盘,都需要先将它格式化成电脑或设备能够识别的「文

Python实现Microsoft Office自动化的几种方式及对比详解

《Python实现MicrosoftOffice自动化的几种方式及对比详解》办公自动化是指利用现代化设备和技术,代替办公人员的部分手动或重复性业务活动,优质而高效地处理办公事务,实现对信息的高效利用... 目录一、基于COM接口的自动化(pywin32)二、独立文件操作库1. Word处理(python-d

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数