ubuntu16.04云服务器上docker服务启动报错(code=exited, status=1/FAILURE)

事件回顾:

重启ubuntu16.04云服务器后

service docker start 一直启动失败

排查阶段:

用service docker status查看,启动报错(code=exited, status=1/FAILURE),没有其他特别明显可排查的报错

网上查了下有可能是/etc/docker/daemon.json里文件包含错误字符而已的,但是之前没这json都可以启动。尝试新建daemon.json也一样重启报错。

继续排查,在网上搜到有可能是docker文件损坏,正常reboot重启应该不会损坏吧,但是我还是去看/var/lib/docker,一看,发现这个目录被软连接到/mnt下,而/mnt目录没有挂载。原来是之前的操作人员没有将磁盘自动挂载,所以重启后,目录没挂载,文件自然也没有,所以docker一直启动失败。

手动执行mount /dev/vdd /mnt 挂载后,重启docker服务成功

预防措施:

用自动挂载

由于云服务器设备名称可能会随着挂载卸载操作而变化,文件系统 UUID 在重新格式化文件系统后也会发生变化,从而导致自动挂载设置失效。所以我这里使用数据盘软连接 /disk/by-id。

1.先备份

cp /etc/fstab /etc/fstab.bak

 

2.查看数据盘的by-id

ls -l /dev/disk/by-id

3.使用如下命令将挂载信息写入 /etc/fstab

挂载的文件系统类型原来是ext3,可用blkid /dev/vdd查看原来磁盘设备初始化的类型是ext3,所以下面是ext3

echo /dev/disk/by-id/vxxxxxx-xxxxxxxx-xxxx-xxxx-x /mnt ext3 defaults 0 0 >> /etc/fstab

4.检查若无异常返回则说明文件正常,自动挂载成功

mount -a

 

 

 

你可能感兴趣的:(devops)