PHP Yaconf 一个高性能的配置管理扩展(PHP7)

时间:2023-02-22 10:01:33


Yaconf 是一个高性能的配置管理扩展,是由PHP核心开发者鸟哥惠新宸发布的 PHP7 下的扩展应用。主要目标是简化读取项目配置文件, 使配置文件和项目代码分离,增强了配置文件的可读性和可维护性。

据 Yaconf 开发者惠新宸在其博客上说,这个项目是其在来微博以后, 第一个优化项目中顺手做的一个小工具, 本身叫做Weibo_Conf. 但是因为 Weibo_Conf 是属于 Weibo 扩展的, 里面还有一些其他功能是专门为 Weibo 定制的. 所以不适合直接开源.随着 PHP7 的发布, 新增了很多持久化类型的支持比如 IS_IMMUTABLE_ARRAY , 于是就在 PHP7 下重新开发了 Yaconf , 开源出来, 方便大家使用。

鸟哥已经将其放在GitHub上:​​https://github.com/laruence/yaconf​​​​原始doc​

首先说说, 这个是干啥的:

  1. 我见过很多的项目中, 用 PHP 文件做配置的, 一个 config 目录下可能有十几个甚至数十个 .php 配置文件, 里面都是各种各样的 array , 还有甚者会把一些词典文件(比如中文/英文对照)也放到配置中去. 这就导致配置文件的解析耗费了很大的性能(诚然, 用了 opcache 能好点, 但是实际上还是有执行的过程).
  2. 除了 PHP 的, 还有用 json 的, yaml 的, 一个共同的特点就是这些配置的可读性比较差. 另外, 他们也都要 runtime 解析.
  3. config 目录往往和代码在一起, 首先会有安全隐患(配置中往往有敏感信息), 其次如果配置和代码属于一个项目, 这就会导致配置的修改也要走代码上线的流程.
  4. 一些资源配置文件, 比如 mysql/memcache 的配置信息, 这些内容本来是应该对开发透明的, 运维直接负责即可. 但是放到了代码中就会导致, 运维如果要发起一些变更, 也要开发配合修改配置文件上线.

所以, Yaconf就是为了解决这些问题而生的一个工具.

  1. 它使用单独的一个配置目录(在 yaconf.directory 指定), 不和代码在一起.
  2. 它在 PHP 启动的时候, 处理所有的要处理的配置, 然后这些配置就会常驻内存, 随着 PHP 的生命周期存亡. 避免了每次请求的时候解析配置文件.
  3. 所有的配置内容都是 immutable 的, 这就可以借助于 Fork 的 COW , 降低内存占用, 并且在访问配置的时候, 几乎不需要任何的内存 Copy, 也不会有无谓的引用计数增减
  4. 最重要的, 配置目录和代码分离以后, 可以借助一个配置管理后台, 来实现配置的统一化管理.
  5. 它支持(对于非ZTS)配置变更重新加载, 也就是说配置如果有变化(建议更改配置一定使用 mv , 不要使用 cp ), 它会 reload, 不需要重启(检测的频率由 yaconf.check_delay 控制).
  6. 它支持丰富的配置类型, 包括​​字符串, 数组, 分节, 分节继承​​, 并且还可以在配置中直接写 PHP 的常量和环境变量等.
  7. 最重要的是, 它很简单.

引用据 Yaconf 开发者惠新宸在其博客上说的
​​​PHP 7.3.X 编译报错,下载 github 的 master最新代码,重新编译安装即可​