配置项描述
Agent配置文件的描述文件结构定义。
每一个Agent项目中的conf目录下必须包含一个manifest.yaml文件用于描述该Agent的配置项信息,该文件被用于外部工具做自动化部署时的展示。
该文件的内容最顶层为一个数组,其中每一个元素代表配置文件中的某一个字段,该字段的描述信息如下:
key: 该字段在配置文件中的名称name.zh: 该字段的中文名称,用于自动化部署工具的展示desc.zh: 该字段的中文描述type: 该字段类型,目前已支持以下类型string: 字符串enum: 枚举值csv: 逗号分隔的字符串,允许多个值int: 有符号整数uint: 无符号整数float: 浮点数bool: 布尔值naddr: 网络地址,<ip>:<port>path: 文件路径bytes: 可视化字节数,(n)G、(n)M、(n)KB、(n)B等duration: 时长,(n)h、(n)m、(n)s等uuid: 唯一标识ID
required: 是否必填default: (可选)默认值enum_valid: (可选)enum字段允许输入的内容csv_valid: (可选)csv字段允许输入的内容str_valid: (可选)string类型的匹配正则表达式min: (可选)最小值,支持的数据类型int、uint、float、bytes、durationmax: (可选)最大值,支持的数据类型int、uint、float、bytes、durationlen: (可选)最大长度,支持的数据类型string、csv、pathallow_relative: (可选)是否允许使用相对路径,支持的数据类型pathcategory: (可选)配置项分类
示例
- key: basic.id
type: string
name:
zh: AgentID
desc:
zh: Agent的ID,在当前服务器下的集群内唯一
required: true
- key: basic.server
type: naddr
name:
zh: 服务端地址
desc:
zh: 链接服务器端的地址
default: 127.0.0.1:13081
required: true
- key: basic.log.target
type: csv
name:
zh: 日志保存目标
desc:
zh: 日志保存目标,目前仅支持stdout和文件
default: stdout
csv_valid: [ stdout, file ]
required: false
- key: basic.log.dir
type: path
name:
zh: 日志保存路径
desc:
zh: 日志保存路径
default: ./logs
required: false
- key: basic.log.size
type: bytes
name:
zh: 日志文件滚动大小
desc:
zh: 日志文件生成时每个文件的大小
default: 10M
min: 1M
max: 100M
required: false
- key: basic.log.rotate
type: uint
name:
zh: 日志文件保留份数
desc:
zh: 日志文件生成时最多保留份数
default: 7
min: 1
max: 100
required: false
关联关系
示例1
log.target = stdout,file
log.dir = ./logs
log.size = 10M
log.rotate = 7
当log.target字段未设置file属性时,log.dir、log.size、log.rotate配置项是无效的。
示例2
monitor.enabled = true
monitor.interval = 10s
当monitor.enabled字段设置为false时,monitor.interval配置项是无效的。
基于以上两种情况,增加配置字段如下:
- key: basic.log.dir
...
enabled:
when:
target: basic.log.target
contain: file
- key: basic.monitor.interval
...
enabled:
when:
target: basic.monitor.enabled
equal: true
enabled字段用于表示当前字段的有效范围when字段表示当条件中的描述符合要求时该字段有效target: 该字段表示需要关联到的原始字段名称contain: 针对于原始字段为csv类型时csv内容中包含该配置项时当前字段才有效equal: 针对于原始字段为bool或数值类型时原始字段的值与要求内容相符时才有效