开机日志分析积累

开机日志分析积累

hongxi.zhu 2022-11-20

1. 开机各个阶段的日志和描述

logcat -b all 抓取所有类型开机日志,从下面的阶段event log可以了解每个阶段的耗时,方便我们定位开机性能的问题。
例子:

	Line    62: 11-10 23:03:54.396   792   792 I boot_progress_start: 3632
	Line    71: 11-10 23:03:54.953   792   792 I boot_progress_preload_start: 4189
	Line    88: 11-10 23:03:56.254   792   792 I boot_progress_preload_end: 5489
	Line    92: 11-10 23:03:56.642  1367  1367 I boot_progress_system_run: 5878
	Line   559: 11-10 23:03:57.485  1367  1367 I boot_progress_pms_start: 6721
	Line   872: 11-10 23:03:57.663  1367  1367 I boot_progress_pms_system_scan_start: 6898
	Line   894: 11-10 23:03:57.938  1367  1367 I boot_progress_pms_data_scan_start: 7174
	Line   900: 11-10 23:03:57.953  1367  1367 I boot_progress_pms_scan_end: 7189
	Line   929: 11-10 23:03:58.139  1367  1367 I boot_progress_pms_ready: 7375
	Line  2021: 11-10 23:03:59.639  1367  1367 I boot_progress_ams_ready: 8875
	Line  3361: 11-10 23:04:01.016  1367  1533 I boot_progress_enable_screen: 10251
	Line  5251: 11-10 23:04:03.237   644   675 I sf_stop_bootanim: 12473
	Line  5252: 11-10 23:04:03.238  1367  1533 I wm_boot_animation_done: 12473
log tagdesc
boot_progress_start系统进入用户空间,标志着kernel启动完成
boot_progress_preload_startZygote启动
boot_progress_preload_endZygote结束
boot_progress_system_runSystemServer ready,开始启动Android系统服务
boot_progress_pms_startPMS开始扫描安装的应用
boot_progress_pms_system_scan_startPMS先行扫描/system目录下的安装包
boot_progress_pms_data_scan_startPMS扫描/data目录下的安装包
boot_progress_pms_scan_endPMS扫描结束
boot_progress_pms_readyPMS就绪
boot_progress_ams_readyAMS就绪
boot_progress_enable_screenAMS启动完成后开始激活屏幕,从此以后屏幕才能响应用户的触摸,它在WindowManagerService发出退出开机动画的时间节点之前
sf_stop_bootanimSF设置service.bootanim.exit属性值为1,标志系统要结束开机动画了
wm_boot_animation_done开机动画结束,这一步用户能直观感受到开机结束

从Android 12源码中找到上述的节点log位置:

  1. boot_progress_start
# frameworks/base/core/jni/AndroidRuntime.cpp:1208

