<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Grafana Enterprise on Grafana Labs</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/</link><description>Recent content in Grafana Enterprise on Grafana Labs</description><generator>Hugo -- gohugo.io</generator><language>en</language><atom:link href="/docs/grafana/v9.0/enterprise/index.xml" rel="self" type="application/rss+xml"/><item><title>Usage insights</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/usage-insights/</link><pubDate>Fri, 07 Mar 2025 11:34:44 +0100</pubDate><guid>https://grafana.com/docs/grafana/v9.0/enterprise/usage-insights/</guid><content><![CDATA[&lt;h1 id=&#34;usage-insights&#34;&gt;Usage insights&lt;/h1&gt;
&lt;p&gt;Usage insights allow you to have a better understanding of how your Grafana instance is used.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;The usage insights feature collects a number of aggregated data and stores them in the database:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Dashboard views (aggregated and per user)&lt;/li&gt;
&lt;li&gt;Data source errors&lt;/li&gt;
&lt;li&gt;Data source queries&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;These aggregated data give you access to several features:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href=&#34;dashboard-datasource-insights/&#34;&gt;Dashboard and data source insights&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href=&#34;presence-indicator/&#34;&gt;Presence indicator&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href=&#34;improved-search/&#34;&gt;Sort dashboards by using insights data&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;This feature also generates detailed logs that can be exported to Loki. Refer to &lt;a href=&#34;../../setup-grafana/configure-security/export-logs/&#34;&gt;Export logs of usage insights&lt;/a&gt;.&lt;/p&gt;
]]></content><description>&lt;h1 id="usage-insights">Usage insights&lt;/h1>
&lt;p>Usage insights allow you to have a better understanding of how your Grafana instance is used.&lt;/p>
&lt;blockquote>
&lt;p>&lt;strong>Note:&lt;/strong> Available in &lt;a href="../">Grafana Enterprise&lt;/a> and &lt;a href="/docs/grafana-cloud/">Grafana Cloud Pro and Advanced&lt;/a>.&lt;/p></description></item><item><title>Query caching</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/query-caching/</link><pubDate>Fri, 07 Mar 2025 11:34:44 +0100</pubDate><guid>https://grafana.com/docs/grafana/v9.0/enterprise/query-caching/</guid><content><![CDATA[&lt;h1 id=&#34;query-caching&#34;&gt;Query caching&lt;/h1&gt;
&lt;p&gt;When query caching is enabled, Grafana temporarily stores the results of data source queries. When you or another user submit the exact same query again, the results will come back from the cache instead of from the data source (like Splunk or ServiceNow) itself.&lt;/p&gt;
&lt;p&gt;Query caching works for all backend data sources. You can enable the cache globally and configure the cache duration (also called Time to Live, or TTL).&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;The following cache backends are available: in-memory, Redis, and Memcached.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Storing cached queries in-memory can increase Grafana&amp;rsquo;s memory footprint. In production environments, a Redis or Memcached backend is highly recommended.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;When a panel queries a cached data source, the time until this query fetches fresh data is determined by the panel&amp;rsquo;s &lt;strong&gt;interval.&lt;/strong&gt; This means that wider panels and dashboards with shorter time ranges fetch new data more frequently than narrower panels and dashboards with longer time ranges.&lt;/p&gt;
&lt;p&gt;Interval is visible in a panel&amp;rsquo;s &lt;a href=&#34;../../panels/query-options/&#34;&gt;query options&lt;/a&gt;. It is calculated like this: &lt;code&gt;(max data points) / time range&lt;/code&gt;. Max data points are calculated based on the width of the panel. For example, a full-width panel on a dashboard with a time range of &lt;code&gt;last 7 days&lt;/code&gt; will retrieve fresh data every 10 minutes. In this example, cached data for this panel will be served for up to 10 minutes before Grafana queries the data source again and returns new data.&lt;/p&gt;
&lt;p&gt;You can make a panel retrieve fresh data more frequently by increasing the &lt;strong&gt;Max data points&lt;/strong&gt; setting in the panel&amp;rsquo;s &lt;a href=&#34;../../panels/query-options/&#34;&gt;query options&lt;/a&gt;.&lt;/p&gt;
&lt;h2 id=&#34;query-caching-benefits&#34;&gt;Query caching benefits&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;Faster dashboard load times, especially for popular dashboards.&lt;/li&gt;
&lt;li&gt;Reduced API costs.&lt;/li&gt;
&lt;li&gt;Reduced likelihood that APIs will rate-limit or throttle requests.&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;data-sources-that-work-with-query-caching&#34;&gt;Data sources that work with query caching&lt;/h2&gt;
&lt;p&gt;Query caching works for all &lt;a href=&#34;/grafana/plugins/?type=datasource&amp;amp;enterprise=1&#34;&gt;Enterprise data sources&lt;/a&gt; as well as the following &lt;a href=&#34;../../datasources/&#34;&gt;built-in data sources&lt;/a&gt;:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;CloudWatch Metrics&lt;/li&gt;
&lt;li&gt;Google Cloud Monitoring&lt;/li&gt;
&lt;li&gt;InfluxDB&lt;/li&gt;
&lt;li&gt;Microsoft SQL Server&lt;/li&gt;
&lt;li&gt;MySQL&lt;/li&gt;
&lt;li&gt;Postgres&lt;/li&gt;
&lt;li&gt;Tempo&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Some data sources, such as Elasticsearch, Prometheus, and Loki, cache queries themselves, so Grafana query caching does not improve performance.&lt;/p&gt;
&lt;p&gt;Query caching also works for all data sources that include a backend. More specifically, caching works with data sources that extend the &lt;code&gt;DataSourceWithBackend&lt;/code&gt; class in the plugins SDK.&lt;/p&gt;
&lt;p&gt;To tell if a data source works with query caching, follow the instructions below to &lt;strong&gt;Enable and Configure query caching&lt;/strong&gt;. If caching is enabled in Grafana but the Caching tab is not visible for the given data source, then query caching is not available for that data source.&lt;/p&gt;
&lt;h2 id=&#34;enable-and-configure-query-caching&#34;&gt;Enable and configure query caching&lt;/h2&gt;
&lt;p&gt;You must be an Org admin or Grafana admin to enable query caching for a data source. For more information on Grafana roles and permissions, refer to &lt;a href=&#34;../../administration/roles-and-permissions/&#34;&gt;About users and permissions&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;By default, data source queries are not cached. To enable query caching for a single data source:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;On the side menu, click Configuration &amp;gt; Data Sources.&lt;/li&gt;
&lt;li&gt;In the data source list, click the data source that you want to turn on caching for.&lt;/li&gt;
&lt;li&gt;Open the Cache tab.&lt;/li&gt;
&lt;li&gt;Press the Enable button.&lt;/li&gt;
&lt;li&gt;(Optional) Choose custom TTLs for the data source&amp;rsquo;s queries and resources caching. If you skip this step, then Grafana uses the default TTL.&lt;/li&gt;
&lt;/ol&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; If query caching is enabled and the Cache tab is not visible in a data source&amp;rsquo;s settings, then query caching is not available for that data source.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;To configure global settings for query caching, refer to the &lt;a href=&#34;../../setup-grafana/configure-grafana/enterprise-configuration/#caching&#34;&gt;Query caching section of Enterprise Configuration&lt;/a&gt;.&lt;/p&gt;
&lt;h2 id=&#34;disable-query-caching&#34;&gt;Disable query caching&lt;/h2&gt;
&lt;p&gt;To disable query caching for a single data source:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;On the side menu, click Configuration &amp;gt; Data Sources.&lt;/li&gt;
&lt;li&gt;In the data source list, click the data source that you want to turn off caching for.&lt;/li&gt;
&lt;li&gt;In the Cache tab, click Disable.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;To disable query caching for an entire Grafana instance, set the &lt;code&gt;enabled&lt;/code&gt; flag to &lt;code&gt;false&lt;/code&gt; in the &lt;a href=&#34;../../setup-grafana/configure-grafana/enterprise-configuration/#caching&#34;&gt;Query caching section of Enterprise Configuration&lt;/a&gt;. You will no longer see the Cache tab on any data sources, and no data source queries will be cached.&lt;/p&gt;
&lt;h2 id=&#34;clear-cache&#34;&gt;Clear cache&lt;/h2&gt;
&lt;p&gt;If you experience performance issues or repeated queries become slower to execute, consider clearing your cache.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; This action impacts all cache-enabled data sources. If you are using Memcached, the system clears all data from the Memcached instance.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;&lt;strong&gt;To clear the cache&lt;/strong&gt;:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Sign in to Grafana and click &lt;strong&gt;Settings &amp;gt; Data Sources&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;Select a data source.&lt;/li&gt;
&lt;li&gt;Click the &lt;strong&gt;Cache&lt;/strong&gt; tab.&lt;/li&gt;
&lt;li&gt;Click &lt;strong&gt;Clear cache&lt;/strong&gt;.&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id=&#34;sending-a-request-without-cache&#34;&gt;Sending a request without cache&lt;/h2&gt;
&lt;p&gt;If a data source query request contains an &lt;code&gt;X-Cache-Skip&lt;/code&gt; header, then Grafana skips the caching middleware, and does not search the cache for a response. This can be particularly useful when debugging data source queries using cURL.&lt;/p&gt;
]]></content><description>&lt;h1 id="query-caching">Query caching&lt;/h1>
&lt;p>When query caching is enabled, Grafana temporarily stores the results of data source queries. When you or another user submit the exact same query again, the results will come back from the cache instead of from the data source (like Splunk or ServiceNow) itself.&lt;/p></description></item><item><title>Recorded queries</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/recorded-queries/</link><pubDate>Fri, 07 Mar 2025 11:34:44 +0100</pubDate><guid>https://grafana.com/docs/grafana/v9.0/enterprise/recorded-queries/</guid><content><![CDATA[&lt;h1 id=&#34;recorded-queries&#34;&gt;Recorded queries&lt;/h1&gt;
&lt;p&gt;Recorded queries allow you to see trends over time by taking a snapshot of a data point on a set interval. This can give you insight into historic trends.&lt;/p&gt;
&lt;p&gt;For our plugins that do not return time series, it might be useful to plot historical data. For example, you might want to query ServiceNow to see a history of request response times but it can only return current point-in-time metrics.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;h2 id=&#34;how-recorded-queries-work&#34;&gt;How recorded queries work&lt;/h2&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; An administrator must configure a Prometheus data source and associate it with a &lt;a href=&#34;#remote-write-target&#34;&gt;Remote write target&lt;/a&gt; before recorded queries can be used.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;Recorded queries only work with backend data source plugins. Refer to &lt;a href=&#34;/tutorials/build-a-data-source-backend-plugin/&#34;&gt;Backend data source plugin&lt;/a&gt; for more information about backend data source plugins. You can recorded three types of queries:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;single row and column - A query that returns a single row and column.&lt;/li&gt;
&lt;li&gt;row count - A query that returns meaningful rows to be counted.&lt;/li&gt;
&lt;li&gt;expression - Any expression. To learn more about creating and using expressions, see &lt;a href=&#34;/docs/grafana/latest/panels/expressions/&#34;&gt;Expressions&lt;/a&gt;.&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;After a recorded query is created or enabled, it immediately creates a snapshot and continues to create snapshots at the set interval. The recorded query stops taking snapshots when it is disabled, deleted, or when Grafana is not running. Data points are gathered in the backend by running the recorded query and forwarding each result to a remote-write enabled Prometheus instance.&lt;/p&gt;
&lt;h2 id=&#34;using-a-recorded-query&#34;&gt;Using a recorded query&lt;/h2&gt;
&lt;p&gt;To use a recorded query, create one and add it to a dashboard. After that, it can be managed in &lt;strong&gt;Preferences&lt;/strong&gt; from the &lt;strong&gt;Recorded queries&lt;/strong&gt; tab.&lt;/p&gt;
&lt;h3 id=&#34;create-a-recorded-query&#34;&gt;Create a recorded query&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;Find/create a query you want to record on a dashboard in an edit panel. The query must only return one row and column. If it returns more, you can still record the number of results returned using the “count” option.
&lt;ul&gt;
&lt;li&gt;The query&amp;rsquo;s data source must be a backend data source.&lt;/li&gt;
&lt;li&gt;Expressions can be used to aggregate data from a time series query. Refer to &lt;a href=&#34;/docs/grafana/latest/panels/expressions/&#34;&gt;Expressions&lt;/a&gt; to learn more about creating and using expressions.&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Click the record query button located in the top right of the query editor.&lt;/li&gt;
&lt;li&gt;Enter recorded query information. All fields are required unless otherwise indicated.
&lt;ul&gt;
&lt;li&gt;Name - Name of the recorded query.&lt;/li&gt;
&lt;li&gt;Description - (optional) Describe the recorded query as you want it to appear in the recorded query list.&lt;/li&gt;
&lt;li&gt;Interval - The interval on which the snapshot will be taken. The interval starts when you create the recorded query and will stop if you pause or delete the recorded query. Refer to &lt;a href=&#34;#manage-recorded-queries&#34;&gt;Managing recorded queries&lt;/a&gt; for more information on pausing and deleting recorded queries.&lt;/li&gt;
&lt;li&gt;Range - The relative time range of the query. If you select a range of &lt;code&gt;30m&lt;/code&gt; and an interval of &lt;code&gt;1h&lt;/code&gt; the query will take a snapshot every hour of the past 30 minutes.&lt;/li&gt;
&lt;li&gt;Count query results - If you want to count the rows returned from your query toggle this option on. If this option is off, your query must return one row with one value.&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Test your recorded query by clicking the test recorded query button.&lt;/li&gt;
&lt;li&gt;Click &lt;code&gt;Start recording query&lt;/code&gt; to start recording your query.&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;add-a-recorded-query&#34;&gt;Add a recorded query&lt;/h3&gt;
&lt;p&gt;You can add existing recorded queries to panels in a dashboard. For each recorded query that you add, a Prometheus query is created: &lt;code&gt;generated_recorded_query_name{id=&amp;quot;generated_id&amp;quot;, name=&amp;quot;recorded query name&amp;quot;}&lt;/code&gt;. The created query from Prometheus returns all the recorded query’s gathered snapshots.&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Navigate to a panel in a dashboard where you wish to add a recorded query.&lt;/li&gt;
&lt;li&gt;Click the &lt;code&gt;&#43; Recorded query&lt;/code&gt; button located below the queries.&lt;/li&gt;
&lt;li&gt;If you want to filter recorded queries by data source, select a data source from the filter by data source drop down menu.&lt;/li&gt;
&lt;li&gt;Click the &lt;code&gt;Add&lt;/code&gt; button on your recorded query to add it to the panel.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;After adding your recorded query to the panel, the panel data source will become &lt;code&gt;-- Mixed --&lt;/code&gt;. Your recorded query is represented by a &lt;code&gt;Prometheus&lt;/code&gt; query with a name label matching your recorded query name. Refer to &lt;a href=&#34;/docs/grafana/latest/datasources/prometheus/&#34;&gt;Prometheus&lt;/a&gt; to learn more about the &lt;code&gt;Prometheus&lt;/code&gt; data source.&lt;/p&gt;
&lt;p&gt;If after adding a recorded query, a query with a &lt;code&gt;-- Mixed --&lt;/code&gt; data source instead of &lt;code&gt;Prometheus&lt;/code&gt; data source appears, this could mean that a Prometheus remote write target was not set up for recorded queries. Refer to &lt;a href=&#34;#remote-write-target&#34;&gt;Remote write target&lt;/a&gt; to set up a remote write point.&lt;/p&gt;
&lt;h3 id=&#34;manage-recorded-queries&#34;&gt;Manage recorded queries&lt;/h3&gt;
&lt;p&gt;Recorded queries can be paused/activated and deleted from the Recorded queries tab in Preferences. Deleting a recorded query will remove it from Grafana, but the information that was gathered in Prometheus will still be there. Pausing a recorded query will no longer gather new data points until it is resumed.&lt;/p&gt;
&lt;h3 id=&#34;remote-write-target&#34;&gt;Remote write target&lt;/h3&gt;
&lt;p&gt;The remote write target is the Prometheus data source that recorded query data points are written to. You will need a Prometheus with remote write enabled and you will need to create a data source for this Prometheus.&lt;/p&gt;
&lt;p&gt;The remote write target can be edited by clicking &lt;code&gt;Edit Remote Write Target&lt;/code&gt; in the upper right on the Recorded Queries tab in Preferences. Select the Prometheus data source that has remote write enabled and enter the remote write path.&lt;/p&gt;
]]></content><description>&lt;h1 id="recorded-queries">Recorded queries&lt;/h1>
&lt;p>Recorded queries allow you to see trends over time by taking a snapshot of a data point on a set interval. This can give you insight into historic trends.&lt;/p></description></item><item><title>Settings updates at runtime</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/settings-updates/</link><pubDate>Fri, 07 Mar 2025 11:34:44 +0100</pubDate><guid>https://grafana.com/docs/grafana/v9.0/enterprise/settings-updates/</guid><content><![CDATA[&lt;h1 id=&#34;settings-updates-at-runtime&#34;&gt;Settings updates at runtime&lt;/h1&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in Grafana Enterprise version 8.0 and later.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;By updating settings at runtime, you can update Grafana settings without needing to restart the Grafana server.&lt;/p&gt;
&lt;p&gt;Updates that happen at runtime are stored in the database and override
&lt;a href=&#34;../../setup-grafana/configure-grafana/&#34;&gt;settings from the other sources&lt;/a&gt;
(arguments, environment variables, settings file, etc). Therefore, every time a specific setting key is removed at runtime,
the value used for that key is the inherited one from the other sources in the reverse order of precedence
(&lt;code&gt;arguments &amp;gt; environment variables &amp;gt; settings file&lt;/code&gt;), being the application default the value used when no one provided
through one of these, at least.&lt;/p&gt;
&lt;p&gt;Currently, &lt;strong&gt;it only supports updates on the &lt;code&gt;auth.saml&lt;/code&gt; section.&lt;/strong&gt;&lt;/p&gt;
&lt;h2 id=&#34;update-settings-via-the-api&#34;&gt;Update settings via the API&lt;/h2&gt;
&lt;p&gt;You can update settings through the &lt;a href=&#34;../../developers/http_api/admin/#update-settings&#34;&gt;Admin API&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;When you submit a settings update via API, Grafana verifies if the given settings updates are allowed and valid. If they are, then Grafana stores the settings in the database and reloads
Grafana services with no need to restart the instance.&lt;/p&gt;
&lt;p&gt;So, the payload of a &lt;code&gt;PUT&lt;/code&gt; request to the update settings endpoint (&lt;code&gt;/api/admin/settings&lt;/code&gt;)
should contain (either one or both):&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;An &lt;code&gt;updates&lt;/code&gt; map with a key, and a value per section you want to set.&lt;/li&gt;
&lt;li&gt;A &lt;code&gt;removals&lt;/code&gt; list with keys per section you want to unset.&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;For example, if you provide the following &lt;code&gt;updates&lt;/code&gt;:&lt;/p&gt;

