External plugins are external programs that are built outside
of Telegraf that can run through an execd
plugin. These external plugins allow for
more flexibility compared to internal Telegraf plugins.
- External plugins can be written in any language (internal Telegraf plugins can only written in Go)
- External plugins can access to libraries not written in Go
- Utilize licensed software that isn't available to the open source community
- Can include large dependencies that would otherwise bloat Telegraf
- You don't need to wait on the Telegraf team to publish your plugin and start working with it.
- using the shim you can easily convert plugins between internal and external use
The guidelines of writing external plugins would follow those for our general input, output, processor, and aggregator plugins. Please reference the documentation on how to create these plugins written in Go.
For listed external plugins, the author of the external plugin is also responsible for the maintenance and feature development of external plugins. Expect to have users open plugin issues on its respective GitHub repository.
For Go plugins, there is a Execd Go Shim that will make it trivial to extract an internal input, processor, or output plugin from the main Telegraf repo out to a stand-alone repo. This shim allows anyone to build and run it as a separate app using one of the execd
plugins:
Follow the Steps to externalize a plugin and Steps to build and run your plugin to properly with the Execd Go Shim
This is a guide to help you set up your plugin to use it with execd
- Write your Telegraf plugin. Depending on the plugin, follow the guidelines on how to create the plugin itself using InfluxData's best practices:
- If your plugin is written in Go, include the steps for the Execd Go Shim
- Move the project to an external repo, it's recommended to preserve the path
structure, (but not strictly necessary). eg if your plugin was at
plugins/inputs/cpu
, it's recommended that it also be underplugins/inputs/cpu
in the new repo. For a further example of what this might look like, take a look at ssoroka/rand or danielnelson/telegraf-execd-openvpn - Copy main.go into your project under the
cmd
folder. This will be the entrypoint to the plugin when run as a stand-alone program, and it will call the shim code for you to make that happen. It's recommended to have only one plugin per repo, as the shim is not designed to run multiple plugins at the same time (it would vastly complicate things). - Edit the main.go file to import your plugin. Within Telegraf this would have
been done in an all.go file, but here we don't split the two apart, and the change
just goes in the top of main.go. If you skip this step, your plugin will do nothing.
eg:
_ "github.com/me/my-plugin-telegraf/plugins/inputs/cpu"
- Optionally add a plugin.conf for configuration specific to your plugin. Note that this config file must be separate from the rest of the config for Telegraf, and must not be in a shared directory where Telegraf is expecting to load all configs. If Telegraf reads this config file it will not know which plugin it relates to. Telegraf instead uses an execd config block to look for this plugin.
- Add usage and development instructions in the homepage of your repository for running
your plugin with its respective
execd
plugin. Please refer to openvpn and awsalarms for examples. Include the following steps:- How to download the release package for your platform or how to clone the binary for your external plugin
- The commands to build your binary
- Location to edit your
telegraf.conf
- Configuration to run your external plugin with inputs.execd, processors.execd or outputs.execd
- Submit your plugin by opening a PR to add your external plugin to the /EXTERNAL_PLUGINS.md list. Please include the plugin name, link to the plugin repository and a short description of the plugin.