当前位置:   article > 正文

Android的dumpsys命令_dumpsys batterystats

dumpsys batterystats

转自 https://www.jianshu.com/p/6bd4813b3c60

我们都知道Android是基于Linux的操作系统,它使用的是默认的Shell是Ash,之前的一篇文章有提到过《Shell脚本的简单介绍》,但是这个东西很明显是不能满足Android需求的,所以Google开发了很多针对Android的命令行工具。

从git上把Android的源码拉下,就会发现有一个cmds的文件夹,里边放着的全是Google为Android开发的shell命令。其中dumpsys在*${path}/frameworks/native/cmds/dumpsys*目录,如果感兴趣可以自行去研究研究。

执行adb shell dumpsys,Android就会把系统里边的各种服务的状态给你dump出来。这里要提一下,不同的Android版本提供的服务会有所不同,不同的ROM厂商也会定制自己的服务跑在系统里边。

我的手机小米4C,MIUI6.3.31的系统(Android5.1.1),Dump出来的 结果大概是这样子。

Currently running services:
  DisplayFeatureControl
  DockObserver
  MiuiBackup
  MiuiInit
  SurfaceFlinger
  accessibility
  account
  activity
  alarm
  android.security.keystore
  appops
  appwidget
  assetatlas
  audio
  backup
  battery
  batteryproperties
  batterystats
  bluetooth_manager
  clipboard
  cneservice
  com.qualcomm.qti.auth.fidocryptodaemon
  com.xiaomi.mtservice
  com.xiaomi.vsimservice
  commontime_management
  connectivity
  consumer_ir
  content
  country_detector
  cpuinfo
  dbinfo
  device_policy
  devicestoragemonitor
  diskstats
  display
  display.qservice
  dpmservice
  dreams
  drm.drmManager
  dropbox
  entropy
  ethernet
  fingerprint
  gfxinfo
  hardware
  imms
  ims
  input
  input_method
  iphonesubinfo
  isms
  isub
  jobscheduler
  launcherapps
  location
  locationpolicy
  lock_settings
  media.audio_flinger
  media.audio_policy
  media.camera
  media.player
  media.sound_trigger_hw
  media_projection
  media_router
  media_session
  meminfo
  miui.fdpp
  miui.security.keystore
  miui.shell
  miui.whetstone
  miui.whetstone.klo
  miui.whetstone.mcd
  miui.whetstone.net
  miui.whetstone.power
  mount
  netpolicy
  netstats
  network_management
  network_score
  notification
  package
  permission
  phone
  power
  print
  procstats
  qti.ims.connectionmanagerservice
  restrictions
  rttmanager
  samplingprofiler
  scheduling_policy
  search
  security
  sensorservice
  serial
  servicediscovery
  simphonebook
  sip
  statusbar
  telecom
  telephony.registry
  textservices
  trust
  uimode
  updatelock
  usagestats
  usb
  user
  vendor.qcom.PeripheralManager
  vibrator
  voiceinteraction
  wallpaper
  webviewupdate
  wfdservice
  whetstone.activity
  wifi
  wifip2p
  wifiscanner
  window
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120

然后后面还有很长,紧接着会把每个服务的dump的详细状况列举出来。这里我们能看到有几个Miui、com.xiaomi 开头的,这就是小米公司提供的服务。其他大部分是Android的标准的服务。

为了方便查看,我们可以传一个参数,来过滤掉多余的信息,比如dumpsys meminfo查看各个进程所占内存的情况。

下面我们就来介绍几个常用的services,默认是在Android的shell环境下。

  • account:账号管理
    就是App向AccountManager注册的账号,执行dumpsys account,会列举出绑定的账号,和各个App注册的ServiceInfo。
  • devicestoragemonitor存储状态
    执行dumpsys devicestoragemonitor,主要是会显示磁盘的使用状况
    结果:
Current DeviceStorageMonitor state:
  mFreeMem=8.55 GB mTotalMemory=11.31 GB
  mFreeMemAfterLastCacheClear=8.55 GB
  mLastReportedFreeMem=8.55 GB mLastReportedFreeMemTime=-21m31s397ms
  mLowMemFlag=false mMemFullFlag=false
 mIsBootImageOnDisk=true  mClearSucceeded=false mClearingCache=false
  mMemLowThreshold=500 MB mMemFullThreshold=1.00 MB
  mMemCacheStartTrimThreshold=375 MB mMemCacheTrimToThreshold=750 MB
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • activity:跟Activity相关的组件的状态
    这个命令支持子命令,通过-h可以看到子参数的列表。
    执行dumpsys activity -h,查看到的参数列表