&lt;div class=&#34;code-snippet &#34;&gt;&lt;div class=&#34;lang-toolbar&#34;&gt;
    &lt;span class=&#34;lang-toolbar__item lang-toolbar__item-active&#34;&gt;JSON&lt;/span&gt;
    &lt;span class=&#34;code-clipboard&#34;&gt;
      &lt;button x-data=&#34;app_code_snippet()&#34; x-init=&#34;init()&#34; @click=&#34;copy()&#34;&gt;
        &lt;img class=&#34;code-clipboard__icon&#34; src=&#34;/media/images/icons/icon-copy-small-2.svg&#34; alt=&#34;Copy code to clipboard&#34; width=&#34;14&#34; height=&#34;13&#34;&gt;
        &lt;span&gt;Copy&lt;/span&gt;
      &lt;/button&gt;
    &lt;/span&gt;
    &lt;div class=&#34;lang-toolbar__border&#34;&gt;&lt;/div&gt;
  &lt;/div&gt;&lt;div class=&#34;code-snippet &#34;&gt;
    &lt;pre data-expanded=&#34;false&#34;&gt;&lt;code class=&#34;language-json&#34;&gt;{
  &amp;#34;updates&amp;#34;: {
    &amp;#34;auth.saml&amp;#34;: {
      &amp;#34;enabled&amp;#34;: &amp;#34;true&amp;#34;,
      &amp;#34;single_logout&amp;#34;: &amp;#34;false&amp;#34;
    }
  }
}&lt;/code&gt;&lt;/pre&gt;
  &lt;/div&gt;
