OpenStack的oslo项目旨在独立出系统中可重用的基础功能,oslo.config就是其中一个被普遍使用的库,该项工做的主要目的就是解析OpenStack中命令行(CLI)或配置文件(.conf)中的配置信息。api
在本文的语境下,有这么几个概念:工具
配置文件: spa
用来配置OpenStack各个服务的ini风格的配置文件,一般以.conf结尾;命令行
配置项(options): code
配置文件或命令行中给出的配置信息的左值, 如:enabled_apis = ec2, osapi_keystone, osapi_compute中的“enabled_apis”;对象
配置项的值: utf-8
配置文件或命令行中给出的配置信息的右值,如:enabled_apis = ec2, osapi_keystone, osapi_compute中的“ec2, osapi_keystone, osapi_compute”;ssl
配置组(option groups): ci
一组配置项,在配置文件中经过[...]来表示,如my.conf文件中的[rabbit]字段表示接下来开始一个名为rabbit的配置组;it
其余模块:
运行时须要根据配置项的值实现具体操做的模块;
配置项的模式(option schemas):
在解析配置文件、获取配置项的值以前,其余模块声明本身须要的配置项。配置文件一般是针对一个完整的服务的,所以其余模块中可能用不到配置 文件中的全部配置项,这样就必须告诉系统本身依赖于哪些配置项,这个过程就是设置配置项的模式。包括声明配置项在配置文件的名称、设置配置项的默认值(一 旦配置文件中没有该配置项而其余模块又依赖于该配置项,就使用这里声明的默认值)等等;
引用(reference):
其余模块解析配置文件,获取配置项的值后,就能够在下面的实现中使用这些具体的配置值了;
注册(register):
其余模块在引用配置项的值以前,必须注册本身将要引用的那些配置项的模式。也就是说,配置文件中的配置项其余模块不必定都为其声明模式,声明了模式的配置项也不必定为其进行注册,固然若是不注册,即便声明了模式,也没法引用。
下面先给一个high-level的过程说明一下如何使用这个库,OpenStack中配置文件的解析主要有如下几个步骤:
step1. 正确配置各个服务主配置文件(*.conf文件),本步骤在各个服务(如:keystone)中完成。
step2. 在要使用到配置信息的模块中声明将用到的那些配置项的模式,包括配置项的名称、数据类型、默认值和说明等;
step3. 建立一个对象,建立该对象的类充当配置管理器,这个对象做为容器之后将存储配置项的值。
step4. 调用step3建立的对象中相应的注册方法(如:register_opt()),注册step2中声明的配置项模式。这个过程不会解析配置文件,只是为step3中建立的对象开辟相应的字段。
step5. 直接调用step3中建立的对象,传入配置文件路径等信息。此时将会解析配置文件,若是未指定配置文件则所有使用step2模式中的默认值。解析过程会提 取step4中注册了的配置项的值,而后这些配置项就做为step3建立的对象的属性能够被直接引用。
一个完整的实例以下:
咱们使用my.conf来存放全部的配置信息,使用config.py来表示一个依赖于my.conf中配置信息的模其余模块。
先设置my.conf文件,在oslo.config语境下,[DEFAULT]字段不可省略。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
接着写一个脚本文件config.py,该脚本的功能很是简单,直接执行时打印该脚本使用到的配置项的值。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 |
|
执行config.py,结果以下:
1 2 3 4 5 6 7 8 |
|
下面的config_test.py不指定配置文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
执行config_test.py比较结果差异:
1 2 3 4 5 6 7 |
|
能够发现,执行config.py时,成功读取了配置项的值,而执行config_test.py时,因为没有指定要解析的配置文件,因此使用的都是设置模式时指定的默认值。
OpenStack的oslo.config项目提供了一种开放的配置项解析工具,能够在其上实现本身须要的命令行和配置文件解析工具,也能够直接应用到本身的项目中,本文对于oslo.config项目的使用方法就介绍到这里。