在数据开发过程中,我们通常需要将两个作业进行对比从而定位作业运行性能或者结果有差异的问题,但是对比作业时需要同时打开两个studio 的tab页,或者两个Logview页,不停切换进行对比,使用起来非常的不方便。MaxCompute Studio从3.1.0版本开始支持作业对比,可以在一个页面同时比较两个作业,并且能自动标注出作业的差异点。

本文我以查找同个作业执行两次用时差别很大的原因为例,通过MaxCompute Studio的对比功能对两次执行的job进行对比,找出执行时间差别大的原因。

作业对比入口

MaxCompute Studio的Maxcompute 工具菜单中进入作业对比。

输入两个需要对比的job的logview url 地址,点击“OK”按钮就可以开始对比:

对比基本信息

作业一运行了01:11:08 ,作业二运行了00:45:59,想知道是什么导致了相差近半个小时。先看基本信息对比:

通过基本信息可以看到studio 标注出作业一的耗时明显上升,其他项目,如IO Bytes 等相差不多, 输入输出表完全相同。基本可以断定是同一作业,为了确保是同一个作业还可以对比执行计划和脚本。

对比执行图

打开执行图 Tab ,可以一目了然看到两个作业的执行计划,执行图无法进行标注,可以通过查看text diff查看。

点击text diff 后可以对比fuxi task 的执行时间, 输入输出等详细信息。可以比较绝对值,可以按比例比较,不一致的地方都会进行有效标注。

这里可以发现执行计划是完全一致的。

对比脚本

点击脚本对比Tab 后,可以对比settings 和script ,settings 非常关键,不同的参数可能会导致完全不同的结果。这里需要使用text diff 功能比较sql 脚本。

可以看到脚本对比功能很方便使用,即便是很复杂的sql 脚本都可以快速发现区别,这里发现只有分区日期不同,其他完全一致。

进一步分析执行计划

通过前面几个对比,确定两个作业完全一致, 再回到执行图中, 通过回放可以发现运行瓶颈在J4, 查看text diff 发现作业一的J4 用时52分, 作业二28分,由此判断作业一主要是J4用时长导致整体运行变慢。

接下来重点分析J4 ,打开J4的 Operation Graph, Studio 在Operation 层新添加了Metric 信息, 可以看到每个operation 的执行时间,inner_time_ms, 这个时间指Operation 执行完所有行的平均时间(每个fuxi instance 都会用这个operation执行, 当这个operation 处理完所有分配给他的数据后就得出一个时间,这里的inner_time_ms 指的是这些fuxi instance 对应的Operation 执行的平均时间) ,通过这个时间可以发现某个Operation 执行时间是否过长,例如自定义udf 是否有性能问题。

对比J4 的实际运行时间相差不多,并且执行的都比较快,由此可以考虑J4 是否存在等待资源情况, 导致fuxi instance 并没有及时开始运行。

对比分析Tab

打开作业分析tab的时序图子页面,可以明显发现作业一的J4_2_3 task 运行时间大于作业二的, 与前面看到的执行计划图一致。

鼠标放到J4上点击展开作业后,可以看出fuxi instance 开始执行时间非常晚,这进一步验证了资源不足导致作业等待情况。

小结

通过Studio 的作业对比功能,调查了资源等待导致的作业运行变慢情况, 并且排查的效率更高。作业对比还有很多其他功能,各位可以自行尝试。


本文作者:海清

原文链接

本文为云栖社区原创内容,未经允许不得转载。