&lt;/div&gt;
&lt;p&gt;it would enable SAML and disable single logouts. And, if you provide the following &lt;code&gt;removals&lt;/code&gt;:&lt;/p&gt;

&lt;div class=&#34;code-snippet &#34;&gt;&lt;div class=&#34;lang-toolbar&#34;&gt;
    &lt;span class=&#34;lang-toolbar__item lang-toolbar__item-active&#34;&gt;JSON&lt;/span&gt;
    &lt;span class=&#34;code-clipboard&#34;&gt;
      &lt;button x-data=&#34;app_code_snippet()&#34; x-init=&#34;init()&#34; @click=&#34;copy()&#34;&gt;
        &lt;img class=&#34;code-clipboard__icon&#34; src=&#34;/media/images/icons/icon-copy-small-2.svg&#34; alt=&#34;Copy code to clipboard&#34; width=&#34;14&#34; height=&#34;13&#34;&gt;
        &lt;span&gt;Copy&lt;/span&gt;
      &lt;/button&gt;
    &lt;/span&gt;
    &lt;div class=&#34;lang-toolbar__border&#34;&gt;&lt;/div&gt;
  &lt;/div&gt;&lt;div class=&#34;code-snippet &#34;&gt;
    &lt;pre data-expanded=&#34;false&#34;&gt;&lt;code class=&#34;language-json&#34;&gt;{
  &amp;#34;auth.saml&amp;#34;: [&amp;#34;allow_idp_initiated&amp;#34;]
}&lt;/code&gt;&lt;/pre&gt;
  &lt;/div&gt;
&lt;/div&gt;
&lt;p&gt;it would remove the key/value setting identified by &lt;code&gt;allow_idp_initiated&lt;/code&gt; within the &lt;code&gt;auth.saml&lt;/code&gt;.
So, the SAML service would be reloaded and that value would be inherited for either (settings &lt;code&gt;.ini&lt;/code&gt; file,
environment variable, command line arguments or any other accepted mechanism to provide configuration).&lt;/p&gt;
&lt;p&gt;Therefore, the complete HTTP payload would looks like:&lt;/p&gt;

