使用环境变量
编辑使用环境变量
编辑概述
编辑- 您可以通过使用
${var}
在 Logstash 插件的配置中设置环境变量引用。 - 在 Logstash 启动时,每个引用都会被替换为环境变量的值。
- 替换区分大小写。
- 引用未定义变量会引发 Logstash 配置错误。
- 您可以使用
${var:默认值}
的形式给出默认值。如果环境变量未定义,Logstash 将使用默认值。 - 您可以在任何插件选项类型中添加环境变量引用:字符串、数字、布尔值、数组或哈希。
- 列表类型的 URI 参数的环境变量可以支持以空格分隔的值列表。目前,其他非 URI 的选项不支持值列表。请参阅 跨插件概念和功能
- 环境变量是不可变的。如果您更新了环境变量,您必须重新启动 Logstash 才能获取更新后的值。
示例
编辑以下示例向您展示如何使用环境变量来设置一些常用配置选项的值。
设置 TCP 端口
编辑以下示例使用环境变量来设置 TCP 端口
input { tcp { port => "${TCP_PORT}" } }
现在,让我们设置 TCP_PORT
的值
export TCP_PORT=12345
在启动时,Logstash 使用此配置
input { tcp { port => 12345 } }
如果未设置 TCP_PORT
环境变量,Logstash 将返回配置错误。
您可以通过指定默认值来解决此问题
input { tcp { port => "${TCP_PORT:54321}" } }
现在,如果变量未定义,Logstash 将使用默认值,而不是返回配置错误。
input { tcp { port => 54321 } }
如果定义了环境变量,Logstash 将使用为该变量指定的值,而不是默认值。
设置标签的值
编辑以下示例使用环境变量来设置标签的值
filter { mutate { add_tag => [ "tag1", "${ENV_TAG}" ] } }
让我们设置 ENV_TAG
的值
export ENV_TAG="tag2"
在启动时,Logstash 使用此配置
filter { mutate { add_tag => [ "tag1", "tag2" ] } }
设置文件路径
编辑以下示例使用环境变量来设置日志文件的路径
filter { mutate { add_field => { "my_path" => "${HOME}/file.log" } } }
让我们设置 HOME
的值
export HOME="/path"
在启动时,Logstash 使用以下配置
filter { mutate { add_field => { "my_path" => "/path/file.log" } } }