void AndroidRuntime::start(const char* className, const Vector<String8>& options, bool zygote)
{
    ALOGD(">>>>>> START %s uid %d <<<<<<\n",
            className != NULL ? className : "(unknown)", getuid());

    static const String8 startSystemServer("start-system-server");
    // Whether this is the primary zygote, meaning the zygote which will fork system server.
    bool primary_zygote = false;

    /*
     * 'startSystemServer == true' means runtime is obsolete and not run from
     * init.rc anymore, so we print out the boot start event here.
     */
    for (size_t i = 0; i < options.size(); ++i) {
        if (options[i] == startSystemServer) {
            primary_zygote = true;
           /* track our progress through the boot sequence */
           const int LOG_BOOT_PROGRESS_START = 3000;
           LOG_EVENT_LONG(LOG_BOOT_PROGRESS_START,  ns2ms(systemTime(SYSTEM_TIME_MONOTONIC)));  //boot_progress_start
        }
    }
    ...
  1. boot_progress_preload_start
frameworks/base/core/java/com/android/internal/os/ZygoteInit.java:954

   public static void main(String[] argv) {
            ...
            // In some configurations, we avoid preloading resources and classes eagerly.
            // In such cases, we will preload things prior to our first fork.
            if (!enableLazyPreload) {
                bootTimingsTraceLog.traceBegin("ZygotePreload");
                EventLog.writeEvent(LOG_BOOT_PROGRESS_PRELOAD_START,
                        SystemClock.uptimeMillis());  //boot_progress_preload_start
                preload(bootTimingsTraceLog);
                EventLog.writeEvent(LOG_BOOT_PROGRESS_PRELOAD_END,
                        SystemClock.uptimeMillis());
                bootTimingsTraceLog.traceEnd(); // ZygotePreload
            }
            ...
  1. boot_progress_preload_end
frameworks/base/core/java/com/android/internal/os/ZygoteInit.java:957

   public static void main(String[] argv) {
            ...
            // In some configurations, we avoid preloading resources and classes eagerly.
            // In such cases, we will preload things prior to our first fork.
            if (!enableLazyPreload) {
                bootTimingsTraceLog.traceBegin("ZygotePreload");
                EventLog.writeEvent(LOG_BOOT_PROGRESS_PRELOAD_START,
                        SystemClock.uptimeMillis());
                preload(bootTimingsTraceLog);
                EventLog.writeEvent(LOG_BOOT_PROGRESS_PRELOAD_END,
                        SystemClock.uptimeMillis());  //boot_progress_preload_end
                bootTimingsTraceLog.traceEnd(); // ZygotePreload
            }
            ...
  1. boot_progress_system_run
frameworks/base/services/java/com/android/server/SystemServer.java:759

        private void run() {
        TimingsTraceAndSlog t = new TimingsTraceAndSlog();
        try {
            t.traceBegin("InitBeforeStartServices");
            ...
            // Here we go!
            Slog.i(TAG, "Entered the Android system server!");
            final long uptimeMillis = SystemClock.elapsedRealtime();
            EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_SYSTEM_RUN, uptimeMillis);  //boot_progress_system_run
            if (!mRuntimeRestart) {
                FrameworkStatsLog.write(FrameworkStatsLog.BOOT_TIME_EVENT_ELAPSED_TIME_REPORTED,
                        FrameworkStatsLog
                                .BOOT_TIME_EVENT_ELAPSED_TIME__EVENT__SYSTEM_SERVER_INIT_START,
                        uptimeMillis);
            }
            ...
  1. boot_progress_pms_start
# frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java:7386

    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest,
            final String buildFingerprint, final boolean isEngBuild,
            final boolean isUserDebugBuild, final int sdkVersion, final String incrementalVersion) {
        mIsEngBuild = isEngBuild;
        mIsUserDebugBuild = isUserDebugBuild;
        mSdkVersion = sdkVersion;
        mIncrementalVersion = incrementalVersion;
        mInjector = injector;
        mInjector.getSystemWrapper().disablePackageCaches();

        final TimingsTraceAndSlog t = new TimingsTraceAndSlog(TAG + "Timing",
                Trace.TRACE_TAG_PACKAGE_MANAGER);
        mPendingBroadcasts = new PendingPackageBroadcasts();

        mInjector.bootstrap(this);
        mLock = injector.getLock();
        mInstallLock = injector.getInstallLock();
        LockGuard.installLock(mLock, LockGuard.INDEX_PACKAGES);
        EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_START,
                SystemClock.uptimeMillis());  //boot_progress_pms_start
        ...
  1. boot_progress_pms_system_scan_start
# frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java:7587
    public PackageManagerService(Injector injector, boolean onlyCore, boolean factoryTest,
            final String buildFingerprint, final boolean isEngBuild,
            final boolean isUserDebugBuild, final int sdkVersion, final String incrementalVersion) {
            ...
            EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_SYSTEM_SCAN_START,
                    startTime);  //boot_progress_pms_system_scan_start
            ...
            for (int i = mDirsToScanAsSystem.size() - 1; i >= 0; i--) {
                final ScanPartition partition = mDirsToScanAsSystem.get(i);
                if (partition.getOverlayFolder() == null) {
                    continue;
                }
                scanDirTracedLI(partition.getOverlayFolder(), systemParseFlags,
                        systemScanFlags | partition.scanFlag, 0,
                        packageParser, executorService);
            }
            ...
  1. boot_progress_pms_data_scan_start
# frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java:7790
            ...
            final long systemScanTime = SystemClock.uptimeMillis() - startTime;
            final int systemPackagesCount = mPackages.size();
            Slog.i(TAG, "Finished scanning system apps. Time: " + systemScanTime
                    + " ms, packageCount: " + systemPackagesCount
                    + " , timePerPackage: "
                    + (systemPackagesCount == 0 ? 0 : systemScanTime / systemPackagesCount)
                    + " , cached: " + cachedSystemApps);
            if (mIsUpgrade && systemPackagesCount > 0) {
                //CHECKSTYLE:OFF IndentationCheck
                FrameworkStatsLog.write(FrameworkStatsLog.BOOT_TIME_EVENT_DURATION_REPORTED,
                    BOOT_TIME_EVENT_DURATION__EVENT__OTA_PACKAGE_MANAGER_SYSTEM_APP_AVG_SCAN_TIME,
                    systemScanTime / systemPackagesCount);
                //CHECKSTYLE:ON IndentationCheck
            }
            if (!mOnlyCore) {
                EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_DATA_SCAN_START,
                        SystemClock.uptimeMillis());  // boot_progress_pms_data_scan_start
                scanDirTracedLI(mAppInstallDir, 0, scanFlags | SCAN_REQUIRE_KNOWN, 0,
                        packageParser, executorService);

            }
            ...
  1. boot_progress_pms_scan_end
# frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java:7982

            ...
            // Now that we know all the packages we are keeping,
            // read and update their last usage times.
            mPackageUsage.read(packageSettings);
            mCompilerStats.read();

            EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_SCAN_END,
                    SystemClock.uptimeMillis()); //boot_progress_pms_scan_end
            Slog.i(TAG, "Time to scan packages: "
                    + ((SystemClock.uptimeMillis()-startTime)/1000f)
                    + " seconds");
            ...
  1. boot_progress_pms_ready
# frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java:8121

            ...
            // can downgrade to reader
            t.traceBegin("write settings");
            writeSettingsLPrTEMP();
            t.traceEnd();
            EventLog.writeEvent(EventLogTags.BOOT_PROGRESS_PMS_READY,
                    SystemClock.uptimeMillis());  //boot_progress_pms_ready
            ...

  1. boot_progress_ams_ready
# frameworksbase/services/core/java/com/android/server/am/ActivityManagerService.java:7612

    /**
     * Ready. Set. Go!
     */
    public void systemReady(final Runnable goingCallback, @NonNull TimingsTraceAndSlog t) {
        t.traceBegin("PhaseActivityManagerReady");
        mSystemServiceManager.preSystemReady();
        ...
        Slog.i(TAG, "System now ready");

        EventLogTags.writeBootProgressAmsReady(SystemClock.uptimeMillis());  //boot_progress_ams_ready
        ...
  1. boot_progress_enable_screen
# framework/base/services/core/java/com/android/server/wm/ActivityTaskManagerService.java:5620

        ...
        @Override
        public void enableScreenAfterBoot(boolean booted) {
            writeBootProgressEnableScreen(SystemClock.uptimeMillis());  //boot_progress_enable_screen
            mWindowManager.enableScreenAfterBoot();
            synchronized (mGlobalLock) {
                updateEventDispatchingLocked(booted);
            }
        }

  1. sf_stop_bootanim
# framework/native/services/surfaceflinger/SurfaceFlinger.cpp:750

void SurfaceFlinger::bootFinished() {
    ...
    // stop boot animation
    // formerly we would just kill the process, but we now ask it to exit so it
    // can choose where to stop the animation.
    property_set("service.bootanim.exit", "1");

    const int LOGTAG_SF_STOP_BOOTANIM = 60110;
    LOG_EVENT_LONG(LOGTAG_SF_STOP_BOOTANIM,
                   ns2ms(systemTime(SYSTEM_TIME_MONOTONIC)));  //sf_stop_bootanim
    ...
  1. wm_boot_animation_done
# framework/base/services/core/java/com/android/server/wm/WindowManagerService.java:3691

    private void performEnableScreen() {
            ...
            try {
                IBinder surfaceFlinger = ServiceManager.getService("SurfaceFlinger");
                if (surfaceFlinger != null) {
                    ProtoLog.i(WM_ERROR, "******* TELLING SURFACE FLINGER WE ARE BOOTED!");
                    Parcel data = Parcel.obtain();
                    data.writeInterfaceToken("android.ui.ISurfaceComposer");
                    surfaceFlinger.transact(IBinder.FIRST_CALL_TRANSACTION, // BOOT_FINISHED
                            data, null, 0);
                    data.recycle();
                }
            } catch (RemoteException ex) {
                ProtoLog.e(WM_ERROR, "Boot completed: SurfaceFlinger is dead!");
            }

            EventLogTags.writeWmBootAnimationDone(SystemClock.uptimeMillis());  //wm_boot_animation_done
            Trace.asyncTraceEnd(TRACE_TAG_WINDOW_MANAGER, "Stop bootanim", 0);
            mDisplayEnabled = true;
            ProtoLog.i(WM_DEBUG_SCREEN_ON, "******************** ENABLING SCREEN!");

            // Enable input dispatch.
            mInputManagerCallback.setEventDispatchingLw(mEventDispatchingEnabled);
        }

        try {
            mActivityManager.bootAnimationComplete();
        } catch (RemoteException e) {
        }

        mPolicy.enableScreenAfterBoot();

        // Make sure the last requested orientation has been applied.
        updateRotationUnchecked(false, false);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要对Android开机时的内存进行分析,可以使用以下方法[^1]: 1. 首先,通过adb shell命令获取系统当前内存状态。可以使用以下命令: ``` adb shell cat /proc/meminfo ``` 该命令可以输出系统的内存信息,包括总内存、空闲内存、缓存等。 2. 如果机器在运行的过程中MemAvailable持续减小,就可以怀疑系统中存在内存泄漏。但是并不是MemAvailable减小就一定存在内存泄漏,还要进一步分析减少的内存被什么占用了。可以使用以下命令获取内存占用信息: ``` adb shell cat /proc/meminfo | grep "Active(anon)\|Inactive(anon)\|SUnreclaim" ``` 该命令可以输出Active(anon)、Inactive(anon)和SUnreclaim所占用的内存情况。其中,Active(anon)+Inactive(anon)所占用的内存增加,说明用户进程占用的内存增加。如果SUnreclaim所占用的内存增加,说明kernel占用的内存增加。 3. 知道了减少的内存是被用户进程还是kernel占用之后,要分析是哪个用户进程或内核哪部分占用了内存。可以使用以下命令: ``` adb shell dumpsys meminfo ``` 该命令可以输出每个进程的内存占用情况,包括Native Heap、Dalvik Heap等。 4. 如果需要进一步分析某个进程的内存占用情况,可以使用以下命令: ``` adb shell dumpsys meminfo <pid> ``` 其中,<pid>为进程的ID号。 另外,如果需要分析slab占用情况,可以使用以下命令: ``` adb shell cat /proc/slabinfo ``` 该命令可以输出所有slab的信息,包括名称、对象大小、分配情况等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

坂田民工

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值