&lt;div class=&#34;code-snippet &#34;&gt;&lt;div class=&#34;lang-toolbar&#34;&gt;
    &lt;span class=&#34;lang-toolbar__item lang-toolbar__item-active&#34;&gt;JSON&lt;/span&gt;
    &lt;span class=&#34;code-clipboard&#34;&gt;
      &lt;button x-data=&#34;app_code_snippet()&#34; x-init=&#34;init()&#34; @click=&#34;copy()&#34;&gt;
        &lt;img class=&#34;code-clipboard__icon&#34; src=&#34;/media/images/icons/icon-copy-small-2.svg&#34; alt=&#34;Copy code to clipboard&#34; width=&#34;14&#34; height=&#34;13&#34;&gt;
        &lt;span&gt;Copy&lt;/span&gt;
      &lt;/button&gt;
    &lt;/span&gt;
    &lt;div class=&#34;lang-toolbar__border&#34;&gt;&lt;/div&gt;
  &lt;/div&gt;&lt;div class=&#34;code-snippet &#34;&gt;
    &lt;pre data-expanded=&#34;false&#34;&gt;&lt;code class=&#34;language-json&#34;&gt;{
  &amp;#34;updates&amp;#34;: {
    &amp;#34;auth.saml&amp;#34;: {
      &amp;#34;enabled&amp;#34;: &amp;#34;true&amp;#34;,
      &amp;#34;single_logout&amp;#34;: &amp;#34;false&amp;#34;
    }
  },
  &amp;#34;removals&amp;#34;: {
    &amp;#34;auth.saml&amp;#34;: [&amp;#34;allow_idp_initiated&amp;#34;]
  }
}&lt;/code&gt;&lt;/pre&gt;
  &lt;/div&gt;
&lt;/div&gt;
&lt;p&gt;In case any of these settings cannot be overridden nor valid, it would return an error and these settings
won&amp;rsquo;t be persisted into the database.&lt;/p&gt;
&lt;h2 id=&#34;background-job-high-availability-set-ups&#34;&gt;Background job (high availability set-ups)&lt;/h2&gt;
&lt;p&gt;Grafana Enterprise has a built-in scheduled background job that looks into the database every minute for
settings updates. If there are updates, it reloads the Grafana services affected by the detected changes.&lt;/p&gt;
&lt;p&gt;The background job synchronizes settings between instances in high availability set-ups. So, after you perform some changes through the
HTTP API, then the other instances are synchronized through the database and the background job.&lt;/p&gt;
&lt;h2 id=&#34;control-access-with-role-based-access-control&#34;&gt;Control access with role-based access control&lt;/h2&gt;
&lt;p&gt;If you have &lt;a href=&#34;../../administration/roles-and-permissions/access-control/&#34;&gt;role-based access control&lt;/a&gt; enabled, you can control who can read or update settings.
Refer to the &lt;a href=&#34;../../developers/http_api/admin/#update-settings&#34;&gt;Admin API&lt;/a&gt; for more information.&lt;/p&gt;
]]></content><description>&lt;h1 id="settings-updates-at-runtime">Settings updates at runtime&lt;/h1>
&lt;blockquote>
&lt;p>&lt;strong>Note:&lt;/strong> Available in Grafana Enterprise version 8.0 and later.&lt;/p>&lt;/blockquote>
&lt;p>By updating settings at runtime, you can update Grafana settings without needing to restart the Grafana server.&lt;/p></description></item><item><title>Reporting</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/reporting/</link><pubDate>Fri, 07 Mar 2025 11:34:44 +0100</pubDate><guid>https://grafana.com/docs/grafana/v9.0/enterprise/reporting/</guid><content><![CDATA[&lt;h1 id=&#34;reporting&#34;&gt;Reporting&lt;/h1&gt;
&lt;p&gt;Reporting allows you to automatically generate PDFs from any of your dashboards and have Grafana email them to interested parties on a schedule. This is available in Grafana Cloud Pro and Advanced and in Grafana Enterprise.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;If you have &lt;a href=&#34;../../administration/roles-and-permissions/access-control/&#34;&gt;Role-based access control&lt;/a&gt; enabled, for some actions you would need to have relevant permissions.
Refer to specific guides to understand what permissions are required.&lt;/p&gt;&lt;/blockquote&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_list_8.1.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_list_8.1.png&#34;alt=&#34;&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_list_8.1.png&#34;
            alt=&#34;&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;p&gt;Any changes you make to a dashboard used in a report are reflected the next time the report is sent. For example, if you change the time range in the dashboard, then the time range in the report changes as well.&lt;/p&gt;
