查看服务器重启前的 dmesg 日志

本文介绍了在服务器重启后如何查看重启前的dmesg日志,这对于排查服务器故障原因至关重要。在Ubuntu 15.04之前,可以通过查看/var/log/dmesg.0获取;而在Ubuntu 15.04及更高版本,可以利用journalctl -k -b -1命令查看。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注: 文章中的示例代码都在 Ubuntu 系统中执行,其他 Linux 发行版操作类似。

场景描述


在日常的运维工作中,不可避免的会遇到服务器故障的问题。虽然在应用运维或SRE岗,不必亲自去维修服务器,但是有必要去排查导致问题的原因,以便后续提交报修工单。

在各种类型的服务器故障中,有一种是这样的:

 某一天,服务器突然无法登录,服务器重启后又恢复正常。

服务器重启恢复正常后,我们登录到服务器上,需要去判断这次故障是否是由于硬件问题导致的,如果是硬件有问题的话,通常会在 dmesg 日志中有所体现。

问题是,每次服务器重启之后,登录到机器上执行 dmesg 命令,都只能展示本次重启后的日志,重启之前的日志就看不到了。而我们为了排查服务器故障的原因,就必须要看到重启之前的 dmesg 日志。

Ubuntu < 15.04


现在使用小于 Ubuntu 15.04 版本的人应该很少了,不过如果你在使用这些旧的 Ubuntu 系统的话,在你的 /var/log/ 目录下,会有如下名称的日志文件:

dmesg
dmesg.0
dmesg.1.gz
...

dmesg 日志文件中保存的是本次重启后的日志,而 dmesg.0 是这次重启前的 dmesg 日志,dmesg.1.gz 是上次重启前的 dmesg 日志,依次类推。

通过查看 dmesg.0 日志文件中的内容&#x

### 在Linux系统中添加新磁盘后不重启查看磁盘的方法 当在Linux系统中添加了一块新的磁盘而不希望重启系统时,可以通过多种方法来识别这块新增加的磁盘。以下是具体的操作方式: #### 使用`lsblk`命令查看磁盘 `lsblk`是一个非常直观的工具,用于列出所有可用块设备的信息,包括硬盘及其上的分区情况。执行此命令不需要任何额外参数即可显示当系统的存储布局。 ```bash lsblk ``` 这会显示出所有的磁盘和它们各自的分区结构,帮助快速定位到刚加入的新磁盘[^1]。 #### 利用`dmesg | tail`获取内核日志中的最新消息 每当有硬件变动发生时,比如插入或移除USB驱动器、连接网络接口卡等事件都会被记录下来。对于热插拔类型的磁盘来说也不例外。因此,通过读取最近的日志条目可以帮助确认是否有新的SCSI/SATA/NVMe等类型的磁盘已经被检测到了。 ```bash dmesg | tail ``` 上述命令将会输出最后几行来自内核的消息缓冲区的内容,其中可能包含了关于新发现磁盘的通知信息[^2]。 #### 执行`partprobe`刷新分区表 如果是在现有磁盘上创建了新的分区而不是整个全新的磁盘,则需要让操作系统重新扫描该磁盘以更新其内部维护着的一份副本——即所谓的“内存映射”。此时就可以调用`partprobe`来进行这项工作;它能够促使kernel去重检指定磁盘上的变化,并相应调整文件系统的视图。 ```bash sudo partprobe /dev/sdb ``` 这里假设目标磁盘为`sdb`,实际应用时应替换为自己环境中对应的名称[^3]。 #### 应用场景下的综合操作建议 为了确保能顺利找到刚刚附加上去的那个未分配过的裸盘,在完成以上任一检查手段之后还可以尝试运行一次完整的磁盘列表枚举动作,例如借助于`fdisk -l`或者更推荐现代版本下使用的`gdisk -l`(针对GPT格式化的大容量介质)。这些工具不仅限于展示基本信息还会提供有关每个已知卷的具体细节描述。 ```bash sudo fdisk -l # 或者 sudo gdisk -l /dev/sdx # 将sdx替换成具体的磁盘标识符 ``` 综上所述,通过组合运用上述几种技术方案便可以在无需中断服务的提下成功探测并管理好那些动态接入至服务器节点内的辅助型外设资源。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值