Shell自动化场景的应用

场景一:Git代码自动更新

背景描述:工作中,我们电脑或多或少很多个工程 git pull 可能是你开启电脑开始一天工作的第一个命令行,有时候你需要切换好几个工程,每个工程又得 git pull 更新一下。

我们都知道shell每次启动时会重新载入.bashrc(因为我的Mac是用zsh,所以是.zshrc,为了名字通用,我们都先统一叫bashrc吧。。。),bashrc文件一般放在/home/linux用户名下,我们可以在里头添加函数实现代码的自动更新,代码打个样:

function auto_pull_project {
    project_list=`ls /Users/your_root/AndroidStudioProjects`
    for project_item in $project_list
    do
        echo "[START] Update project $project_item"
        cd /Users/your_root/AndroidStudioProjects/$project_item
        git pull -p
        cd ..
        echo "[END] Update project $project_item"
    done    
}

auto_pull_project

场景二:Apk性能监控

背景描述:冷启动时间、内存、cpu、帧率,是不是每次通过Android Studio或者其它第三方工具进行数据采样呢?但是这样有无发现一个问题?电脑变卡了,烫了,散热器异常繁忙了,因为工具太重了。想轻量级捞取这些数据,可以通过如下面命令,收集相关维度的数据,然后对数据进行批处理,再根据你要统计的性能指标维度,输出想要的呈现方式,比如:以图表的方式,excel的方式,简单文本提示的方式等等。

下面就用冷启动时间统计维度打个样吧,指标:冷启动平均时长、最大启动时长、最快启动时长

#!bin/bash

LOG_START_TIME=/Users/cengfanwei/Desktop/start_time.txt
PACKAGE_NAME=$1
ACTIVITY_NAME=$2
TEST_TIME=$3

counter=0
while [[ $counter -lt $TEST_TIME ]]
do
    adb shell am start -W -n $PACKAGE_NAME/.$ACTIVITY_NAME >> $LOG_START_TIME
    adb shell am force-stop $PACKAGE_NAME
    sleep 1
    let counter++
done

ALL_TOTAL_TIME=0
MAX_START_TIME=0
MIN_START_TIME=0

time_list=`cat $LOG_START_TIME | grep TotalTime`

for time_item in $time_list
do
    t0=`echo "$time_item" | tr -cd "[0-9]"`
    let ALL_TOTAL_TIME+=t0

    if [[ $MAX_START_TIME -lt $t0 ]]; then
        MAX_START_TIME=$t0
    fi

    if [[ $MIN_START_TIME -eq 0 || $MIN_START_TIME -gt $t0 ]]; then
        MIN_START_TIME=$t0
    fi
done

avg_time=`echo "$ALL_TOTAL_TIME / $TEST_TIME" | bc`

echo "avg_time: $avg_time"
echo "max_time: $MAX_START_TIME"
echo "min_time: $MIN_START_TIME"

然后我们终端跑下(第一个参数是包名,第二个是启动的MainActivity,第三个是统计次数):

sh /Users/cengfanwei/Desktop/start_time.sh [package_name] [launch_activity] 5
avg_time: 459
max_time: 565
min_time: 434

好啦,以上就是关于冷启动指标数据收集的方式,可能你会有疑问,那我们平时的app冷启动时间这么统计并不准呢?

这里我想说的是,重要的是这个思想,比如你的app的冷启动流程是先经过SplashActivity再到HomeActivity,那你可以选择HomeActivity相对比较适合产品的埋点位置,然后添加日志,假设在HomeActivity的onCreate的第一行代码埋点日志Log.d("ZFW", "onCreate.")那就可以在脚本里头添加:

adb shell logcat -s ZFW

04-26 12:17:43.478  1266  1442 D ZFW: onCreate.

最后,再通过拿到你要的logcat日志对时间进行文本批处理统计即。 _

在上面的冷启动指标时长统计代码打样后,我们想统计其它维度指标也就一个思想道理了。

# 打印应用Activity堆栈信息
adb shell dumpsys activity [package] > dumpsys_activity.txt
# 打印应用内存使用信息
adb shell dumpsys meminfo [package] > dumpsys_meminfo.txt
# 打印应用CPU使用情况
adb shell dumpsys cpuinfo [package] > dumpsys_cpuinfo.txt

关于场景二,你可能不得不去补一下adb常用命令,以及一些系统命令工具,比如dumpsys相关的命令就很多啦~

场景三:Apk自动编译、安装到设备

背景描述:电脑的项目本地临时编译一个release带签名的apk再安装到设备上调试,也是我们比较常见的繁琐场景。

步骤一般是:

  1. 配置gradle的签名信息(当然也可以把apk构建出来之后再通过 jarsigner
  2. AndroidStudio build一下
  3. 把apk安装到设备上

通过写个脚本,只要输入ip,以及项目路径,我们即可全自动化完成这个流程步骤,你倒杯茶回来就可以直接开始调试了,代码打个样(伪代码,需要自行补充细节):


function auto_build_install{
    # 1.通过adb的方式连接设备IP
    adb connect $1
    # 2.通过cd到项目目录位置
    cd $2
    # 3.执行gradle命令自动构建apk
    ~/Library/Android/gradle/gradle-4.10.1/bin/gradle build assembleRelease
    # 4.通过jarsigner命令对output目录下的release apk进行签名
    jarsigner output/release_unsign.apk...
    # 5.安装到设备上面
    adb shell pm install -r -d apk_path
}

auto_build_install $ip $project_path

BY THE WAY......

shell脚本的应用场景还有很多很多,也请记住,它不是一个人在战斗,它往往是多个命令工具的组合,脚本可能包含python、jdk的工具命令,gradle命令等等。

当然,最最最重要的一点就是:牢记自动化的思想,优化日常工作的一些繁琐、重复流程,将精力放到刀刃上~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容

  • 前言 App运行在设备上的性能表现也是质量保障的一个重要环节。因此,当我们确保了基本功能的准确之后,还需要有一定的...
    海波笔记阅读 5,689评论 1 52
  • 什么是运维 术语名词 IDC--(Internet Data Center)互联网数据中心,主要服务包括整机租用、...
    lyh165阅读 2,656评论 0 19
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,656评论 2 59
  • 表情是什么,我认为表情就是表现出来的情绪。表情可以传达很多信息。高兴了当然就笑了,难过就哭了。两者是相互影响密不可...
    Persistenc_6aea阅读 123,317评论 2 7
  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 6,020评论 0 4