什么是ThinkSNS ?
ThinkSNS(简称TS),一款全平台综合性社交系统,为国内外大中小企业和创业者提供社会化软件研发及技术解决方案。
1.png
这是 https://github.com/overtrue/pinyin 首页 README 中的持续集成状态。
之前有朋友问我,这个 travis 状态时 error 能用么?肯定是能用,我们来看下 travis 上什么地方错误了:
2.png
已经显示出来了,其中单元测试失败的是 php 5.5 和 php 5.6 我们随便点击一个进去看看
3.png
超过 10m 没有收到输出,所以 travis 认为构建是有问题的。其实吧~确实有问题,个人也苦恼了很久,没有收到输出的构建是 tests/GeneratorFileDictLoaderTest.php 这个测试类测试的是 Overtrue/Pinyin/GeneratorFileDictLoader 这个加载器。
解释下这个加载器,因为拼音库是基于词库的,而词库非常大,在很多场景下内存中是不允许载入这么多的数据的。所以这个加载器利用 php5.5+ 的 Generator (生成器)特性来生成数据,而生成数据的代价就是需要大量的磁盘 IO 以及增加 >90% 的允许时间。(PHP 官方文档中有说明)。
travis 认为构建失败原因:这个问题本身可能存在于 PHP 5.5 & 5.6 的文件系统(看 PHP 改动日志是有改动的)造成了假死,再加上 travis 本身 IO 能力比较低。所以造成生成器同时打开多个文件流之后就假死了。
如何修复
额~我是来搞笑的。。。。并不知道如何解决构建失败的问题,这个问题我曾经 fork 超哥的库该代码,也并没有找到好的解决方法。
可能删除这种「生成器」加载器会好吧
其实我特地发这篇文章,是想让超哥看到,研究下怎么让构建跑通
往期研发日记传送门:
《ThinkSNS+基于 Laravel master 分支【研发日记一】》
《ThinkSNS+研发中前端的抉择(webpack/Vue)踩坑日记【研发日记二】》
《基于 Laravel Route 的 ThinkSNS+ Component【研发日记三】》
《如何做到 Laravel 配置可以网站后台配置【研发日记四】》
《ThinkSNS+ 如何计算字符显示长度【研发日记五】》
《基于 Laravel 的 ThinkSNS+ alpha.2 版本发布【研发日记六】》
《聊聊 Laravel 5.5 的 「自动发现」和此刻心情【研发日记七】》
《继:我朝特有需求之–英文字符占 0.5 个,中文字符占 1 个【研发日记八】》
《利用 Docker 包 Laradock 服务器部署 Laravel & ThinkSNS+ 等程序实战(多项目)【研发日记九】》
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/opensource/192214.html