java watchdog_Watchdog实现分析

java watchdog_Watchdog实现分析系统启动过程图:Framework层所有的Service都是运行在SystemServer进程中;SystemServer进程是由Zygote进程创建。SystemServer进程启动分两个过程init1创建Service和进程状态对象;init2创建Framework层的Service,将其加入到ServiceManager中,最后启动launcher;Android提供了Watchdog类,用…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

系统启动过程图:

bc9fb55984804210b7c476dc042fa092.png

Framework层所有的Service都是运行在SystemServer进程中;SystemServer进程是由Zygote进程创建。

SystemServer进程启动分两个过程init1创建Service和进程状态对象;init2创建Framework层的Service,将其加入到ServiceManager中,最后启动launcher;

Android提供了Watchdog类,用来监测Service是否处于正常工作中,是在SystemServer中启动的。

下面看一下SystemServer中Watchdog这个过程。

SystemServer.java:

public voidrun() {//初始化Watchdog 传入各个Service作为参数

Watchdog.getInstance().init(context, battery, power, alarm,

ActivityManagerService.self());//启动Watchdog

Watchdog.getInstance().start();

}

Watchdog类实现

类继承结构:

7c993e4ac85bbb3c4ec149841f5f227d.png

看到Watchdog是一个Thread,运行在SystemServer进程中,单例模式;

HeartbeatHandler处理接受监控的对象(Service),运行在主线程中;

Monitor提供监控接口,接受监控对象实现此接口;

XXXService具体实现的检测对象。

执行流程:

ef28aad15e2252b7b685cf4252fdea05.png

对外接口

初始化:

public voidinit(Context context, BatteryService battery,

PowerManagerService power, AlarmManagerService alarm,

ActivityManagerService activity) {//存储Service对象,运行在同一个进程中

mResolver =context.getContentResolver();

mBattery= battery; mPower =power;

mAlarm= alarm; mActivity =activity;//注册广播

context.registerReceiver(newRebootReceiver(),newIntentFilter(REBOOT_ACTION));

mRebootIntent=PendingIntent.getBroadcast(context,0, new Intent(REBOOT_ACTION), 0);

……//开机时间

mBootTime =System.currentTimeMillis();

}

注册监控对象:

public voidaddMonitor(Monitor monitor) {

synchronized (this) {//将监控对象加入到列表中

mMonitors.add(monitor);

}

}

搜索一下此函数的调用,表示被监控;看到在如下Service中实现Watchdog的Monitor接口:

ActivityManagerService

InputManagerService

NetworkManagementService

PowerManagerService

WindowManagerService

都有调用:Watchdog.getInstance().addMonitor(this);

Watchdog线程执行函数:

public voidrun() {

boolean waitedHalf= false;while (true) {//监测完成标志

mCompleted = false;//发送监测消息

mHandler.sendEmptyMessage(MONITOR);

synchronized (this) {long timeout =TIME_TO_WAIT;long start =SystemClock.uptimeMillis();while (timeout > 0 && !mForceKillSystem) {//休眠等待检查结果

wait(timeout); //notifyAll() is called when mForceKillSystem is set

timeout = TIME_TO_WAIT – (SystemClock.uptimeMillis() -start);

}if (mCompleted && !mForceKillSystem) {//检查结果OK

waitedHalf = false;continue;

}//在进行检查一次

if (!waitedHalf) {

ActivityManagerService.dumpStackTraces(true, pids, null, null,

NATIVE_STACKS_OF_INTEREST);

waitedHalf= true;continue;

}

}//表明监控对象有问题//If we got here, that means that the system is most likely hung.//First collect stack traces from all threads of the system process.//Then kill this process so that the system will restart.//保存stack信息

……//Only kill the process if the debugger is not attached.

if(!Debug.isDebuggerConnected()) {if(SystemProperties.getInt(“sys.watchdog.disabled”, 0) == 0) {//kill当前进程SystemServer

Process.killProcess(Process.myPid());

System.exit(10);

}

}

waitedHalf= false;

}

}

在此run函数中循环发送消息,判断标志是否正常,决定检测对象是否正常工作。

若监测对象不正常工作,则收集重要的stack信息保存下来,然后重启SystemServer。

监测消息的处理:

是在HeartbeatHandler中进行,看看消息处理函数。

