对比分析法

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

相关文章

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

关于MyISAM和InnoDB对比分析

《关于MyISAM和InnoDB对比分析》:本文主要介绍关于MyISAM和InnoDB对比分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录开篇:从交通规则看存储引擎选择理解存储引擎的基本概念技术原理对比1. 事务支持:ACID的守护者2. 锁机制:并发控制的艺

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

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

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