Cloud-init.log日志如下:
![](https://img-blog.csdnimg.cn/img_convert/c2985929265d01bc78b4e75a0d529cbc.webp?x-oss-process=image/format,png)
cloud-init日志中提示:
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-3: ordinal not in range(128)
错误原因:
虚拟机(中文编码)启动时 , cloud-init初始化过程中在growpart之后有一个locale模块把系统编码改成了英文,所以第一次执行系统还是中文编码,启动之后系统已经是英文编码了 。
growpart是基于python的模块执行的,然而python对中文编码不是很友好,导致cloud-init报错,无法执行后续操作。
解决办法:
1. 查看系统编码:
echo $LANG 或者locale,
![](https://img-blog.csdnimg.cn/img_convert/bcb4d6617560bfdbc14c62b963344cd4.webp?x-oss-process=image/format,png)
其中的LANG字段表示系统当前的编码
2.更改系统编码:
修改/etc/sysconfig/i18n,如将中文编码修改为英文编码:
复制代码代码如下:
LANG= zh_CN.GBK 改为 LANG=" en_US.UTF-8" 之后重启即可