今天使用vagrant ,代码同步:vagrant rsync-auto 发现代码同步失效了,几次重启之后发现启动报错:
有点疑惑,因为1h之前还同步过修改的代码,现在突然报错,目前仍然不明原因(这1h之内没有做过任何编码设置/修改的操作,仍然诡异,留待大神研究吧~)以下直接说重点
报错的原因:
vagrant的源码使用Ruby实现的,Ruby 转码的方法:encode 有转码兼容,GBK转码为UTF-8不兼容,所以报错,报错行的源代码:
data << io.readpartial(READ_CHUNK_SIZE).encode(“UTF-8”, Encoding.default_external)
解决方法:
思路:将参数用 force_encoding方法 强制转换成UTF-8编码即可
方法:找到报错的目录:C:\HashiCorp\Vagrant\embedded\gems\gems\vagrant-1.7.2\lib\vagrant\util io.rb文件找到line 32,将代码修改为:
data << io.readpartial(READ_CHUNK_SIZE).force_encoding(‘UTF-8’)
然后vagrant reload 没有报错,重启成功,代码同步成功。这是vagrant的一个bug。
说说这里面的曲折过程,最开始发现这个错误以后,我将错误提示:”from GBK to UTF-8”理解成:
要转码为UTF-8必须要求原编码是GBK,所以我改了io.rb中出错的源码成这个样子:
str = io.readpartial(READ_CHUNK_SIZE).force_encoding(‘GBK’) //强制转换为GBK
data << str .encode(“UTF-8”, Encoding.default_external) //将GBK转换为UTF-8
这样还是报错,然后我看到转码的encode有编码兼容,所以使用强制转换的方式转换为UTF-8,果然还是简单粗暴比较好呀~~
附上一句:解决了这个问题我好开心呀,离大神又进了一步~~