&lt;h2 id=&#34;requirements&#34;&gt;Requirements&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;SMTP must be configured for reports to be sent. Refer to &lt;a href=&#34;../../setup-grafana/configure-grafana/#smtp&#34;&gt;SMTP&lt;/a&gt; in &lt;a href=&#34;../../setup-grafana/configure-grafana/&#34;&gt;Configuration&lt;/a&gt; for more information.&lt;/li&gt;
&lt;li&gt;The Image Renderer plugin must be installed or the remote rendering service must be set up. Refer to &lt;a href=&#34;../../setup-grafana/image-rendering/&#34;&gt;Image rendering&lt;/a&gt; for more information.&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;access-control&#34;&gt;Access control&lt;/h2&gt;
&lt;p&gt;When &lt;a href=&#34;../../administration/roles-and-permissions/access-control/&#34;&gt;RBAC&lt;/a&gt; is enabled, you need to have the relevant &lt;a href=&#34;../../administration/roles-and-permissions/access-control/rbac-fixed-basic-role-definitions/&#34;&gt;Permissions&lt;/a&gt; to create and manage reports.&lt;/p&gt;
&lt;h2 id=&#34;create-or-update-a-report&#34;&gt;Create or update a report&lt;/h2&gt;
&lt;p&gt;Only organization admins can create reports by default. You can customize who can create reports with &lt;a href=&#34;../../administration/roles-and-permissions/access-control/&#34;&gt;Role-based access control&lt;/a&gt;.&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Click on the Reports icon in the side navigation menu.
The Reports tab allows you to view, create, and update your reports. The report form has a multi-step layout. The steps do not need to be completed in succession and can be skipped over by clicking a step name.&lt;/li&gt;
&lt;li&gt;Select report dashboard.
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Source dashboard -&lt;/strong&gt; Select the dashboard to generate the report from.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Time range -&lt;/strong&gt; (optional) Use custom time range for the report. For more information, refer to &lt;a href=&#34;#report-time-range&#34;&gt;Report time range&lt;/a&gt;.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Add another dashboard -&lt;/strong&gt; Add more than one dashboard to the report.&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Format report.
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Choose format options for the report -&lt;/strong&gt; Select at least one option. Attach report as PDF, embed dashboard as an image, or attach CSV file of table panel data.&lt;/li&gt;
&lt;li&gt;If you selected the PDF format option:
&lt;ul&gt;
&lt;li&gt;Select an orientation for the report: &lt;strong&gt;Portrait&lt;/strong&gt; or &lt;strong&gt;Landscape&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;Select a layout for the generated report: &lt;strong&gt;Simple&lt;/strong&gt; or &lt;strong&gt;Grid&lt;/strong&gt;. The simple layout renders each panel as full-width across the PDF. The grid layout renders the PDF with the same panel arrangement and width as the source dashboard.&lt;/li&gt;
&lt;li&gt;Click &lt;strong&gt;Preview PDF&lt;/strong&gt; to view a rendered PDF with the options you selected.&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Schedule report.
&lt;ul&gt;
&lt;li&gt;Enter scheduling information. Options vary depending on the frequency selected.&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Enter report information. All fields are required unless otherwise indicated.
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Report name -&lt;/strong&gt; Name of the report as you want it to appear in the Reports list. It&amp;rsquo;s also used as the email subject.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Recipients -&lt;/strong&gt; Enter the emails of the people or teams that you want to receive the report, separated by commas or semicolons.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Reply to -&lt;/strong&gt; (optional) The address that will appear in the &lt;strong&gt;Reply to&lt;/strong&gt; field of the email.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Message -&lt;/strong&gt; (optional) Message body in the email with the report.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Include a dashboard link -&lt;/strong&gt; Include a link to the dashboard from within the report email.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Send test email&lt;/strong&gt; to verify that the whole configuration is working as expected. You can choose to send this email to the recipients configured for the report, or to a different set of email addresses only used for testing.&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Preview and save the report.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports/select-dashboard.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports/select-dashboard.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports/select-dashboard.png?w=320 320w, /static/img/docs/enterprise/reports/select-dashboard.png?w=550 550w, /static/img/docs/enterprise/reports/select-dashboard.png?w=750 750w, /static/img/docs/enterprise/reports/select-dashboard.png?w=900 900w, /static/img/docs/enterprise/reports/select-dashboard.png?w=1040 1040w, /static/img/docs/enterprise/reports/select-dashboard.png?w=1240 1240w, /static/img/docs/enterprise/reports/select-dashboard.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1280&#34;height=&#34;1204&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports/select-dashboard.png&#34;
            alt=&#34;&#34;width=&#34;1280&#34;height=&#34;1204&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports/format-report.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports/format-report.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports/format-report.png?w=320 320w, /static/img/docs/enterprise/reports/format-report.png?w=550 550w, /static/img/docs/enterprise/reports/format-report.png?w=750 750w, /static/img/docs/enterprise/reports/format-report.png?w=900 900w, /static/img/docs/enterprise/reports/format-report.png?w=1040 1040w, /static/img/docs/enterprise/reports/format-report.png?w=1240 1240w, /static/img/docs/enterprise/reports/format-report.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;886&#34;height=&#34;1192&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports/format-report.png&#34;
            alt=&#34;&#34;width=&#34;886&#34;height=&#34;1192&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports/schedule.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports/schedule.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports/schedule.png?w=320 320w, /static/img/docs/enterprise/reports/schedule.png?w=550 550w, /static/img/docs/enterprise/reports/schedule.png?w=750 750w, /static/img/docs/enterprise/reports/schedule.png?w=900 900w, /static/img/docs/enterprise/reports/schedule.png?w=1040 1040w, /static/img/docs/enterprise/reports/schedule.png?w=1240 1240w, /static/img/docs/enterprise/reports/schedule.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1168&#34;height=&#34;1195&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports/schedule.png&#34;
            alt=&#34;&#34;width=&#34;1168&#34;height=&#34;1195&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports/share.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports/share.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports/share.png?w=320 320w, /static/img/docs/enterprise/reports/share.png?w=550 550w, /static/img/docs/enterprise/reports/share.png?w=750 750w, /static/img/docs/enterprise/reports/share.png?w=900 900w, /static/img/docs/enterprise/reports/share.png?w=1040 1040w, /static/img/docs/enterprise/reports/share.png?w=1240 1240w, /static/img/docs/enterprise/reports/share.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1292&#34;height=&#34;1191&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports/share.png&#34;
            alt=&#34;&#34;width=&#34;1292&#34;height=&#34;1191&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports/confirm.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports/confirm.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports/confirm.png?w=320 320w, /static/img/docs/enterprise/reports/confirm.png?w=550 550w, /static/img/docs/enterprise/reports/confirm.png?w=750 750w, /static/img/docs/enterprise/reports/confirm.png?w=900 900w, /static/img/docs/enterprise/reports/confirm.png?w=1040 1040w, /static/img/docs/enterprise/reports/confirm.png?w=1240 1240w, /static/img/docs/enterprise/reports/confirm.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1272&#34;height=&#34;1279&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports/confirm.png&#34;
            alt=&#34;&#34;width=&#34;1272&#34;height=&#34;1279&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h3 id=&#34;choose-template-variables&#34;&gt;Choose template variables&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 7.5 and later behind the &lt;code&gt;reportVariables&lt;/code&gt; feature flag, Grafana Enterprise version 8.0 and later without a feature flag, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can configure report-specific template variables for the dashboard on the report page. The variables that you select will override the variables from the dashboard, and they are used when rendering a PDF file of the report. For detailed information about using template variables, refer to the &lt;a href=&#34;../../variables/&#34;&gt;Templates and variables&lt;/a&gt; section.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; The query variables saved with a report might go out of date if the results of that query change. For example, if your template variable queries for a list of hostnames and a new hostname is added, then it will not be included in the report. If that happens, the selected variables will need to be manually updated in the report. If you select the &lt;code&gt;All&lt;/code&gt; value for the template variable or if you keep the dashboard&amp;rsquo;s original variable selection, then the report will stay up-to-date as new values are added.&lt;/p&gt;&lt;/blockquote&gt;
