AWS使用快照创建实例启动失败
问题描述
因业务需求,需要将A集群复制一份到B集群,当做预生产环境使用。但是在AWS使用快照的方式创建EC2实例的时候无法正常启动,通过获取AWS EC2截图能够看到已经到了登录界面。

分析过程
在发现问题后尝试使用SSM登录,但是却无法登录进系统内部。后再停止实例运行,然后在运行实例,依然无法启动。
为了排查是VPC的问题,还是实例镜像的问题。使用另外一台服务器的镜像启动,但是依然无效。最后在待实例进入 running 状态后,依次选择 Actions、Instance Settings、Get System Log通过获取系统日志发现了一些问题。

后来在通过查看服务器的python版本的时候发现

到这里,基本上能确定是python版本的问题了。
最后通过分析排查发现是因为环境配置所导致。
Linux 系统默认的python2.7被修改为了python3.6.8 快照的恢复使用的应用是Cloud-init,cloud-init调用的是python 也就是系统默认的python2.7的版本 也就导致cloud-init调用了python3.6.8的版本,从而导入配置失败。
关于cloud-init可参考 cloud-init文档
解决方法
在/usr/bin/cloud-init中修改#!/usr/bin/python为 #!/usr/bin/python2.7然后手动创建快照。在用创建的快照重新启动一台新的实例来。
最后
为了能够更好的解决这个问题。后来通过实际测试,centos7系统中默认使用的python版本为python2.7,我们通过使用yum安装,是不会覆盖掉系统的python版本。
|
|
所以建议,系统中同时存在两个python版本,您使用yum安装python3这样不会覆盖系统的python版本,在您不想使用系统python2.7.x 而使用python3时,您直接在相应应用指明使用python的版本即可。
如果将Centos7中系统默认的python版本修改为python3时,这个可能会遇到各种各样的问题。
不过python2.7 已经停止维护了,如果不想使用python2.7,目前可能只能通过升级系统的方式来解决这个问题,centos8和redhat8系统默认使用的python版本都是python3
文章链接
https://www.cnsre.cn/posts/210311132723/