系统自动关机怎么处理(电脑总是自动关机?这 2 条命令帮你轻松)

100次浏览     发布时间:2025-01-28 00:33:06    


即使现在的系统相比 20 年前已经稳定了很多了,使用电脑时也难免会遇到蓝屏、意外重启、甚至是意外关机的情况。尽管这种问题可能只是偶然发生,可以说是不太走运;但更多的时候放着不管,反而会让电脑的问题出现得越来越频繁。

一个蓝屏小「贴士」

所以,这篇文章就旨在帮助大家快速找到让电脑不能正常工作的罪魁祸首,虽然不一定能「药到病除」,但也能让你离正确答案更近一步。

▍macOS

尽管 macOS 是 Apple 为 Mac 产品线定制的操作系统,但实际上出现问题的机会还是很多的。虽然在 macOS 中我们可以通过控制台获取日志信息,但从 macOS Sierra 及更高版本开始,考虑到安全和隐私问题,控制台只允许访问最近的日志条目,而不是整个日志文件。

所以想要分析日志中所有和关机有关的事件,就需要通过「终端」和相应的指令进行分析。如果你的 Mac 近期出现了意外重启等问题,不妨跟着下面的步骤试一试,打开「终端」,并输入如下指令:

log show --predicate 'eventMessage contains "Previous shutdown cause"' --last 24h

上面这一串指令会使用 log show 检索系统日志,predicate 可以进一步筛选日志,在本文中我们筛选的日志类型是 eventMessage 中包含 Previous shutdown cause(此前关机的原因)的信息,而筛选的时间范围 --last 24h 则是过去 24 小时,如果有必要的话可以扩展到 36 小时甚至更长。

来自作者群的一个朋友

静静等待一段,你就能看到如上图一样的、将日志筛选后到结果,我们需要注意的信息就是Previous shutdown cause后续跟随的数字,这个数字代表着 Mac 电脑上次是因为什么原因而关闭的。

总的来说,负数的代码通常是因硬件而关机的,该信息由系统管理控制器(SMC)或处理器本身报告;而正数因软件而关机的。以下是每个代码所包含的含义:

如果你的 Mac 出现大量因为 0(断电)导致的意外关闭,那么就需要进行一定的排查。对于没有电池的台式 Mac 而言,主要检查的就是电源线有没有牢牢插入到电源接口中;如果依然出现这样的问题则很有可能是计算机内的电源出现了问题,需要进行维修。

对于有电池的笔记本型 Mac 而言,需要同时检查电源线和电池;笔记本型 Mac 通常会在电池耗尽之前进入休眠状态;出现断电而导致的关机很有可能是电池或读取电量的电池控制器有硬件问题,对于 Intel 款 Mac 而言需要根据官方文档重置 smc,而 M 系列 Mac 需要手动重启一次。如果上述步骤依然不起作用的话,也需要进行维修。

长时间未响应可能会让整个系统崩溃,严重时还会导致相关数据丢失。定时器超时作为 macOS 中一项功能,它可以有效防止未响应的程序导致的内核崩溃。

偶然发生的 -61/-62 错误可能没什么问题,但短时间内出现大量的类似错误就要对电脑进行排查了;-61 表示系统认为不能自动恢复的情况只能进行关机,而 -62 用于系统确定重启后可能解决的情况并进行重启。

排查的办法很简单,在 macOS 启动时进入安全模式,在安全模式下启动项目和守护程序都被禁用;如果没有再次意外关机则是最近安装或更新的程序出现了问题,如果再次意外关机则和系统本身有关。

以上就是 macOS 的部分了,相信这个指令可以简单帮你定位问题,并为你后续的问题解决打下一个不错的基础。

▍Windows

除了 macOS,Windows 系统日志同样可以在时间查看器中查看并进行筛选,但考虑界面相对「复古」且用于筛选的 UI 选项更为复杂,因此我也更推荐大家使用命令行工具获取和筛选日志。

有的时候用 UI 界面反而会让一件事情变得更复杂

如果你的 PC 电脑近期出现了意外重启等问题,不妨跟着下面的步骤试一试:

# 命令 1Get-Eventlog -LogName System -Source "User32" | group EventID# 命令 2Get-EventLog -LogName System -Source "
Microsoft-Windows-Kernel-Power" | Where-Object { $_.EventID -eq 41 }

Get-EventLog 是 Windows 中获取日志的命令,-LogName System 则限定了查找由系统生成的命令。-Source 则是来源,User32 和
Microsoft-Windows-Kernel-Power 则是两个不同的来源。

从用户或程序层面进行分析

User32 是一个 Windows 系统应用程序源,它包含了许多与用户界面相关的函数,如窗口创建、消息处理、控件操作等等;它还会负责处理用户交互方面的任务,例如鼠标、键盘输入和窗口管理等。

因此由用户或是程序发起的事件,如登录、注销、锁定或解锁计算机等,都可以通过 User32 来源来定位。而后 | 用于进一步处理 Get-EventLog 得到的数据,这里按照 EventID 事件 ID 来group 成组。

目前我电脑中只有 1074 这个事件,这个 1074 事件是计算机的正常关机的主要表现形式。如果 User32 有其他的 EventID 那么用下面的命令进一步分析:

# 本例中依然用 1074 做分析 Get-Eventlog -LogName System -Source "User32"-Newest 1 | Where-Object { $_.EventID -eq 1074} | fl *

前面的命令就不再赘述了,-Newest 1 表示选取最近的一个日志, | 用于进一步筛选 Get-EventLog 得到的数据。Where-Object 表示筛选一个对象数组,$_ 表示当前处理的对象(也就是 | 传递过来的数据 ),.EventID 表示对象的 EventID 属性,-eq 是一个比较运算符,表示等于,这里等于的 1074 这个事件。| 依然是用于进一步处理 Where-Object 得到的数据,由 fl(也可以用完整写法 Format-List 替代)格式化输出对象的 * 所有属性。

找到其中的Reason Code: 0x80020010可以得知这是一个计划内的关机请求,如果不是服务器的话,这一般由 Windows Update 自动更新发起;而由用户发起的关机则会被标识为 0x0。以下是常见的 Reason Code 所表示的含义:

蓝屏问题导致关机或重启,还可以进一步下方的命令进行分析。

从电源管理相关的事件入手进行分析

不过很多意外关机的事件,比如蓝屏导致的,无法被 User32 捕获,因此从
Microsoft-Windows-Kernel-Power 获取电源状态、电源事件以及与电源管理相关的错误和警告信息得到更多的信息。

Get-EventLog -LogName System -Source "Microsoft-Windows-Kernel-Power" | Where-Object { $_.EventID -eq 41 }

代码中相似的内容不再赘述,在
Microsoft-Windows-Kernel-Power和意外关机有关的 EventID 是 41,这个事件通常是在意外关机后重启的阶段中生成的。输入上面的命令以后,Powershell 会输出一段包含十进制 BugcheckCode 的内容,首先需要将它转换为十六进制,以做进一步分析。

如 159 等同于 0x0000009f,209 等同于 0x000000d1 等等,转换后的十六进制就可以得到最终的含义了。BugcheckCode 内容也和蓝屏时输出的错误码是相同的内容,有的时候蓝屏代码一跳而过,所以这也是找到问题的好办法。以下是常见的错误的代码以及含义 :

由于错误码的种类繁多,因此这里不太可能一一列举。另外还需要注意的是,同一个错误可能会有不同的原因而导致,排查时可以从近期的软件改动入手去寻找电脑意外关机的原因,排查完软件以后才是排查硬件的真正时机。

关于 Powershell 7 使用中的一些细节

值得注意的是,Get-EventLog 只能使用 Windows 内的 Powershell 运行;Powershell 7 中因为相关 API 已被弃用,会提示无效指令,因此需要换用Get-WinEvent命令:

#命令 1Get-WinEvent -ProviderName 'User32' | group EventID#命令 2Get-WinEvent -ProviderName "
Microsoft-Windows-Kernel-Power" | Where-Object { $_.EventID -eq 41}#命令 2 改进版Get-WinEvent -FilterHashtable @{ProviderName = "
Microsoft-Windows-Kernel-Power"; Id = 41}