&lt;h3 id=&#34;render-a-report-with-panels-or-rows-set-to-repeat-by-a-variable&#34;&gt;Render a report with panels or rows set to repeat by a variable&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 8.0 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can include dynamic dashboards with panels or rows, set to repeat by a variable, into reports. For detailed information about setting up repeating panels or rows in dashboards, refer to the &lt;a href=&#34;../../panels/configure-panel-options/#configure-repeating-rows-or-panels&#34;&gt;Repeat panels or rows&lt;/a&gt; section.&lt;/p&gt;
&lt;h4 id=&#34;caveats&#34;&gt;Caveats:&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;Rendering repeating panels for dynamic variable types (e.g. &lt;code&gt;query&lt;/code&gt; variables) with selected &lt;code&gt;All&lt;/code&gt; value is currently not supported. As a workaround, it is possible to individually select all the values instead.&lt;/li&gt;
&lt;li&gt;If you select different template variables in a report for a dashboard with repeating rows, you might see empty space or missing values at the bottom of the report. This is because the dimensions of the panels from the dashboard are used to generate the report. To avoid this issue, use the dashboard&amp;rsquo;s original template variables for the report, or make a copy of the dashboard, select the new set of template variables, and generate a report based on the copied dashboard.&lt;/li&gt;
&lt;li&gt;Rendering of the repeating panels inside collapsed rows in reports is not supported.&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;report-time-range&#34;&gt;Report time range&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; You can set custom report time ranges in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; 7.2&#43; and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;By default, reports use the saved time range of the dashboard. Changing the time range of the report can be done by:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Saving a modified time range to the dashboard.&lt;/li&gt;
&lt;li&gt;Setting a time range via &lt;strong&gt;Time range&lt;/strong&gt; field in the report form. If specified, then this custom time range overrides the one from the report&amp;rsquo;s dashboard.&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;The page header of the report displays the time range for the dashboard&amp;rsquo;s data queries. Dashboards set to use the browser&amp;rsquo;s time zone will use the time zone on the Grafana server.&lt;/p&gt;
&lt;p&gt;If the time zone is set differently between your Grafana server and its remote image renderer, then the time ranges in the report might be different between the page header and the time axes in the panels. To avoid this, set the time zone to UTC for dashboards when using a remote renderer. Each dashboard&amp;rsquo;s time zone setting is visible in the &lt;a href=&#34;../../dashboards/time-range-controls/#dashboard-time-settings&#34;&gt;time range controls&lt;/a&gt;.&lt;/p&gt;
&lt;h3 id=&#34;layout-and-orientation&#34;&gt;Layout and orientation&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;We&amp;rsquo;re actively developing new report layout options. &lt;a href=&#34;/contact?about=grafana-enterprise&amp;amp;topic=design-process&amp;amp;value=reporting&#34;&gt;Contact us&lt;/a&gt; to get involved in the design process.&lt;/p&gt;&lt;/blockquote&gt;
&lt;section class=&#34;expand-table-wrapper&#34;&gt;&lt;div class=&#34;button-div&#34;&gt;
      &lt;button class=&#34;expand-table-btn&#34;&gt;Expand table&lt;/button&gt;
    &lt;/div&gt;&lt;div class=&#34;responsive-table-wrapper&#34;&gt;
    &lt;table&gt;
      &lt;thead&gt;
          &lt;tr&gt;
              &lt;th&gt;Layout&lt;/th&gt;
              &lt;th&gt;Orientation&lt;/th&gt;
              &lt;th&gt;Support&lt;/th&gt;
              &lt;th&gt;Description&lt;/th&gt;
              &lt;th&gt;Preview&lt;/th&gt;
          &lt;/tr&gt;
      &lt;/thead&gt;
      &lt;tbody&gt;
          &lt;tr&gt;
              &lt;td&gt;Simple&lt;/td&gt;
              &lt;td&gt;Portrait&lt;/td&gt;
              &lt;td&gt;v6.4&#43;&lt;/td&gt;
              &lt;td&gt;Generates an A4 page in portrait mode with three panels per page.&lt;/td&gt;
              &lt;td&gt;&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_portrait_preview.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_portrait_preview.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_portrait_preview.png?w=320 320w, /static/img/docs/enterprise/reports_portrait_preview.png?w=550 550w, /static/img/docs/enterprise/reports_portrait_preview.png?w=750 750w, /static/img/docs/enterprise/reports_portrait_preview.png?w=900 900w, /static/img/docs/enterprise/reports_portrait_preview.png?w=1040 1040w, /static/img/docs/enterprise/reports_portrait_preview.png?w=1240 1240w, /static/img/docs/enterprise/reports_portrait_preview.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;595&#34;height=&#34;841&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_portrait_preview.png&#34;
            alt=&#34;&#34;width=&#34;595&#34;height=&#34;841&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;&lt;/td&gt;
          &lt;/tr&gt;
          &lt;tr&gt;
              &lt;td&gt;Simple&lt;/td&gt;
              &lt;td&gt;Landscape&lt;/td&gt;
              &lt;td&gt;v6.7&#43;&lt;/td&gt;
              &lt;td&gt;Generates an A4 page in landscape mode with a single panel per page.&lt;/td&gt;
              &lt;td&gt;&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_landscape_preview.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_landscape_preview.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_landscape_preview.png?w=320 320w, /static/img/docs/enterprise/reports_landscape_preview.png?w=550 550w, /static/img/docs/enterprise/reports_landscape_preview.png?w=750 750w, /static/img/docs/enterprise/reports_landscape_preview.png?w=900 900w, /static/img/docs/enterprise/reports_landscape_preview.png?w=1040 1040w, /static/img/docs/enterprise/reports_landscape_preview.png?w=1240 1240w, /static/img/docs/enterprise/reports_landscape_preview.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;841&#34;height=&#34;595&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_landscape_preview.png&#34;
            alt=&#34;&#34;width=&#34;841&#34;height=&#34;595&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;&lt;/td&gt;
          &lt;/tr&gt;
          &lt;tr&gt;
              &lt;td&gt;Grid&lt;/td&gt;
              &lt;td&gt;Portrait&lt;/td&gt;
              &lt;td&gt;v7.2&#43;&lt;/td&gt;
              &lt;td&gt;Generates an A4 page in portrait mode with panels arranged in the same way as at the original dashboard.&lt;/td&gt;
              &lt;td&gt;&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_grid_portrait_preview.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_grid_portrait_preview.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_grid_portrait_preview.png?w=320 320w, /static/img/docs/enterprise/reports_grid_portrait_preview.png?w=550 550w, /static/img/docs/enterprise/reports_grid_portrait_preview.png?w=750 750w, /static/img/docs/enterprise/reports_grid_portrait_preview.png?w=900 900w, /static/img/docs/enterprise/reports_grid_portrait_preview.png?w=1040 1040w, /static/img/docs/enterprise/reports_grid_portrait_preview.png?w=1240 1240w, /static/img/docs/enterprise/reports_grid_portrait_preview.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;943&#34;height=&#34;1335&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_grid_portrait_preview.png&#34;
            alt=&#34;&#34;width=&#34;943&#34;height=&#34;1335&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;&lt;/td&gt;
          &lt;/tr&gt;
          &lt;tr&gt;
              &lt;td&gt;Grid&lt;/td&gt;
              &lt;td&gt;Landscape&lt;/td&gt;
              &lt;td&gt;v7.2&#43;&lt;/td&gt;
              &lt;td&gt;Generates an A4 page in landscape mode with panels arranged in the same way as at the original dashboard.&lt;/td&gt;
              &lt;td&gt;&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_grid_landscape_preview.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_grid_landscape_preview.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_grid_landscape_preview.png?w=320 320w, /static/img/docs/enterprise/reports_grid_landscape_preview.png?w=550 550w, /static/img/docs/enterprise/reports_grid_landscape_preview.png?w=750 750w, /static/img/docs/enterprise/reports_grid_landscape_preview.png?w=900 900w, /static/img/docs/enterprise/reports_grid_landscape_preview.png?w=1040 1040w, /static/img/docs/enterprise/reports_grid_landscape_preview.png?w=1240 1240w, /static/img/docs/enterprise/reports_grid_landscape_preview.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1397&#34;height=&#34;987&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_grid_landscape_preview.png&#34;
            alt=&#34;&#34;width=&#34;1397&#34;height=&#34;987&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;&lt;/td&gt;
          &lt;/tr&gt;
      &lt;/tbody&gt;
    &lt;/table&gt;
  &lt;/div&gt;
