当前位置: 代码迷 >> Ruby/Rails >> vagrant rsync-auto 代码同步失败出错:UndefinedConversionError
  详细解决方案

vagrant rsync-auto 代码同步失败出错:UndefinedConversionError

热度:206   发布时间:2016-04-29 02:16:04.0
vagrant rsync-auto 代码同步失败报错:UndefinedConversionError

今天使用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,果然还是简单粗暴比较好呀~~
附上一句:解决了这个问题我好开心呀,离大神又进了一步~~

  相关解决方案