每次请求都会去从新加载配置文件。即便配置文件内容没有更新, 也会去从新加载一次。这是一个很很差的设计。(开启Opcache状况下, 仍是有执行的过程时间)php
读取到配置文件的内容保存到系统内存, 下一次请求直接去内存读取数据。Asf 也提供很是简单的配置实现 Config Cache。redis
<?php ini_set('asf.cache_config_enable', 1); /* 开启配置文件缓存 */ ini_set('asf.cache_config_expire', 300); /* 设置缓存多少秒以后过时, 300 seconds by default */
<?php define('APP_PATH', dirname(__DIR__)); /* 缓存 config.ini 文件 */ $app = new Asf\Application(APP_PATH . '/config/config.ini'); $app->run();
<?php $conf_php = new Asf\Config\Php(CONFIG_PATH . '/config.db.php');
<?php $conf_ini = new Asf\Config\Ini(CONFIG_PATH . '/config.redis.ini');
<?php print_r(Asf\Application::getInstance()->getConfig()->toArray()); print_r(Asf\Config::get()->toArray());
在开启 Opcache 状况下, 简单作了一个 Config Cache 性能测试, ab -c100 -n10000缓存
配置文件中配置项复杂程度与性能指标是有直线联系的哟多线程
Total transferred: 16109994 bytes HTML transferred: 14259994 bytes Requests per second: 6859.01 [#/sec] (mean) Time per request: 14.579 [ms] (mean) Time per request: 0.146 [ms] (mean, across all concurrent requests)
Total transferred: 16080000 bytes HTML transferred: 14230000 bytes Requests per second: 6398.22 [#/sec] (mean) Time per request: 15.629 [ms] (mean) Time per request: 0.156 [ms] (mean, across all concurrent requests)
Cache Config 不是基于共享内存的, 是基于 PHP 进程的哟, 不会有共享内存锁的问题。app