在Linux实例中,如果一些关键文件的格式不是Unix格式,可能导致该实例无法被远程连接。您可以通过实例健康诊断工具进行问题修复。
前提条件
Linux实例已通过实例健康诊断工具进行诊断,诊断结果中实例无法启动场景的系统关键文件格式检查未通过。
背景信息
问题描述:Linux实例中因部分关键文件的格式不是Unix格式,导致的实例无法被远程连接。
可能原因:出现问题的关键文件可能由Windows系统中编辑后上传至Linux实例,或因其它不当操作导致文件格式不是Unix。
解决方案
- 远程连接问题实例。当ECS实例处于正在挂载修复盘的模式下时,只能通过VNC远程连接。具体操作,请参见通过密码认证登录Linux实例。
- 查看问题实例原有系统盘的挂载信息。在临时挂载的修复盘中,问题实例原有系统盘的文件系统会被挂载到某一临时目录下。您可以通过以下任一方式查看所在的临时目录信息:
- 通过ECS控制台的实例健康诊断结果获取,对应的信息格式示例如下所示:
/tmp/ecs-offline-diagnose_disk-bp19bspzms79kqse****
。 - 在临时挂载的修复盘中,运行mount命令查看。例如,问题实例原有系统盘的设备路径为/dev/vda,命令示例如下所示:
mount | grep /dev/vda
返回结果如下所示:/dev/vda1 on /tmp/ecs-offline-diagnose_disk-bp19bspzms79kqse**** type ext4 (rw,relatime)
- 运行chroot命令,将根目录切换为问题实例原有系统盘所在的临时路径,并进入chroot环境。您需要在问题实例原有系统盘所在的临时路径中进行文件修复。例如,临时路径为/tmp/ecs-offline-diagnose_disk-bp19bspzms79kqse****,命令如下所示:
chroot /tmp/ecs-offline-diagnose_disk-bp19bspzms79kqse****
- 在chroot环境中,运行vim命令,编辑指定文件。编辑前,您需要注意以下事项:
vim [$File]
其中[$File]变量为指定的非Unix格式的文件名。本文以/etc/passwd文件为例,命令示例如下所示:vim /etc/passwd
- 编辑关键文件前,请先运行cp命令对文件进行备份。
例如,备份实例原有系统盘中的/etc/passwd文件命令为
cp /etc/passwd /etc/passwd.bak
。 - 当前编辑的文件均为问题实例原有系统盘中的文件,如果您需要编辑该系统盘挂载点之外的文件,请先运行exit命令退出chroot环境。
- 当前处于chroot环境,因此命令中不需要加上/tmp/ecs-offline-diagnose_disk-bp19bspzms79kqse****路径地址。
例如,实例原有系统盘中的/etc/passwd文件,编辑命令为vim /etc/passwd,不需要添加/tmp/ecs-offline-diagnose_disk-bp19bspzms79kqse****路径地址。
- 调整文件格式。
- 在文件内,按下Shift+:组合键,并输入
set ff=unix
后按下Enter键。 - 按下Shift+:组合键,并输入
wq
后按下Enter键,保存退出文件。 - 修复完成后,退出修复环境,然后检查问题实例的当前状态。
- 运行exit命令,退出chroot环境。
- 在ECS控制台的实例健康诊断页面,卸载临时挂载的修复盘并恢复问题实例至正常模式。
- 远程连接已修复的ECS实例,确认成功登录。
来源:阿里云