The open and composable observability and data visualization platform. Visualize metrics, logs, and traces from multiple sources like Prometheus, Loki, Elasticsearch, InfluxDB, Postgres and many more.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
grafana/docs/sources/developers/plugins/introduction-to-plugin-deve.../backend/plugin-protocol.md

2.8 KiB

aliases description keywords labels title
[../../plugins/backend/plugin-protocol/] Learn about the Grafana wire protocol used for communication between the Grafana server and backend plugins. [grafana plugins backend plugin backend-plugins documentation] [{products [enterprise oss]}] Plugin protocol

Plugin protocol

The Grafana server uses a physical wire protocol to communicate with backend plugins. This protocol establishes a contract between Grafana and backend plugins to allow them to communicate with each other.

Developing with the plugin protocol

{{% admonition type="caution" %}} We strongly recommend that backend plugin development not be implemented directly against the protocol. Instead, we prefer that you use the [Grafana Plugin SDK for Go]({{< relref "./grafana-plugin-sdk-for-go" >}}) that implements this protocol and provides higher-level APIs. {{% /admonition %}}

If you choose to develop against the plugin protocol directly, you can do so using Protocol Buffers (that is, protobufs) with gRPC.

Grafana's plugin protocol protobufs are available in the GitHub repository.

{{% admonition type="note" %}} The plugin protocol lives in the [Grafana Plugin SDK for Go]({{< relref "./grafana-plugin-sdk-for-go.md" >}}) because Grafana itself uses parts of the SDK as a dependency. {{% /admonition %}}

Versioning

From time to time, Grafana will offer additions of services, messages, and fields in the latest version of the plugin protocol. We don't expect these updates to introduce any breaking changes. However, if we must introduce breaking changes to the plugin protocol, we'll create a new major version of the plugin protocol.

Grafana will release new major versions of the plugin protocol alongside new major Grafana releases. When this happens, we'll support both the old and the new plugin protocol for some time to make sure existing backend plugins continue to work.

The plugin protocol attempts to follow Grafana's versioning. However, that doesn't mean we will automatically create a new major version of the plugin protocol when a new major release of Grafana is released.

Writing plugins without Go

If you want to write a backend plugin in a language other than Go, then it's possible as long as the language supports gRPC. However, we recommend that you develop your plugin in Go for several reasons:

  • We offer an official plugin SDK.
  • The compiled output is a single binary.
  • Writing for multiple platforms is easy. Typically, no additional dependencies must be installed on the target platform.
  • Small footprint for binary size.
  • Small footprint for resource usage.