&lt;/section&gt;&lt;h3 id=&#34;csv-export&#34;&gt;CSV export&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; 8&#43; with the &lt;a href=&#34;/grafana/plugins/grafana-image-renderer&#34;&gt;Grafana image renderer plugin&lt;/a&gt; v3.0&#43;, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can attach a CSV file to the report email for each table panel on the selected dashboard, along with the PDF report. By default, CSVs larger than 10Mb won&amp;rsquo;t be sent to avoid email servers to reject the email. You can increase or decrease this limit in the &lt;a href=&#34;#rendering-configuration&#34;&gt;reporting configuration&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;This feature relies on the same plugin that supports the &lt;a href=&#34;../../setup-grafana/image-rendering/&#34;&gt;image rendering&lt;/a&gt; features.&lt;/p&gt;
&lt;p&gt;When the CSV file is generated, it is temporarily written to the &lt;code&gt;csv&lt;/code&gt; folder in the Grafana &lt;code&gt;data&lt;/code&gt; folder.&lt;/p&gt;
&lt;p&gt;A background job runs every 10 minutes and removes temporary CSV files. You can configure how long a CSV file should be stored before being removed by configuring the &lt;a href=&#34;../../setup-grafana/configure-grafana/#temp-data-lifetime&#34;&gt;temp-data-lifetime&lt;/a&gt; setting. This setting also affects how long a renderer PNG file should be stored.&lt;/p&gt;
&lt;h3 id=&#34;scheduling&#34;&gt;Scheduling&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 8.0 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.
The scheduler was significantly changed in Grafana Enterprise version 8.1.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;Scheduled reports can be sent once, or repeated on an hourly, daily, weekly, or monthly basis, or sent at custom intervals. You can also disable scheduling by selecting &lt;strong&gt;Never&lt;/strong&gt;, for example to send the report via the API.&lt;/p&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_scheduler_8.1.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_scheduler_8.1.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_scheduler_8.1.png?w=320 320w, /static/img/docs/enterprise/reports_scheduler_8.1.png?w=550 550w, /static/img/docs/enterprise/reports_scheduler_8.1.png?w=750 750w, /static/img/docs/enterprise/reports_scheduler_8.1.png?w=900 900w, /static/img/docs/enterprise/reports_scheduler_8.1.png?w=1040 1040w, /static/img/docs/enterprise/reports_scheduler_8.1.png?w=1240 1240w, /static/img/docs/enterprise/reports_scheduler_8.1.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1278&#34;height=&#34;816&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_scheduler_8.1.png&#34;
            alt=&#34;&#34;width=&#34;1278&#34;height=&#34;816&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;p&gt;&lt;strong&gt;Send now or schedule for later&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Send now&lt;/strong&gt; sends the report immediately after you save it. To stop sending the report at some point in the future, add an end date. If you leave the end date empty, the report is sent out indefinitely.&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Send later&lt;/strong&gt; schedules a report for a later date. Thus, the start date and time are required fields. If you leave the end date empty, the report is sent out indefinitely.&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;Send only from Monday to Friday&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;For reports that have an hourly or daily frequency, you can choose to send them only from Monday to Friday.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Send on the last day of the month&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;When you schedule a report with a monthly frequency, and set the start date between the 29th and the 31st of the month, the report is only sent during the months that have those dates. If you want the report to be sent every month, select the &lt;strong&gt;Send on the last day of the month&lt;/strong&gt; option instead. This way, the report is sent on the last day of every month regardless of how many days there are in any given month.&lt;/p&gt;
&lt;h3 id=&#34;send-a-test-email&#34;&gt;Send a test email&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 7.0 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;ol&gt;
&lt;li&gt;In the report, click &lt;strong&gt;Send test email&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;In the Email field, enter the email address or addresses that you want to test, separated by semicolon.
If you want to use email addresses from the report, then select the &lt;strong&gt;Use emails from report&lt;/strong&gt; check box.&lt;/li&gt;
&lt;li&gt;Click &lt;strong&gt;Send&lt;/strong&gt;.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;The last saved version of the report will be sent to selected emails. You can use this to verify emails are working and to make sure the report is generated and displayed as you expect.&lt;/p&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_send_test_mail.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_send_test_mail.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_send_test_mail.png?w=320 320w, /static/img/docs/enterprise/reports_send_test_mail.png?w=550 550w, /static/img/docs/enterprise/reports_send_test_mail.png?w=750 750w, /static/img/docs/enterprise/reports_send_test_mail.png?w=900 900w, /static/img/docs/enterprise/reports_send_test_mail.png?w=1040 1040w, /static/img/docs/enterprise/reports_send_test_mail.png?w=1240 1240w, /static/img/docs/enterprise/reports_send_test_mail.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;500&#34;height=&#34;243&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_send_test_mail.png&#34;
            alt=&#34;&#34;width=&#34;500&#34;height=&#34;243&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;h3 id=&#34;pause-a-report&#34;&gt;Pause a report&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 8.0 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can pause sending of reports from the report list view by clicking the pause icon. The report will not be sent according to its schedule until it is resumed by clicking the resume button on the report row.&lt;/p&gt;
&lt;h3 id=&#34;add-multiple-dashboards-to-a-report&#34;&gt;Add multiple dashboards to a report&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 9.0 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can add more than one dashboard to a report. Additional dashboards will be rendered as new pages in the same PDF file, or additional images if you chose to embed images in your report email. Note: you cannot add the same dashboard to a report twice.&lt;/p&gt;
&lt;h3 id=&#34;embed-a-dashboard-as-an-image-into-a-report&#34;&gt;Embed a dashboard as an image into a report&lt;/h3&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 9.0 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can send a report email with an image of the dashboard embedded in the email itself, instead of attached as a PDF. In this case, the email recipients can see the dashboard at a glance instead of having to open the PDF.&lt;/p&gt;
&lt;h2 id=&#34;send-a-report-via-the-api&#34;&gt;Send a report via the API&lt;/h2&gt;
&lt;p&gt;You can send reports programmatically with the &lt;a href=&#34;../../developers/http_api/reporting/#send-report&#34;&gt;send report&lt;/a&gt; endpoint in the &lt;a href=&#34;../../developers/http_api/&#34;&gt;HTTP APIs&lt;/a&gt;.&lt;/p&gt;
&lt;h2 id=&#34;rendering-configuration&#34;&gt;Rendering configuration&lt;/h2&gt;
&lt;p&gt;When generating reports, each panel renders separately before being collected in a PDF. The per-panel rendering timeout and number of concurrently rendered panels can be configured.&lt;/p&gt;
&lt;p&gt;To make a panel more legible, you can set a scale factor for the rendered images. However, a higher scale factor increases the file size of the generated PDF.&lt;/p&gt;
&lt;p&gt;You can also specify custom fonts that support different Unicode scripts. The DejaVu font is the default used for PDF rendering.&lt;/p&gt;
&lt;p&gt;These options are available in the &lt;a href=&#34;../../setup-grafana/configure-grafana/&#34;&gt;configuration&lt;/a&gt; file.&lt;/p&gt;

&lt;div class=&#34;code-snippet &#34;&gt;&lt;div class=&#34;lang-toolbar&#34;&gt;
    &lt;span class=&#34;lang-toolbar__item lang-toolbar__item-active&#34;&gt;ini&lt;/span&gt;
    &lt;span class=&#34;code-clipboard&#34;&gt;
      &lt;button x-data=&#34;app_code_snippet()&#34; x-init=&#34;init()&#34; @click=&#34;copy()&#34;&gt;
        &lt;img class=&#34;code-clipboard__icon&#34; src=&#34;/media/images/icons/icon-copy-small-2.svg&#34; alt=&#34;Copy code to clipboard&#34; width=&#34;14&#34; height=&#34;13&#34;&gt;
        &lt;span&gt;Copy&lt;/span&gt;
      &lt;/button&gt;
    &lt;/span&gt;
    &lt;div class=&#34;lang-toolbar__border&#34;&gt;&lt;/div&gt;
  &lt;/div&gt;&lt;div class=&#34;code-snippet &#34;&gt;
    &lt;pre data-expanded=&#34;false&#34;&gt;&lt;code class=&#34;language-ini&#34;&gt;[reporting]
# Set timeout for each panel rendering request
rendering_timeout = 10s
# Set maximum number of concurrent calls to the rendering service
concurrent_render_limit = 4
# Set the scale factor for rendering images. 2 is enough for monitor resolutions
# 4 would be better for printed material. Setting a higher value affects performance and memory
image_scale_factor = 2
# Set the maximum file size in megabytes for the CSV attachments
max_attachment_size_mb = 10
# Path to the directory containing font files
fonts_path =
# Name of the TrueType font file with regular style
font_regular = DejaVuSansCondensed.ttf
# Name of the TrueType font file with bold style
font_bold = DejaVuSansCondensed-Bold.ttf
# Name of the TrueType font file with italic style
font_italic = DejaVuSansCondensed-Oblique.ttf&lt;/code&gt;&lt;/pre&gt;
  &lt;/div&gt;