MaxCompute Studio使用心得系列7——作业对比的更多相关文章

  1. 一探究竟:善用 MaxCompute Studio 分析 SQL 作业

    头疼的问题 MaxCompute 用户一个常见的问题是:同一个周期任务,为什么最近几天比之前慢了很多?或者为什么之前都能按时产出的作业最近经常破线? 通常来说,引起作业执行变慢的原因有:quota 组 ...

  2. MaxCompute Studio 使用入门

    MaxCompute Studio 是MaxCompute 平台提供的安装在开发者客户端的大数据集成开发环境工具,是一套基于流行的集成开发平台 IntelliJ IDEA 的开发插件,可以帮助您方便地 ...

  3. Android Studio使用技巧系列教程(二)

    尊重劳动成果,转载请注明出处:http://blog.csdn.net/growth58/article/details/46764575 关注新浪微博:@于卫国 邮箱:yuweiguocn@gmai ...

  4. 【Android Studio安装部署系列】目录

    概述 从刚开始使用Android Studio到现在,下面所有目录下的操作,当时习惯性的把每一个整理成一个文档(其实就是简单文字描述+截图):有些地方当时是一知半解,现在会稍微明白一些.正好赶上现在有 ...

  5. 【Android Studio安装部署系列】二十一、Android studio将项目上传到github中

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 两个相关概念:git和github Git是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理.Git ...

  6. 【Android Studio安装部署系列】二十五、Android studio使用NDK生成so文件和arr文件

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 Android Studio使用ndk的简单步骤. NDK环境搭建 下载NDK 下载链接:https://developer.and ...

  7. 【Android Studio安装部署系列】二十八、Android Studio查看其它APP的布局结构

    概述 日常使用别家的APP过程中,会遇到一些比较好看的布局,这时候我们就想学习一下别人的布局结构,以便参考. (1)手机连接电脑.设置手机为USB调试模式 参考<[Android Studio安 ...

  8. 【Android Studio安装部署系列】三十三、windows系统中通过SourceTree使用git

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 前期准备 选择代码托管服务器:gitlab.github.开源中国等. 注册账号 创建项目 安装git 参考<[Android ...

  9. 【Android Studio安装部署系列】三十六、从Android Studio3.1.4升级到Android studio3.2【以及创建android p模拟器(未成功)】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 因为想要使用Android P模拟器,所以需要将Android Studio升级到3.2版本以上. 按照官网的说法:参考<ht ...

随机推荐

  1. vue-cli3.x正确打包项目,解决静态资源与路由加载无效的问题,history模式下配合使用nginx运行打包后的项目

    使用vue-cli3.x正确打包项目,配合nginx运行打包后的内容 vue.config.js module.exports = { publicPath: './',//打包后的位置(如果不设置这 ...

  2. Yii 网站上线不需手动配置

    参考: http://www.cnblogs.com/x3d/p/php_auto_prepend_file.html

  3. LintCode刷题笔记-- Maximum Product Subarray

    标签: 动态规划 描述: Find the contiguous subarray within an array (containing at least one number) which has ...

  4. LintCode_100 删除排序数组中的重复数字 ||

    题目 跟进“删除重复数字”: 如果可以允许出现两次重复将如何处理? 样例 给出数组A =[1,1,1,2,2,3],你的函数应该返回长度5,此时A=[1,1,2,2,3]. C++代码 int rem ...

  5. 小希的迷宫 HDU - 1272 (并查集)

    思路: 当图中的集合(连通子图)个数为1并且边数等于顶点数-1(即改图恰好为一棵生成树)时,输出Yes. 此题的坑:(1) 如果只输入0 0算作一组数据的话答案应该输出Yes (2) 输入数据可能并不 ...

  6. Scanner读取记事本文件内容为空的解决办法

    原因:记事本txt文件中含有中文,windows记事本编码方式为gbk,但是eclipse中为utf-8,所以需要在Scanner中指定编码方式.

  7. myeclipse10.7的破解 不需要去CSDN付费下载-免csdn费下载

    吐槽一下,大票CSDN博主,在博文里基本不放干货,都弄成附件,放在csdn付费下载,一个破解办法,竟然50元,好在我是vip用户,不在乎价格,特此 这篇文章搬运一下资源给大家免费下载 顺便纠正一下其文 ...

  8. Python学习(二) 基础语法之初看python

    Python 标识符 略 Python保留字符 一大堆,说了未必记得住,编码过程中慢慢去记住. 行和缩进 这个要说一下,学习Python与其他语言最大的区别就是,Python的代码块不使用大括号({} ...

  9. rpmnew和rpmsave怎么来的

    RPM spec文件有个名为 %config 的宏,它可以标识配置文件,这样在升级时用户对配置文件做过的修改就不会丢失.没有它,用户千辛万苦修改过的配置文件会在升级过程中被覆盖. %config也可以 ...

  10. I Love Palindrome String

    I Love Palindrome String 时间限制: 2 Sec  内存限制: 128 MB 题目描述 You are given a string S=s1s2..s|S| containi ...