读了一遍yaconf的源码,发现大部分可以理解。在这个项目上结合现实中使用的两个场景进行进行一些小改动是个比较有趣的事情。
创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、成都网站制作、盐边网络推广、小程序开发、盐边网络营销、盐边企业策划、盐边品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供盐边建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com
代码地址:https://github.com/netbird/yaconf
业务场景一
在自己的测试环境,各个业务方要求某个业务的api必须长期指向他们的测试环境供他们测试。之前做法有修改host(碰到非80端口失灵),修改代码,修改配置文件。而这套环境又有新的开发任务,需要随时更新代码和配置文件,不更新会导致其他业务失败,所以不能加锁。经常造成代码和配置覆盖。不得不重新修改配置文件和代码满足之前的测试环境。。。
因代码配置文件基于yaconf的。所以修改了下yaconf的源码,提供了一种小方案。
在不修改配置文件和主项目代码的情况下。
增加测试模式和测试配置文件目录。
在yaconf设置成测试模式下,在directory_test添加自己需要满足测试需要的配置文件(可以是局部内容)。
在读取配置的时候 就优先读取测试内容,然后在读取通用配置。
例如:
配置文件:
a.ini的内容
a="b"
b="c"
此时读取Yaconf::get(‘a.a’) 得到的是b。
设置测试模式,里面测试配置:
a.ini
a="d"
此时读取Yaconf::get('a.a') 得到的是d。
当然,整体读取Yaconf::get('a'),会导致读取不到a.b的内容,具体依据自己使用的场景。
PS:仅在测试环境下当作练习使用,不适用所有场景。
业务场景二
如何在CLI模式下使用Yaconf
虽然Yaconf更适合web请求场景,不太适合在CLI模式下使用,但是受限与环境, 历史(业务难分离)等问题,又急切想使用Yaconf怎么办?
Yaconf的原理是在PHP_MINIT_FUNCTION函数里面初始化配置,然后在PHP_RINIT_FUNCTION函数里面根据条件更新配置。这样当一个web请求时,会触发PHP_RINIT_FUNCTION这个函数,从而自动根据条件更新配置。
而CLI模式模式下,如果进程不退出,那么只在启动的时候执行一次PHP_MINIT_FUNCTION和PHP_RINIT_FUNCTION,此时无法更新配置信息。
解决方案:
增加外部触发函数,手动执行更新。即:增加Yaconf::update()方法,在代码中,适合的位置去执行这个函数,触发更新。
当然,更新的原则和原理还是跟PHP_RINIT_FUNCTION一样。
如配置文件:
a.ini
a="b"
代码:
while(true) {
Yaconf::update();
var_dump(Yaconf::get('a.a'));
}
此时,如果将配置文件改成:
a="c"
则上述程序会在check_delay(通常5分钟)后,输出c(不用退出进程,即可更新).
目前,还没有投入正式环境。如果大家有这个使用场景,可以考虑以上方式。
ps: 1. 限于本人能力,仅仅包了个接口,没有对内部进行合并逻辑处理,重在解决问题。
2. 条条大道通罗马,如果可能,大家也可以使用别的更好的方式。解决问题的方法不唯一。
因能力有限,内部解析代码没有做改动。
名称栏目:为Yaconf的添加测试场景(练习用)
链接分享:http://scpingwu.com/article/jsossg.html