Activity manager dump options:
  [-a] [-c] [-p package] [-h] [cmd] ...
  cmd may be one of:
    a[ctivities]: activity stack state
    r[recents]: recent activities state
    b[roadcasts] [PACKAGE_NAME] [history [-s]]: broadcast state
    i[ntents] [PACKAGE_NAME]: pending intent state
    p[rocesses] [PACKAGE_NAME]: process state
    o[om]: out of memory management
    prov[iders] [COMP_SPEC ...]: content provider state
    provider [COMP_SPEC]: provider client-side state
    s[ervices] [COMP_SPEC ...]: service state
    as[sociations]: tracked app associations
    service [COMP_SPEC]: service client-side state
    package [PACKAGE_NAME]: all state related to given package
    all: dump all activities
    top: dump the top activity
    write: write all pending state to storage
    track-associations: enable association tracking
    untrack-associations: disable and clear association tracking
  cmd may also be a COMP_SPEC to dump activities.
  COMP_SPEC may be a component name (com.foo/.myApp),
    a partial substring in a component name, a
    hex object identifier.
  -a: include all available server state.
  -c: include client state.
  -p: limit output to given package.
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

这里非常值得一提的就是 OOM参数,这里是指被踢出内存的优先级,也就是我们常说的进程优先级,值越小,就优先级越高,越不容易被杀,可以出现负数,系统App一般才会为负数,一般App最高为0。
当然你还可以直接查看进程的优先级oom_adj的值
//查看进程的优先级

cat /proc/${pid}/oom_adj
  • 1
  • battery:电池状态
    执行dumpsys battery
    结果:
Current Battery Service state:
  AC powered: false
  USB powered: true
  Wireless powered: false
  status: 5
  health: 2
  present: true
  level: 100
  scale: 100
  voltage: 4376
  temperature: 272
  technology: Li-poly
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • batterystats:各应用耗电量信息
    支持子命令的,执行dumpsys batterystats -h查看参数列表
Battery stats (batterystats) dump options:
  [--checkin] [--history] [--history-start] [--unplugged] [--charged] [-c]
  [--reset] [--write] [-h] [<package.name>]
  --checkin: format output for a checkin report.
  --history: show only history data.
  --history-start <num>: show only history data starting at given time offset.
  --unplugged: only output data since last unplugged.
  --charged: only output data since last charged.
  --reset: reset the stats, clearing all current data.
  --write: force write current collected stats to disk.
  <package.name>: optional name of package to filter output by.
  -h: print this help text.
Battery stats (batterystats) commands:
  enable|disable <option>
    Enable or disable a running option.  Option state is not saved across boots.
   
   - Options are:
      full-history: include additional detailed events in battery history:
          wake_lock_in and proc events
      no-auto-reset: don't automatically reset stats when unplugged
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • alarm:Alarm的唤醒队列信息
    查看放到定时队列中的事件
    有些时候adb dumpsys alarm命令输出再cmd窗口显示不全,可以通过 以下命令输出到电脑对应文件中查看
 adb shell dumpsys alarm > f:/alarm.txt
  • 1
  • cpuinfo:各进程使用CPU信息
    查看一段时间段内各个进程使用CPU的信息,包括user、kernel区分
  • dbinfo:各进程使用SQLite数据的信息
    查看各个进程使用数据库的状况,sql的执行时间等
  • diskstats:磁盘相关信息
    执行dumpsys diskstats
    结果:
Latency: 1ms [512B Data Write]
Data-Free: 8963580K / 11855028K total = 75% free
Cache-Free: 371304K / 380888K total = 97% free
System-Free: 299116K / 1889440K total = 15% free
  • 1
  • 2
  • 3
  • 4
  • dropbox:各进程的dropbox的日志信息

  • statusbar:状态栏相关的信息

  • usagestats:每个界面启动的时间

  • meminfo:各进程的内存使用状况
    执行dumpsys meminfo查看的每个进程占用PSS的列表
    如果后面接pid或者包名就可以查看具体某个进程的内存详细状况
    执行dumpsys meminfo com.eg.android.AlipayGphone
    结果:
    支付宝的内存详情

  • package : 查看安装的信息
    主要就是获取AndroidManifest.xml里边的信息

  • window:键盘,窗口和它们的关系

  • wifi:WIFI的信息
    但是这个log太多了,看不明白

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/酷酷是懒虫/article/detail/945128
推荐阅读
相关标签
  

闽ICP备14008679号