public voidhandleMessage(Message msg) {switch(msg.what) {caseMONITOR: {//See if we should force a reboot.//监测对象是否正常工作中……

final int size =mMonitors.size();for (int i = 0 ; i < size ; i++) {//调用监测对象的monitor接口

mCurrentMonitor = mMonitors.get(i);

mCurrentMonitor.monitor();

}//走到这里表明监测对象正常

synchronized (Watchdog.this) {

mCompleted= true;

mCurrentMonitor= null;

}

}break;

}

}

判断监测对象是否正常工作,通过调用监测对象实现的接口monitor,看看这个接口该如何执行的。

PowerManagerService中:

public voidmonitor() {//判断Service是否发生死锁,如果发生死锁,程序将在此一直等待

//主要是线程间同步问题 造成死锁

synchronized (mLocks) { }

}

以上便是Watchdog监测Service是否正常工作的流程;我们也可以使用Watchdog来监测别的资源如内存等使用情况。

这个Watchdog给我们提供了一种思路,一种框架,对程序正常运行或者资源的正常使用情况等的一种监测机制。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/230820.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 浅谈CICD持续集成、持续部署的流程

    浅谈CICD持续集成、持续部署的流程Jenkins是一个比较流行的持续集成工具GitLab是存储镜像的镜像仓库由客户端将代码push推送到git仓库,gitlab上配置了一个webHook的东西可以触发Jenkins的构建。进入到Jenkins虚线范围内,它所做的事情非常多,从mvn构建代码,对代码进行静态分析,做单元测试,测试通过之后就可以build镜像,镜像构建成功后就把镜像push推送到Harbor镜像仓库中,镜像push…

    2022年6月11日
    29
  • 基于特征的图像拼接算法_图像拼接算法原理

    基于特征的图像拼接算法_图像拼接算法原理目录APAP算法思路几个问题SVD在最小二乘中的应用DLT求单应性矩阵HMovingDLT求局部单应性矩阵实现的小细节文献图像拼接首先通过一些手段(标定、SIFT等特征点、其他传感器等)获取图像间的对应关系(2D-2D)。这个对应关系可以用单应性矩阵HHH(也称透视变换)描述[x′y′w′]=[h00h01h02h10h11h12h20h21h22][xyw]=H[xyw](1)\begin{aligned}\left[\begin{matrix}x’\\y’\\w’\end{matrix}\ri

    2022年9月22日
    1
  • pychram安装教程

    pychram安装教程前言Pycharm社区版其实基本也够用的,但是,但是,还是想装专业版呢。一、安装pycharm1.下载安装包先去官网下载好安装包,我们这里用Windown环境的普通版就够用了https://www.jetbrains.com/pycharm/download/#section=windows2.安装后面就是一路next,跟装个QQ一样安装完成后,选择稍后重启电脑,然后去桌面打开pycharm…

    2022年8月27日
    2
  • Netty权威指南V2.0版_javascript权威指南第七版

    Netty权威指南V2.0版_javascript权威指南第七版作者:李林锋著作出版发行:北京:电子工业出版社,2015.04ISBN号:978-7-121-25801-5页数:554开本:16开主题词:JAVA语言-程序设计-指南中图法分类号:TP312-62(工业技术->自动化技术、计算机技术->计算技术、计算机技术->计算机软件)内容提要:《Netty权威指南(第2版)…

    2022年10月2日
    1
  • javascript 换行符[通俗易懂]

    javascript 换行符[通俗易懂] 在JS的字符串里对[TAB]的表述是 /x09  你可以做这样的测试: alert(“/x41”); //看看得到是什么?? 是字母A(41是十六进制的ASCII码值)  我喜欢用 /x0f 这类的做分隔符, [TAB]键用户还是有可能输入的, 但 /x0f 就绝对不可能输入  var s = “A/x0fB/x0fC/x0f

    2022年5月10日
    41
  • php图片加水印(华为关水印)

    很多站长朋友们都知道,Phpcmsv9有自带的水印功能。今天无忧主机小编在给一个朋友修改网站时,询问小编能否把Phpcmsv9自带的水印功能去掉呢,因为有时候在编辑器中上传图片时,不希望上传的图片被自动加上phpcmsv9自带的水印。无忧主机小编分析:既然是程序中的功能,那么就一定有一段代码控制着这个功能。通过进一步的查找资料,小编找得到了这个功能所在的文件以及相应的控制代码。下面无忧主机小编…

    2022年4月12日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号