Golang 输出插件

Fluent Bit 当前仅支持将 Golang 插件集成为仅用于输出插件的共享库。Golang 插件的接口目前正在开发中,但可以使用。

Fluent Bit当前仅支持将 Golang 插件集成为仅用于输出插件的共享库。Golang 插件的接口目前正在开发中,但可以使用。

Getting Started

启用 Golang 支持选项编译 Fluent Bit,如:

$ cd build/
$ cmake -DFLB_DEBUG=On -DFLB_PROXY_GO=On ../
$ make

编译后,我们可以在二进制中看到新选项 -e,它代表扩展插件,例如:

$ bin/fluent-bit -h
Usage: fluent-bit [OPTION]

Available Options
  -c  --config=FILE    specify an optional configuration file, 指定可选的配置文件
  -d, --daemon        run Fluent Bit in background mode, 以后台方式运行 Fluent Bit
  -f, --flush=SECONDS    flush timeout in seconds (default: 5), 刷新数据到输出的超时时间(默认 5 秒)
  -i, --input=INPUT    set an input, 设置输入
  -m, --match=MATCH    set plugin match, same as '-p match=abc', 设置插件匹配的标签模式,与 '-p match=abc' 相同
  -o, --output=OUTPUT    set an output, 设置输出
  -p, --prop="A=B"    set plugin configuration property, 设置插件配置参数
  -e, --plugin=FILE    load an external plugin (shared lib), 加载扩展插件(共享库)
  ...

Build a Go Plugin

fluent-bit-go 软件包可用于帮助开发人员创建 Go 插件

https://github.com/fluent/fluent-bit-go

作为最小形式,Go 插件至少如下所示:

上面的代码是编写输出插件的模板,将包名称设置为 main 并添加显式的 main() 函数非常重要。这是必需的,因为代码将被构建为共享库。

要构建上面的代码,请使用以下命令行:

构建完成后,共享库 out_gstdout.so 将可被使用。仔细检查最终的 .so 文件确实是我们所期望的,这非常重要。对库执行 ldd 命令,我们应该看到类似于如下的内容:

Run Fluent Bit with the new plugin

Last updated

Was this helpful?