配置

安装

配置文件结构

以下结构仅为 Hyperf-Skeleton 所提供的默认配置的情况下的结构,实际情况由于依赖或使用的组件的差异,文件会有差异。

  1. config
  2. ├── autoload // 此文件夹内的配置文件会被配置组件自己加载,并以文件夹内的文件名作为第一个键值
  3. ├── amqp.php // 用于管理 AMQP 组件
  4. ├── annotations.php // 用于管理注解
  5. ├── apollo.php // 用于管理基于 Apollo 实现的配置中心
  6. ├── aspects.php // 用于管理 AOP 切面
  7. ├── async_queue.php // 用于管理基于 Redis 实现的简易队列服务
  8. ├── commands.php // 用于管理自定义命令
  9. ├── consul.php // 用于管理 Consul 客户端
  10. ├── databases.php // 用于管理数据库客户端
  11. ├── devtool.php // 用于管理开发者工具
  12. ├── exceptions.php // 用于管理异常处理器
  13. ├── listeners.php // 用于管理事件监听者
  14. ├── logger.php // 用于管理日志
  15. ├── middlewares.php // 用于管理中间件
  16. ├── opentracing.php // 用于管理调用链追踪
  17. ├── processes.php // 用于管理自定义进程
  18. ├── redis.php // 用于管理 Redis 客户端
  19. └── server.php // 用于管理 Server 服务
  20. ├── config.php // 用于管理用户或框架的配置,如配置相对独立亦可放于 autoload 文件夹内
  21. ├── container.php // 负责容器的初始化,作为一个配置文件运行并最终返回一个 Psr\Container\ContainerInterface 对象
  22. ├── dependencies.php // 用于管理 DI 的依赖关系和类对应关系
  23. └── routes.php // 用于管理路由

config.phpautoload 文件夹内的配置文件在服务启动时都会被扫描并注入到 Hyperf\Contract\ConfigInterface 对应的对象中,配置的结构为一个键值对的大数组,两种配置形式不同的在于 autoload 内配置文件的文件名会作为第一层 键(Key) 存在,而 config.php 内的则以您定义的为第一层,我们通过下面的例子来演示一下。我们假设存在一个 config/autoload/client.php 文件,文件内容如下:

  1. 'request' => [
  2. 'timeout' => 10,
  3. ],
  4. ];

那么我们想要得到 timeout 的值对应的 键(Key) 为 client.request.timeout

我们假设想要以相同的 键(Key) 获得同样的结果,但配置是写在 config/config.php 文件内的,那么文件内容应如下:

该组件是官方提供的默认的配置组件,是面向 Hyperf\Contract\ConfigInterface 接口实现的,由 hyperf/config 组件内的 ConfigProviderHyperf\Config\Config 对象绑定到接口上。

Config 组件提供了三种方式获取配置,通过 Hyperf\Config\Config 对象获取、通过 @Value 注解获取和通过 config(string $key, $default) 函数获取。

通过 Config 对象获取配置

这种方式要求你已经拿到了 Config 对象的实例,默认对象为 Hyperf\Config\Config,注入实例的细节可查阅 依赖注入 章节;

  1. * @var \Hyperf\Contract\ConfigInterface
  2. */
  3. // 通过 get(string $key, $default): mixed 方法获取 $key 所对应的配置,$key 值可以通过 . 连接符定位到下级数组,$default 则是当对应的值不存在时返回的默认值
  4. $config->get($key$default);

通过 @Value 注解获取配置

这种方式要求注解的应用对象必须是通过 hyperf/di 组件创建的,注入实例的细节可查阅 章节,示例中我们假设 IndexController 就是一个已经定义好的 Controller 类,Controller 类一定是由 DI 容器创建出来的;@Value() 内的字符串则对应到 内的 $key 参数,在创建该对象实例时,对应的配置会自动注入到定义的类属性中。

  1. class IndexController
  2. {
  3. /**
  4. * @Value("config.key")
  5. */
  6. private $configValue;
  7. public function index()
  8. {
  9. return $this->configValue;
  10. }
  11. }

通过 config 函数获取

在任意地方可以通过 config(string $key, $default) 函数获取对应的配置,但这样的使用方式也就意味着您对 和 hyperf/utils 组件是强依赖的。

对于不同的运行环境使用不同的配置是一种常见的需求,比如在测试环境和生产环境的 Redis 配置不一样,而生产环境的配置又不能提交到源代码版本管理系统中以免信息泄露。

在新安装好的 Hyperf 应用中,其根目录会包含一个 .env.example 文件。如果是通过 Composer 安装的 Hyperf,该文件会自动基于 .env.example 复制一个新文件并命名为 .env。否则,需要你手动更改一下文件名。

您的 .env 文件不应该提交到应用的源代码版本管理系统中,因为每个使用你的应用的开发人员 / 服务器可能需要有一个不同的环境配置。此外,在入侵者获得你的源代码仓库的访问权的情况下,这会导致严重的安全问题,因为所以敏感的数据都被一览无余了。

.env 文件中的所有变量都会被解析为字符串类型,因此提供了一些保留值以允许您从 env() 函数中获取更多类型的变量:

如果你需要使用包含空格的环境变量,可以通过将值括在双引号中来实现,比如:

  1. APP_NAME="Hyperf Skeleton"
  1. // config/config.php
  2. return [
  3. ];

Hyperf 为您提供了分布式系统的外部化配置支持,默认且仅适配了由携程开源的 ,由 hyper/config-apollo 组件提供功能支持。关于配置中心的使用细节我们由 章节来阐述。