&lt;/div&gt;
&lt;h2 id=&#34;report-settings&#34;&gt;Report settings&lt;/h2&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt; version 7.2 and later, and &lt;a href=&#34;/docs/grafana-cloud/&#34;&gt;Grafana Cloud Pro and Advanced&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;You can configure organization-wide report settings in the &lt;strong&gt;Settings&lt;/strong&gt; tab on the &lt;strong&gt;Reporting&lt;/strong&gt; page. Settings are applied to all the reports for current organization.&lt;/p&gt;
&lt;p&gt;You can customize the branding options.&lt;/p&gt;
&lt;p&gt;Report branding:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Company logo URL&lt;/strong&gt; - Company logo displayed in the report PDF. Defaults to the Grafana logo.&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Email branding:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Company logo URL&lt;/strong&gt; - Company logo displayed in the report PDF. Defaults to the Grafana logo.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Email footer&lt;/strong&gt; - Toggle to enable report email footer. Select &lt;strong&gt;Sent by&lt;/strong&gt; or &lt;strong&gt;None&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Footer link text&lt;/strong&gt; - Text for the link in the report email footer. Defaults to &amp;ldquo;Grafana&amp;rdquo;.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Footer link URL&lt;/strong&gt; - Link for the report email footer.&lt;/li&gt;
&lt;/ul&gt;
&lt;figure
    class=&#34;figure-wrapper figure-wrapper__lightbox w-100p docs-image--no-shadow&#34;
    style=&#34;max-width: 500px;&#34;
    itemprop=&#34;associatedMedia&#34;
    itemscope=&#34;&#34;
    itemtype=&#34;http://schema.org/ImageObject&#34;
  &gt;&lt;a
        class=&#34;lightbox-link&#34;
        href=&#34;/static/img/docs/enterprise/reports_settings.png&#34;
        itemprop=&#34;contentUrl&#34;
      &gt;&lt;div class=&#34;img-wrapper w-100p h-auto&#34;&gt;&lt;img
          class=&#34;lazyload &#34;
          data-src=&#34;/static/img/docs/enterprise/reports_settings.png&#34;data-srcset=&#34;/static/img/docs/enterprise/reports_settings.png?w=320 320w, /static/img/docs/enterprise/reports_settings.png?w=550 550w, /static/img/docs/enterprise/reports_settings.png?w=750 750w, /static/img/docs/enterprise/reports_settings.png?w=900 900w, /static/img/docs/enterprise/reports_settings.png?w=1040 1040w, /static/img/docs/enterprise/reports_settings.png?w=1240 1240w, /static/img/docs/enterprise/reports_settings.png?w=1920 1920w&#34;data-sizes=&#34;auto&#34;alt=&#34;&#34;width=&#34;1128&#34;height=&#34;1029&#34;/&gt;
        &lt;noscript&gt;
          &lt;img
            src=&#34;/static/img/docs/enterprise/reports_settings.png&#34;
            alt=&#34;&#34;width=&#34;1128&#34;height=&#34;1029&#34;class=&#34;docs-image--no-shadow&#34;/&gt;
        &lt;/noscript&gt;&lt;/div&gt;&lt;/a&gt;&lt;/figure&gt;
&lt;h2 id=&#34;troubleshoot-reporting&#34;&gt;Troubleshoot reporting&lt;/h2&gt;
&lt;p&gt;To troubleshoot and get more log information, enable debug logging in the configuration file. Refer to &lt;a href=&#34;../../setup-grafana/configure-grafana/#filters&#34;&gt;Configuration&lt;/a&gt; for more information.&lt;/p&gt;

&lt;div class=&#34;code-snippet &#34;&gt;&lt;div class=&#34;lang-toolbar&#34;&gt;
    &lt;span class=&#34;lang-toolbar__item lang-toolbar__item-active&#34;&gt;Bash&lt;/span&gt;
    &lt;span class=&#34;code-clipboard&#34;&gt;
      &lt;button x-data=&#34;app_code_snippet()&#34; x-init=&#34;init()&#34; @click=&#34;copy()&#34;&gt;
        &lt;img class=&#34;code-clipboard__icon&#34; src=&#34;/media/images/icons/icon-copy-small-2.svg&#34; alt=&#34;Copy code to clipboard&#34; width=&#34;14&#34; height=&#34;13&#34;&gt;
        &lt;span&gt;Copy&lt;/span&gt;
      &lt;/button&gt;
    &lt;/span&gt;
    &lt;div class=&#34;lang-toolbar__border&#34;&gt;&lt;/div&gt;
  &lt;/div&gt;&lt;div class=&#34;code-snippet &#34;&gt;
    &lt;pre data-expanded=&#34;false&#34;&gt;&lt;code class=&#34;language-bash&#34;&gt;[log]
filters = report:debug&lt;/code&gt;&lt;/pre&gt;
  &lt;/div&gt;
&lt;/div&gt;
]]></content><description>&lt;h1 id="reporting">Reporting&lt;/h1>
&lt;p>Reporting allows you to automatically generate PDFs from any of your dashboards and have Grafana email them to interested parties on a schedule. This is available in Grafana Cloud Pro and Advanced and in Grafana Enterprise.&lt;/p></description></item><item><title>Export dashboard as PDF</title><link>https://grafana.com/docs/grafana/v9.0/enterprise/export-pdf/</link><pubDate>Fri, 07 Mar 2025 11:34:44 +0100</pubDate><guid>https://grafana.com/docs/grafana/v9.0/enterprise/export-pdf/</guid><content><![CDATA[&lt;h1 id=&#34;export-dashboard-as-pdf&#34;&gt;Export dashboard as PDF&lt;/h1&gt;
&lt;p&gt;You can generate and save PDF files from any of your dashboards.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; Available in &lt;a href=&#34;../&#34;&gt;Grafana Enterprise&lt;/a&gt;.&lt;/p&gt;&lt;/blockquote&gt;
&lt;ol&gt;
&lt;li&gt;In the upper right corner of the dashboard that you want to export as PDF, click the &lt;strong&gt;Share dashboard&lt;/strong&gt; icon.&lt;/li&gt;
&lt;li&gt;On the PDF tab, select the layout option for exported dashboard: &lt;strong&gt;Portrait&lt;/strong&gt; or &lt;strong&gt;Landscape&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;Click &lt;strong&gt;Save as PDF&lt;/strong&gt; to render the dashboard as a PDF file.
Grafana opens the PDF file in a new window or browser tab.&lt;/li&gt;
&lt;/ol&gt;
]]></content><description>&lt;h1 id="export-dashboard-as-pdf">Export dashboard as PDF&lt;/h1>
&lt;p>You can generate and save PDF files from any of your dashboards.&lt;/p>
&lt;blockquote>
&lt;p>&lt;strong>Note:&lt;/strong> Available in &lt;a href="../">Grafana Enterprise&lt;/a>.&lt;/p>&lt;/blockquote>
&lt;ol>
&lt;li>In the upper right corner of the dashboard that you want to export as PDF, click the &lt;strong>Share dashboard&lt;/strong> icon.&lt;/li>
&lt;li>On the PDF tab, select the layout option for exported dashboard: &lt;strong>Portrait&lt;/strong> or &lt;strong>Landscape&lt;/strong>.&lt;/li>
&lt;li>Click &lt;strong>Save as PDF&lt;/strong> to render the dashboard as a PDF file.
Grafana opens the PDF file in a new window or browser tab.&lt;/li>
&lt;/ol></description></item></channel></rss>