Get-WinEvent 是 Powershell 7 中获取 Windows 日志的新命令,不同于此前的 Get-EventLog 能同时筛选具体的事件日志 -LogName 和事件源 -Source;Get-WinEvent在使用时只能在筛选事件日志 -Logname 和事件源 -ProviderName 中二选一。Get-WinEvent 还 可以使用一个新的写法 -FilterHashtable,降低命令长度的同时提高索引效率。

相关推荐

  • 腊八粥的材料有哪些(教你传统的腊八粥做法)
    由于咱们国家地大物博,少数民族众多,各地腊八节的过法和饮食活动也不尽相同。但大致上都要喝腊八粥,而且因为地域和民族的不同,各地腊八粥的做法多有所不同。今天小面姨给大家推荐一道腊八粥的做法,是一种我们这里最简单的腊八粥做法,美味好喝,营养丰富。对于咱们每个人或者每个家庭来说,腊八节吃腊八粥都想有一个好
    2025-03-05 21:23:13
  • 1t硬盘是什么意思(为什么1T的固态硬盘显示只有931G容量?)
    Why does a 1TB SSD offer only 931GB of space?【译】为什么1TB的SSD只能提供931GB的空间?【解析】1TB在这里是指硬盘的容量,其中,B代表bytes,即“字节”,一个字节表示计算机领域中的8个2进制位,T则表示trillion,即万亿,1TB即1万
    2025-03-01 01:35:03
  • 番茄炒蛋怎么做才好吃?教你一招
    番茄炒蛋是一道家常菜,做法简单易学。下面分享一种常见的做法。首先准备食材:番茄、鸡蛋、盐和食用油。番茄选择成熟、多汁的两个,鸡蛋根据个人口味选择数量,并将其切成适当大小的块状。然后将番茄去蒂,用沸水烫一下去皮,再切成小块备用。鸡蛋打散。接着加热油。炒锅加热后倒入适量的油,烧热后可以多放一些油,这样炒
    2025-02-22 03:25:00
  • 豆腐串的做法大全(自制美食 五香豆腐串)
    用料 豆腐串/豆腐皮若干辣椒,花椒,香叶,八角,桂皮适量孜然可以多一些(其实香料可以根据喜好随意添加类别)葱姜蒜适量生抽,老抽,糖,盐,鸡精适量五香豆腐串的做法 热锅凉油放入干香料煎出香味,转大火,加入葱姜蒜爆香,加水烧开。2.水开后加入生抽,老抽,糖,盐,鸡精,大火煮5分钟。3.然后放入豆腐串。大
    2025-02-21 10:33:30
  • 芹菜炒豆皮的做法家常(豆皮炒芹菜,脆嫩爽口、味美鲜香扑面来)
    一、经典家常菜——豆皮炒芹菜美食特点豆皮炒芹菜,脆嫩爽口、味美鲜香、营养又健康二、经典家常菜——豆皮炒芹菜食材原料1)主料:豆皮、芹菜2)辅料:食用油3)调料:食用盐、生抽三、经典家常菜——豆皮炒芹菜营养价值1)豆皮炒芹中的豆皮富含:蛋白质、氨基酸、铁、 钙、钼等人体所必需的18种微量元素。2)豆皮
    2025-02-21 10:12:24
  • 松鼠鱼做法全教程(造型惊艳的“松鼠鱼”。)
    松鼠鱼因其形似松鼠、造型逼真而得名。是一道传统名菜,通常以草鱼、鲤鱼、鲑鱼等鱼类为原料,色泽鲜艳,鲜嫩酥香,酸甜适口,受到很多人的喜爱。虽然很多人钟爱这道“神菜”,但是人们看到它的刀工造型就头疼,却很少有人会去做这道菜,其实做法非常简单。松鼠鱼的做法:<原料>草鱼一条、番茄酱、白糖、白醋
    2025-02-21 07:57:25