- Introducing Elasticsearch Add-On for Heroku
- Configuring your deployment
- Securing your deployment
- Monitoring your deployment
- How to set up monitoring
- Access performance metrics
- Keep track of deployment activity
- Diagnose unavailable nodes
- Why are my shards unavailable?
- Why is performance degrading over time?
- Is my cluster really highly available?
- How does high memory pressure affect performance?
- Why are my cluster response times suddenly so much worse?
- How do I resolve deployment health warnings?
- How do I resolve node bootlooping?
- Snapshot and restore
- About
- Subscription levels
- Version policy
- Elasticsearch Add-On for Heroku hardware
- Elasticsearch Add-On for Heroku GCP instance configurations
- Elasticsearch Add-On for Heroku GCP default provider instance configurations
- Elasticsearch Add-On for Heroku AWS instance configurations
- Elasticsearch Add-On for Heroku AWS default provider instance configurations
- Elasticsearch Add-On for Heroku Azure instance configurations
- Elasticsearch Add-On for Heroku Azure default provider instance configurations
- Elasticsearch Add-On for Heroku regions
- Service status
- Getting help
- Restrictions and known problems
- What’s new with the Elastic Stack
Edit Kibana user settings
editEdit Kibana user settings
editElasticsearch Add-On for Heroku supports most of the standard Kibana and X-Pack settings. Through a YAML editor in the console, you can append Kibana properties to the kibana.yml
file. Your changes to the configuration file are read on startup.
Be aware that some settings that could break your cluster if set incorrectly and that the syntax might change between major versions. Before upgrading, be sure to review the full list of the latest Kibana settings and syntax.
To change Kibana settings:
- Log in to the Elasticsearch Add-On for Heroku console.
-
On the deployments page, select your deployment.
Narrow your deployments by name, ID, or choose from several other filters. To customize your view, use a combination of filters, or change the format from a grid to a list.
- From your deployment menu, go to the Edit page.
- In the Kibana section, select Edit user settings. (For deployments with existing user settings, you may have to expand the Edit kibana.yml caret instead.)
- Update the user settings.
- Select Save changes.
Saving your changes initiates a configuration plan change that restarts Kibana automatically for you.
If a setting is not supported by Elasticsearch Add-On for Heroku, you will get an error message when you try to save.
Supported Kibana settings
editVersion 8.12.0+
edit-
xpack.reporting.csv.maxConcurrentShardRequests
-
Sets the maximum number of concurrent shard requests that each sub-search request executes per node during Kibana CSV export. Defaults to
5
.
Version 8.11.0+
edit-
xpack.action.queued.max
-
Specifies the maximum number of actions that can be queued. Defaults to
1000000
.
Version 8.9.0+
edit-
xpack.fleet.createArtifactsBulkBatchSize
- Allow to configure batch size for creating and updating Fleet user artifacts. Examples include creation of Trusted Applications and Endpoint Exceptions in Security. To learn more, check Fleet settings in Kibana.
-
xpack.securitySolution.maxUploadResponseActionFileBytes
- Allow to configure the max file upload size for use with the Upload File Repsonse action available with the Defend Integration. To learn more, check Endpoint Response actions.
Version 8.7.0+
edit-
xpack.security.session.concurrentSessions.maxSessions
- Set the maximum number of sessions each user is allowed to have active in Kibana. By default, no limit is applied. If set, the value of this option should be an integer between 1 and 1000. When the limit is exceeded, the oldest session is automatically invalidated. To learn more, check Session management.
-
server.securityResponseHeaders.crossOriginOpenerPolicy
-
Controls whether the
Cross-Origin-Opener-Policy
header is used in all responses to the client from the Kibana server. To learn more, see Configure Kibana.
Version 8.6.0+
edit-
server.compression.brotli.enabled
- Enable brotli compression format for browser-server communications. Default: false. To learn more, check Configure Kibana.
-
xpack.fleet.enableExperimental
- Allow to configure experimental feature for Fleet. To learn more, check Fleet settings in Kibana.
Version 8.4.0+
edit-
migrations.discardUnknownObjects
-
Discard saved objects with unknown types during a migration. Must be set to the target version, e.g.:
8.4.0
. Default: undefined. To learn more, check Configure Kibana. -
migrations.discardCorruptObjects
-
Discard corrupt saved objects, as well as those that cause transform errors during a migration. Must be set to the target version, e.g.:
8.4.0
. Default: undefined. To learn more, check Configure Kibana.
Version 8.3.0+
edit-
elasticsearch.compression
- Enable compression for communications with Elasticsearch. Default: false. To learn more, check Configure Kibana.
Version 8.2.0+
edit-
elasticsearch.maxSockets
- The maximum number of sockets that can be used for communications with Elasticsearch. Default: Infinity. To learn more, check Configure Kibana.
Version 8.1.0+
edit-
execution_context.enabled
-
Propagate request-specific metadata to Elasticsearch server by way of the
x-opaque-id
header. To learn more, check Configure Kibana.
Supported versions before 8.x
edit-
vis_type_table.legacyVisEnabled
-
For 7.x versions version 7.11 and higher, a new version of the datatable visualization is used. Set to
true
to enable the legacy version. In version 8.0, the old implementation is removed and this setting is no longer supported. -
vega.enableExternalUrls
-
Set to
true
to allow Vega vizualizations to use data from sources other than the linked Elasticsearch cluster. In stack version 8.0 and above, thevega.enableExternalUrls
is not supported. Usevis_type_vega.enableExternalUrls
instead.
All supported versions
edit-
migrations.maxBatchSizeBytes
- Defines the maximum payload size for indexing batches of saved objects during upgrade migrations. To learn more, check Configure Kibana.
-
server.maxPayload
- The maximum payload size in bytes for incoming server requests. Default: 1048576. To learn more, check Configure Kibana.
-
server.securityResponseHeaders.strictTransportSecurity
-
Controls whether the
Strict-Transport-Security
header is used in all responses to the client from the Kibana server. To learn more, check Configure Kibana. -
server.securityResponseHeaders.xContentTypeOptions
-
Controls whether the
X-Content-Type-Options
header is used in all responses to the client from the Kibana server. To learn more, check Configure Kibana. -
server.securityResponseHeaders.referrerPolicy
-
Controls whether the
Referrer-Policy
header is used in all responses to the client from the Kibana server. To learn more, see Configure Kibana. -
server.securityResponseHeaders.permissionsPolicy
-
Controls whether the
Permissions-Policy
header is used in all responses to the client from the Kibana server. To learn more, see Configure Kibana. -
server.securityResponseHeaders.permissionsPolicyReportOnly
-
Controls whether the
Permissions-Policy-Report-Only
header is used in all responses to the client from the Kibana server. To learn more, see Configure Kibana. -
server.securityResponseHeaders.disableEmbedding
-
Controls whether the
Content-Security-Policy
andX-Frame-Options
headers are configured to disable embedding Kibana in other webpages using iframes. To learn more, see Configure Kibana. -
data.autocomplete.valueSuggestions.timeout
- Specifies the time in milliseconds to wait for autocomplete suggestions from Elasticsearch. The default is 1000. Allowed values are between 1 and 1200000. To learn more, check Configure Kibana.
-
data.autocomplete.valueSuggestions.terminateAfter
- Specifies the max number of documents loaded by each shard to generate autocomplete suggestions. The default is 100000. Allowed values are between 1 and 10000000. To learn more, check Configure Kibana.
-
map.tilemap.options.attribution
- Adds the map attribution string.
-
map.tilemap.options.maxZoom
- Sets the maximum zoom level.
-
map.tilemap.options.minZoom
- Sets the minimum zoom level.
-
map.tilemap.options.subdomains
-
Provides an array of subdomains used by the tile service.
Specify the position of the subdomain the URL with the token
{s}
. -
map.tilemap.url
- Lists the URL to the tileservice that Kibana uses to display map tiles in tilemap visualizations.
-
i18n.locale
-
Specifies the locale for all strings, dates, and number formats that can be localized. Defaults to
en
(English). -
migrations.batchSize
- Defines the number of documents migrated at a time during saved object upgrade migrations. To learn more, check Configure Kibana.
-
server.defaultRoute
- Specifies the default route when opening Kibana. You can use this setting to modify the landing page when opening Kibana.
-
server.customResponseHeaders
- Specifies HTTP header names and values that the Kibana backend will return to the client.
Map settings
edit-
map.regionmap:
-
Specifies additional vector layers for use in Region Map visualizations. Each layer object points to an external vector file that contains a geojson FeatureCollection. The file must use the WGS84 coordinate reference system and only include polygons. If the file is hosted on a separate domain from Kibana, the server needs to be CORS-enabled so Kibana can download the file. The following example shows a valid regionmap configuration.
map.regionmap: includeElasticMapsService: false layers: - name: "Departments of France" url: "http://my.cors.enabled.server.org/france_departements.geojson" attribution: "INRAP" fields: - name: "department" description: "Full department name" - name: "INSEE" description: "INSEE numeric identifier"
-
map.regionmap.includeElasticMapsService:
-
Turns on or off
whether layers from the Elastic Maps Service should be included in the vector
layer option list. Supported on Elastic Cloud Enterprise. By turning this off,
only the layers that are configured here will be included. The default is
true
. -
map.regionmap.layers[].attribution:
- Optional. References the originating source of the geojson file.
-
map.regionmap.layers[].fields[]:
- Mandatory. Each layer can contain multiple fields to indicate what properties from the geojson features you wish to expose. The previous example shows how to define multiple properties.
-
map.regionmap.layers[].fields[].description:
- Mandatory. The human readable text that is shown under the Options tab when building the Region Map visualization.
-
map.regionmap.layers[].fields[].name:
-
Mandatory.
This value is used to do an inner-join between the document stored in
Elasticsearch and the geojson file. For example, if the field in the geojson is
called
Location
and has city names, there must be a field in Elasticsearch that holds the same values that Kibana can then use to lookup for the geoshape data. -
map.regionmap.layers[].name:
- Mandatory. A description of the map being provided.
-
map.regionmap.layers[].url:
- Mandatory. The location of the geojson file as provided by a webserver.
-
tilemap.options.attribution
- Adds the map attribution string.
-
tilemap.options.maxZoom
- Sets the maximum zoom level.
-
tilemap.options.minZoom
- Sets the minimum zoom level.
-
tilemap.options.subdomains
-
Provides an array of subdomains used by the tile service.
Specify the position of the subdomain the URL with the token
{s}
. -
tilemap.url
- Lists the URL to the tileservice that Kibana uses to display map tiles in tilemap visualizations.
SAML settings
editIf you are using SAML to secure your clusters, these settings are supported in Elasticsearch Add-On for Heroku.
To learn more, refer to configuring Kibana to use SAML.
Version 8.0.0+
editThe following additional setting is supported:
-
server.xsrf.allowlist
- Allows the SAML authentication URL within Kibana, so that the Kibana server doesn’t reject external authentication messages that originate from your Identity Provider.
All supported versions
edit-
xpack.security.authc.providers.saml.<provider-name>.useRelayStateDeepLink
-
Specifies if Kibana should treat the
RelayState
parameter as a deep link when Identity Provider Initiated login flow is used. -
xpack.security.authc.providers.saml.<provider-name>.order
- Specifies order of the SAML authentication provider in the authentication chain.
-
xpack.security.authc.providers.saml.<provider-name>.realm
- Specifies which SAML realm in Elasticsearch should be used.
-
xpack.security.authc.providers.saml.<provider-name>.maxRedirectURLSize
- Specifies the maximum size of the URL that Kibana is allowed to store during the SAML handshake.
-
xpack.security.authc.providers.saml.<provider-name>.description
- Specifies how SAML login should be titled in the Login Selector UI.
-
xpack.security.authc.saml.maxRedirectURLSize
- Specifies the maximum size of the URL that Kibana is allowed to store during the SAML handshake.
-
xpack.security.authc.saml.realm
- Specifies which SAML realm in Elasticsearch should be used.
-
xpack.security.authc.providers
- Specifies which providers are going to be used in Kibana.
All supported versions before 8.x
edit-
xpack.security.authProviders
-
Set to
saml
to instruct Kibana to use SAML SSO as the authentication method. -
xpack.security.public.protocol
- Set to HTTP or HTTPS. To access Kibana, HTTPS protocol is recommended.
-
xpack.security.public.hostname
- Set to a fully qualified hostname to connect your users to the proxy server.
-
xpack.security.public.port
- The port number that connects your users to the proxy server (for example, 80 for HTTP or 443 for HTTPS).
-
xpack.security.authc.saml.useRelayStateDeepLink
-
Specifies if Kibana should treat the
RelayState
parameter as a deep link when Identity Provider Initiated login flow is used. -
server.xsrf.whitelist
-
Explicitly allows the SAML authentication URL within Kibana, so that the Kibana server doesn’t reject external authentication messages that originate from your Identity Provider.
This setting is renamed to
server.xsrf.allowlist
in version 8.0.0.
OpenID Connect
editIf you are using OpenID Connect to secure your clusters, these settings are supported in Elasticsearch Add-On for Heroku.
-
xpack.security.authc.providers.oidc.<provider-name>.order
- Specifies order of the OpenID Connect authentication provider in the authentication chain.
-
xpack.security.authc.providers.oidc.<provider-name>.realm
- Specifies which OpenID Connect realm in Elasticsearch should be used.
-
xpack.security.authc.providers.oidc.<provider-name>.description
- Specifies how OpenID Connect login should be titled in the Login Selector UI.
-
xpack.security.authc.oidc.realm
- Specifies which OpenID Connect realm in Elasticsearch should be used.
To learn more, check configuring Kibana to use OpenID Connect.
Anonymous authentication
editIf you want to allow anonymous authentication in Kibana, these settings are supported in Elasticsearch Add-On for Heroku. To learn more on how to enable anonymous access, check Enabling anonymous access and Configuring Kibana to use anonymous authentication.
Supported versions before 8.0.0
edit-
xpack.security.sessionTimeout
- Specifies the session duration in milliseconds. Allows a value between 15000 (15 seconds) and 86400000 (1 day). To learn more, check Security settings in Kibana. Deprecated in versions 7.6+ and removed in versions 8.0+.
All supported versions
edit-
xpack.security.authc.anonymous.*
-
Enables access for the
anonymous
user. In versions prior to 7.10 anonymous access is enabled by default, but you can add this setting if you want to avoid anonymous access being disabled accidentally by a subsequent upgrade. -
xpack.security.authc.providers.anonymous.<provider-name>.order
- Specifies order of the anonymous authentication provider in the authentication chain.
-
xpack.security.authc.providers.anonymous.<provider-name>.credentials
- Specifies which credentials Kibana should use for anonymous users.
X-Pack configuration settings
editYou can configure the following X-Pack settings from the Kibana User Settings editor.
Version 8.16+
edit-
xpack.task_manager.capacity
- Controls the number of tasks that can be run at one time. Can be minimum 5 and maximum 50. Default: 10.
Version 8.8+
edit-
xpack.cases.files.allowedMimeTypes
-
The MIME types that you can attach to a case, represented in an array of strings. For example:
['image/tiff','text/csv','application/zip'].
The default MIME types are specified in mime_types.ts. -
xpack.cases.files.maxSize
- The size limit for files that you can attach to a case, represented as the number of bytes. By default, the limit is 10 MiB for images and 100 MiB for all other MIME types. If you specify a value for this setting, it affects all file types.
-
xpack.actions.enableFooterInEmail
- A boolean value indicating that a footer with a relevant link should be added to emails sent as alerting actions. Default: true.
Version 8.7+
edit-
xpack.actions.run.maxAttempts
- Specifies the maximum number of times an action can be attempted to run. Can be minimum 1 and maximum 10.
-
xpack.actions.run.connectorTypeOverrides
- Overrides the settings under xpack.actions.run for a connector type with the given ID. For example id:'.server-log', maxAttempts:5.
Version 8.6+
edit-
xpack.task_manager.monitored_stats_health_verbose_log.level
-
Set to
info
for Task Manager to log the health monitoring stats at info level instead ofdebug
. Default:debug
.
Version 8.5+
edit-
xpack.security.accessAgreement.message
-
This setting specifies the access agreement text in Markdown format that will be used as the default access agreement for all providers that do not
specify a value for
xpack.security.authc.providers.<provider-type>.<provider-name>.accessAgreement.message
. -
xpack.alerting.rules.run.alerts.max
-
Sets the maximum number of alerts that a rule can generate each time detection checks run. Defaults to
1000
.
Version 8.3+
edit-
xpack.cloudSecurityPosture.enabled
-
Enables the Kibana UI for Elastic’s Cloud Security Posture solution. The solution provides audit & compliance checks on Cloud & Kubernetes environments. Defaults to
false
. -
xpack.alerting.rules.run.actions.connectorTypeOverrides
- Overrides the settings under xpack.alerting.rules.run.actions for a connector type with the given ID. For example id:'.server-log', max:1000.
Version 8.2+
edit-
xpack.alerting.rules.minimumScheduleInterval.value
-
Specifies the minimum schedule interval for rules. This minimum is applied to all rules created or updated after you set this value. Defaults to
1m
. -
xpack.alerting.rules.minimumScheduleInterval.enforce
-
Specifies the behavior when a new or changed rule has a schedule interval less than the value defined in
xpack.alerting.rules.minimumScheduleInterval.value
. Iffalse
, rules with schedules less than the interval will be created but warnings will be logged. Iftrue
, rules with schedules less than the interval cannot be created. Default:false
. -
xpack.alerting.rules.run.actions.max
-
Sets the maximum number of actions that a rule can trigger each time detection checks run (maximum
100000
). -
xpack.alerting.rules.run.timeout
- Specifies the default timeout for the all rule types tasks.
-
xpack.alerting.rules.run.ruleTypeOverrides
- Overrides the settings under xpack.alerting.rules.run for a rule type with the given id. e.g. (id:'index-threshold', timeout:'5m'),
Version 8.1+
edit-
xpack.alerting.cancelAlertsOnRuleTimeout
-
Set to
false
to enable writing alerts and scheduling actions even if rule execution is cancelled due to timeout. Defaults totrue
.
Version 8.0+
edit-
xpack.endpoint.enabled
-
Set to
true
to enable the Endpoint application. -
xpack.fleet.enabled
-
Set to
false
to disable the Fleet application. Also enables the EPM and Agents features. For details about using this application, check the blog post Easier data onboarding with Elastic Agent and Ingest Manager. -
xpack.fleet.agents.enabled
-
Set to
false
to disable the Agents API & UI. -
xpack.ruleRegistry.write.disabledRegistrationContexts
- Specifies the observability alert indices that are disabled to be written. Data type is array. Allowed values are: [ observability.logs,observability.metrics,observability.apm,observability.uptime ]
Version 7.17.4+, 8.3+
edit-
xpack.actions.email.domain_allowlist
- A list of allowed email domains which can be used with the email connector. When this setting is not used, all email domains are allowed. When this setting is used, if any email is attempted to be sent that (a) includes an addressee with an email domain that is not in the allowlist, or (b) includes a from address domain that is not in the allowlist, it will fail with a message indicating the email is not allowed.
This setting is not available in versions 8.0.0 through 8.2.0. As such, this setting should be removed before upgrading from 7.17 to 8.0, 8.1 or 8.2. It is possible to configure the settings in 7.17.4 and then upgrade to 8.3.0 directly.
Version 7.17.2+, 8.2+
edit-
xpack.task_manager.event_loop_delay.monitor
-
Enables event loop delay monitoring, which will log a warning when a task causes an event loop delay which exceeds the
warn_threshold
setting. Defaults to true.This setting is not available in versions 8.0.0 through 8.1.1.
-
xpack.task_manager.event_loop_delay.warn_threshold
-
Sets the amount of event loop delay during a task execution which will cause a warning to be logged. Defaults to 5000 milliseconds (5 seconds).
This setting is not available in versions 8.0.0 through 8.1.1. As such, this setting should be removed before upgrading from 7.17 to 8.0 or 8.1.0. It is possible to configure the settings in 7.17.2 and then upgrade to 8.2.0 directly.
All supported versions
edit-
xpack.alerting.defaultRuleTaskTimeout
-
Specifies the default timeout for the all rule types tasks. Defaults to
5m
. Deprecated in versions 8.2+ and removed in versions 9.0+. -
xpack.actions.microsoftGraphApiUrl
-
Specifies the URL to the Microsoft Graph server when using the MS Exchange Server email service. Defaults to
https://graph.microsoft.com/v1.0
. -
xpack.alerting.maxEphemeralActionsPerAlert
-
Sets the number of actions that will be executed ephemerally. Defaults to
10
. -
xpack.task_manager.ephemeral_tasks.enabled
-
Enables an experimental feature that executes a limited (and configurable) number of actions in the same task as the alert which triggered them. These action tasks reduce the latency of the time it takes an action to run after it’s triggered, but are not persisted as SavedObjects. These non-persisted action tasks have a risk that they won’t be run at all if the Kibana instance running them exits unexpectedly. Defaults to
false
. -
xpack.task_manager.ephemeral_tasks.request_capacity
-
Sets the size of the ephemeral queue. Defaults to
10
. -
xpack.actions.customHostSettings
- An array of objects, one per host, containing the SSL/TLS settings used when executing connectors which make HTTPS and SMTP connections to the host servers. For details about using this setting, check Alerting and action settings in Kibana.
-
xpack.actions.ssl.proxyVerificationMode
-
Controls the verification of the proxy server certificate that hosted-ems receives when making an outbound SSL/TLS connection to the host server. Valid values are
full
,certificate
, andnone
. Usefull
to perform hostname verification,certificate
to skip hostname verification, andnone
to skip verification. Default:full
. -
xpack.actions.ssl.verificationMode
-
Controls the verification of the server certificate that hosted-ems receives when making an outbound SSL/TLS connection to the host server. Valid values are
full
,certificate
, andnone
. Usefull
to perform hostname verification,certificate
to skip hostname verification, andnone
to skip verification. Default:full
. -
xpack.task_manager.monitored_stats_health_verbose_log.enabled
-
Enable to allow the Kibana task manager to log at either a warning or error log level if it self-detects performance issues. Default:
false
. -
xpack.task_manager.monitored_stats_health_verbose_log.warn_delayed_task_start_in_seconds
-
The number of seconds we allow a task to delay before printing a warning server log. Default:
60
. -
xpack.actions.preconfiguredAlertHistoryEsIndex
-
Set to
true
to enable experimental Alert history Elasticsearch index connector. Default:false
. -
xpack.discoverEnhanced.actions.exploreDataInContextMenu.enabled
-
Set to
true
to enable the "explore underlying data" menu action in dashboards. Default:false
. -
xpack.actions.proxyBypassHosts
-
Specifies hostnames which should not use the proxy, if using a proxy for actions. The value is an array of hostnames as strings. By default, all hosts will use the proxy. The settings
xpack.actions.proxyBypassHosts
andxpack.actions.proxyOnlyHosts
cannot be used at the same time. -
xpack.actions.proxyOnlyHosts
-
Specifies hostnames which should only be used with the proxy, if using a proxy for actions. The value is an array of hostnames as strings. By default, all hosts will use the proxy. The settings
xpack.actions.proxyBypassHosts
andxpack.actions.proxyOnlyHosts
cannot be used at the same time. -
xpack.actions.maxResponseContentLength
- Specifies the max number of bytes of the HTTP response for requests to external resources. Defaults to 1mb.
-
xpack.actions.responseTimeout
- Specifies the time allowed for requests to external resources. Requests that take longer are aborted. The time is formatted as <count>[ms|s|m|h|d|w|M|Y], for example, 20m, 24h, 7d, 1w. Defaults to 60s.
-
xpack.task_manager.monitored_task_execution_thresholds
-
Specifies the thresholds for failed task executions. If the percentage of failed executions exceeds the specified thresholds, the health of the task will be reported as configured. Can be specified at a default level or a custom level for specific task types. The following example shows a valid
monitored_task_execution_thresholds configuration
.xpack.task_manager.monitored_task_execution_thresholds: default: error_threshold: 70 warn_threshold: 50 custom: "alerting:.index-threshold": error_threshold: 50 warn_threshold: 0
-
xpack.task_manager.version_conflict_threshold
-
Specifies the threshold for version conflicts. If the percentage of version conflicts exceeds the threshold, the task manager
poll_interval
will automatically be adjusted. Default:80
. -
xpack.actions.proxyUrl
- Specifies the proxy URL to use, if using a proxy for actions.
-
xpack.actions.proxyHeaders
- Specifies headers for proxy, if using a proxy for actions.
-
xpack.ingestManager.enabled
-
Set to
false
to disable the Ingest Manager application. Also enables the EPM and Fleet features. For details about using this application, check the blog post Easier data onboarding with Elastic Agent and Ingest Manager. -
xpack.ingestManager.fleet.enabled
-
Set to
false
to disable the Fleet API & UI. -
xpack.lists.maxImportPayloadBytes
-
Sets the number of bytes (default
9000000
, maximum100000000
) allowed for uploading Security Solution value lists. For every 10 megabytes, it is recommended to have an additional 1 gigabyte of RAM reserved for Kibana. For example, on a Kibana instance with 2 gigabytes of RAM, you can set this value up to 20000000 (20 megabytes). -
xpack.lists.importBufferSize
-
Sets the buffer size used for uploading Security Solution value lists (default
1000
). Change the value if you are experiencing slow upload speeds or larger than wanted memory usage when uploading value lists. Set to a higher value to increase throughput at the expense of using more Kibana memory, or a lower value to decrease throughput and reduce memory usage. -
xpack.security.sameSiteCookies
-
Sets the
SameSite
attribute ofSet-Cookie
HTTP header. It allows you to declare whether your cookie should be restricted to a first-party or same-site context. Not set by default, which makes modern browsers treat it asLax
. If you use Kibana embedded in an iframe in modern browsers, you might need to set it toNone
. Note thatNone
usage requires secure context:xpack.security.secureCookies: true
. Some old versions of IE11 do not supportSameSite: None
, so you should not specifyxpack.security.sameSiteCookies
at all. -
xpack.ingestManager.enabled
-
Set to
true
(defaultfalse
) to enable the Ingest Manager application. Also enables the EPM and Fleet features. For details about using this application, check the blog post Easier data onboarding with Elastic Agent and Ingest Manager. -
xpack.ingestManager.epm.enabled
-
Set to
true
(default) to enable the EPM API & UI. -
xpack.ingestManager.fleet.enabled
-
Set to
true
(default) to enable the Fleet API & UI. -
xpack.task_manager.max_workers
-
Specify the maximum number of tasks a Kibana will run concurrently. Default:
10
. Deprecated in versions 8.16+ -
xpack.task_manager.poll_interval
-
Specify how often, in milliseconds, a Kibana should check for more tasks. Default:
3000
. -
xpack.eventLog.logEntries
-
Set to
true
to enable logging event log documents from alerting to the Kibana log, in addition to being indexed into the event log index. Default:false
. -
xpack.security.session.idleTimeout
-
Set the session duration. The format is a string of
count
andunit
, where unit is one ofms
,s
,m
,h
,d
,w
,M
,Y
. For example,70ms
,5s
,3d
,1Y
. To learn more, check Security settings in Kibana. -
xpack.security.session.lifespan
- Sets the maximum duration, also known as "absolute timeout". After this duration, the session will expire even if it is not idle. To learn more, check Security settings in Kibana.
-
xpack.maps.showMapVisualizationTypes
-
Set to
true
if you want to create new region map visualizations. -
xpack.actions.allowedHosts
-
Set to an array of host names which actions such as email, slack, pagerduty, and webhook can connect to. An element of
*
indicates any host can be connected to. An empty array indicates no hosts can be connected to. Default:[ * ]
-
xpack.actions.enabledActionTypes
-
Set to an array of action types that are enabled. An element of
*
indicates all action types registered are enabled. The action types provided by Kibana are:.server-log
,.slack
,.email
,.index
,.pagerduty
,.webhook
. Default:[ * ]
-
xpack.grokdebugger.enabled
-
Set to
true
(default) to enable the Grok Debugger. -
xpack.graph.enabled
-
Set to
false
to disable X-Pack graph. -
xpack.monitoring.cluster_alerts.email_notifications.email_address
- When enabled, specifies the email address to receive cluster alert notifications.
-
xpack.monitoring.kibana.collection.interval
- Controls how often data samples are collected.
-
xpack.monitoring.min_interval_seconds
-
Specifies the minimum number of seconds that a time bucket in a chart can represent. If you modify the
xpack.monitoring.kibana.collection.interval
, use the same value in this setting. -
xpack.monitoring.ui.container.elasticsearch.enabled
-
For Elasticsearch clusters that run in containers, enables the
Node Listing
to display theCPU utilization
based on theCgroup statistics
, and adds theCgroup CPU utilization
to the Node Overview page instead of the overall operating system CPU utilization. -
xpack.ml.enabled
-
Set to true (default) to enable machine learning.
If set to
false
inkibana.yml
, the machine learning icon is hidden in this Kibana instance. Ifxpack.ml.enabled
is set totrue
inelasticsearch.yml
, however, you can still use the machine learning APIs. To disable machine learning entirely, check the Elasticsearch Machine Learning Settings.
Content security policy configuration
edit-
csp.script_src
-
Add sources for the Content Security Policy
script-src
directive. Whencsp.strict
istrue
,csp.script_src
may not beunsafe-inline
. Rules may not containnonce-*
ornone
and will not override the defaults. Default: ['unsafe-eval'
,'self'
] -
csp.worker_src
-
Add sources for the Content Security Policy
worker-src
directive. Rules may not containnonce-*
ornone
and will not override the defaults. Default: [blob:
,'self'
] -
csp.style_src
-
Add sources for the Content Security Policy
style-src
directive. Rules may not containnonce-*
ornone
and will not override the defaults. Default: ['unsafe-inline'
,'self'
] -
csp.connect_src
-
Add sources for the Content Security Policy
connect-src
directive. -
csp.default_src
-
Add sources for the Content Security Policy
default-src
directive. -
csp.font_src
-
Add sources for the Content Security Policy
font-src
directive. -
csp.frame_src
-
Add sources for the Content Security Policy
frame-src
directive. -
csp.img_src
-
Add sources for the Content Security Policy
img-src
directive. -
csp.report_uri
-
Add sources for the Content Security Policy
report-uri
directive. -
csp.report_only.form_action
-
Add sources for the Content Security Policy
form-action
directive in reporting mode. -
csp.strict
-
Blocks Kibana access to any browser that does not enforce even rudimentary CSP rules. In practice, this disables support for older, less safe browsers like Internet Explorer. Default:
true
To learn more, check Configure Kibana]. -
csp.warnLegacyBrowsers
-
Shows a warning message after loading Kibana to any browser that does not
enforce even rudimentary CSP rules, though Kibana is still accessible. This
configuration is effectively ignored when
csp.strict
is enabled. Default:true
-
csp.disableUnsafeEval
-
[preview] This functionality is in technical preview and may be changed or removed in a future release. Elastic will work to fix any issues, but features in technical preview are not subject to the support SLA of official GA features. Set this to
true
to remove theunsafe-eval
source expression from thescript-src
directive. Default:false
By enabling
csp.disableUnsafeEval
, Kibana will use a custom version of the Handlebars template library which doesn’t support inline partials. Handlebars is used in various locations in the Kibana frontend where custom templates can be supplied by the user when for instance setting up a visualisation. If you experience any issues rendering Handlebars templates after turning oncsp.disableUnsafeEval
, or if you rely on inline partials, please revert this setting tofalse
and open an issue in the Kibana GitHub repository.
Permissions policy configuration
edit-
permissionsPolicy.report_to
-
Add sources for the permissions policy
report-to
directive. To learn more, see Configure Kibana
Banner settings
editBanners are disabled by default. You need to manually configure them in order to use the feature.
-
xpack.banners.placement
-
Set to
top
to display a banner above the Elastic header. Defaults todisabled
. -
xpack.banners.textContent
- The text to display inside the banner, either plain text or Markdown.
-
xpack.banners.textColor
-
The color for the banner text. Defaults to
#8A6A0A
. -
xpack.banners.backgroundColor
-
The color of the banner background. Defaults to
#FFF9E8
. -
xpack.banners.disableSpaceBanners
-
If true, per-space banner overrides are disabled. Defaults to
false
.
Reporting settings
editVersion 8.13.0+
edit-
xpack.reporting.csv.scroll.strategy
-
Choose the API method used to page through data during CSV export. Valid options are
scroll
andpit
. Defaults topit
.
Each method has its own unique limitations which are important to understand.
- Scroll API: Search is limited to 500 shards at the very most. In cases where data shards are unavailable or time out, the export may return partial data.
- PIT API: Permissions to read data aliases alone will not work. The permissions are needed on the underlying indices or data streams. In cases where data shards are unavailable or time out, the export will be empty instead of returning partial data.
Support for the The option auto
was included here, when the config value is set to auto
the scroll context will be preserved for as long as is possible, before the report task is terminated due to the limits of xpack.reporting.queue.timeout
.
All supported versions
edit-
xpack.reporting.enabled
-
Set to
false
to completely disable reporting. -
xpack.reporting.queue.timeout
-
Specifies the time each worker has to produce a report. If your machine is slow or under heavy load, you might need to increase this timeout. Specified in milliseconds (number) or duration (string). Duration is a string value formatted as <count>[ms|s|m|h|d|w|M|Y], for example, 20m, 24h, 7d, 1w.
Defaults to
120000
(2 minutes) -
xpack.reporting.capture.maxAttempts
-
Specifies how many retries to attempt in case of occasional failures.
Defaults to
3
. -
xpack.screenshotting.capture.timeouts.openUrl
-
Specify how long to allow the Reporting browser to wait for the "Loading…" screen to dismiss and find the initial data for the Kibana page. If the time is exceeded, a page screenshot is captured showing the current state, and the download link shows a warning message.
Defaults to
30000
(30 seconds). -
xpack.screenshotting.capture.timeouts.waitForElements
-
Specify how long to allow the Reporting browser to wait for all visualization panels to load on the Kibana page. If the time is exceeded, a page screenshot is captured showing the current state, and the download link shows a warning message.
Defaults to
30000
(30 seconds). -
xpack.screenshotting.capture.timeouts.renderComplete
-
Specify how long to allow the Reporting browser to wait for all visualizations to fetch and render the data. If the time is exceeded, a page screenshot is captured showing the current state, and the download link shows a warning message.
Defaults to
30000
(30 seconds). -
xpack.screenshotting.capture.browser.type
-
Specifies the browser to use to capture screenshots. Valid options are
phantom
andchromium
.Beginning with version 7.0,
chromium
is the only allowed option. Defaults tophantom
for earlier versions. -
xpack.reporting.csv.maxSizeBytes
-
Sets the maximum size of a CSV file before being truncated. This setting exists to prevent large exports from causing performance and storage issues. Until 7.15, maximum allowed value is 50 MB (52428800 Bytes).
Defaults to
250MB
. Elastic Stack versions before 8.10 default to10485760
(10MB). -
xpack.reporting.encryptionKey
- Set to any text string. To provide your own encryption key for reports, use this setting.
-
xpack.reporting.roles.enabled
-
When
true
, grants users access to the reporting features when they are assigned thereporting_user
role. Granting access to users this way is deprecated. Set tofalse
and use Kibana privileges instead.
Defaults to true
.
-
xpack.reporting.csv.scroll.duration
- Amount of time allowed before Kibana cleans the scroll context during a CSV export.
Defaults to 30s
(30 seconds).
If search latency in Elasticsearch is sufficiently high, such as if you are using cross-cluster search or frozen tiers, you may need to increase the setting.
-
xpack.reporting.csv.scroll.size
-
Sets the number of documents retrieved from Elasticsearch for each scroll iteration during Kibana CSV export. Defaults to
500
. -
xpack.reporting.csv.checkForFormulas
-
Enables a check that warns you when there’s a potential formula included in the output (=, -, +, and @ chars). See OWASP: https://www.owasp.org/index.php/CSV_Injection. Defaults to
true
. -
xpack.reporting.csv.escapeFormulaValues
-
Escapes formula values in cells with a
'
. See OWASP: https://www.owasp.org/index.php/CSV_Injection. Defaults totrue
. -
xpack.reporting.csv.useByteOrderMarkEncoding
-
Adds a byte order mark (
\ufeff
) at the beginning of the CSV file. Defaults tofalse
.
Logging and audit settings
editTo change logging settings or to enable auditing you must first enable deployment logging.
The following logging settings are supported:
Version 8.0+
edit-
logging.root.level
-
Can be used to adjust Kibana’s logging level. Allowed values are
fatal
,error
,warn
,info
,debug
,trace
, andall
. Setting this toall
causes all events to be logged, including system usage information, all requests, and Elasticsearch queries. This has a similar effect to enabling bothlogging.verbose
andelasticsearch.logQueries
in older 7.x versions. Setting toerror
has a similar effect to enablinglogging.quiet
in older 7.x versions. Defaults toinfo
. -
xpack.security.audit.enabled
- When set to true, audit logging is enabled for security events. Defaults to false.
Supported 7.x versions
edit-
xpack.security.audit.appender.type
-
When set to "rolling-file" and
xpack.security.audit.enabled
is set to true, Kibana ECS audit logs are enabled. Beginning with version 8.0, this setting is no longer necessary for ECS audit log output; it’s only necessary to setxpack.security.audit.enabled
totrue
-
logging.verbose
- If set to true, all events are logged, including system usage information and all requests. Defaults to false.
-
logging.quiet
- If set to true, all logging output other than error messages is suppressed. Defaults to false.
-
elasticsearch.logQueries
-
When set to true, queries sent to Elasticsearch are logged (requires
logging.verbose
set to true). Defaults to false. -
xpack.security.audit.enabled
- When set to true, audit logging is enabled for security events. Defaults to false.
All supported versions
edit-
xpack.security.audit.ignore_filters
- List of filters that determine which audit events should be excluded from the ECS audit log.
-
xpack.security.audit.ignore_filters.actions
-
List of values matched against the
event.action
field of an audit event. -
xpack.security.audit.ignore_filters.categories
-
List of values matched against the
event.category
field of an audit event. -
xpack.security.audit.ignore_filters.outcomes
-
List of values matched against the
event.outcome
field of an audit event. -
xpack.security.audit.ignore_filters.spaces
-
List of values matched against the
kibana.space_id
field of an audit event. This represents the space id in which the event took place. -
xpack.security.audit.ignore_filters.types
-
List of values matched against the
event.type
field of an audit event.
Version 8.15.0+
edit-
xpack.security.audit.ignore_filters.users
-
List of values matched against the
user.name
field of an audit event. This represents the username associated with the audit event.
APM
editThe following APM settings are supported in Kibana:
Version 8.0.0+
edit-
xpack.apm.autoCreateApmDataView
-
Set to
false
to disable the automatic creation of the APM data view when the APM app is opened. Defaults totrue
. This setting was calledxpack.apm.autocreateApmIndexPattern
in versions prior to 8.0.0.
Version 7.16.0 to 8.6.2
edit-
xpack.apm.ui.transactionGroupBucketSize
-
Number of top transaction groups displayed in the APM app. Defaults to
1000
.
Version 7.16.0 to 8.0.0
edit-
xpack.apm.maxServiceEnvironments
-
Maximum number of unique service environments recognized by the UI. Defaults to
100
.
Supported versions before 8.x
edit-
xpack.apm.autocreateApmIndexPattern
-
Set to
false
to disable the automatic creation of the APM data view when the APM app is opened. Defaults totrue
. This setting is renamed toxpack.apm.autoCreateApmDataView
in version 8.0.0.
All supported versions
edit-
xpack.apm.serviceMapFingerprintBucketSize
-
Maximum number of unique transaction combinations sampled for generating service map focused on a specific service. Defaults to
100
. -
xpack.apm.serviceMapFingerprintGlobalBucketSize
-
Maximum number of unique transaction combinations sampled for generating the global service map. Defaults to
100
. -
xpack.apm.serviceMapEnabled
-
Set to
false
to disable service maps. Defaults totrue
. -
xpack.apm.serviceMapTraceIdBucketSize
-
Maximum number of trace IDs sampled for generating service map focused on a specific service. Defaults to
65
. -
xpack.apm.serviceMapTraceIdGlobalBucketSize
-
Maximum number of trace IDs sampled for generating the global service map. Defaults to
6
. -
xpack.apm.serviceMapMaxTracesPerRequest
-
Maximum number of traces per request for generating the global service map. Defaults to
50
. -
xpack.observability.annotations.index
-
Index name where Observability annotations are stored. Defaults to
observability-annotations
. -
xpack.apm.metricsInterval
-
Sets a
fixed_interval
for date histograms in metrics aggregations. Defaults to30
. -
xpack.apm.agent.migrations.enabled
-
Set to
false
to disable cloud APM migrations. Defaults totrue
. -
xpack.apm.indices.span
- Matcher for indices containing span documents. Defaults to apm-*.
-
xpack.apm.indices.error
- Matcher for indices containing error documents. Defaults to apm-*.
-
xpack.apm.indices.transaction
- Matcher for indices containing transaction documents. Defaults to apm-*.
-
xpack.apm.indices.onboarding
- Matcher for all onboarding indices. Defaults to apm-*.
-
xpack.apm.indices.metric
- Matcher for all metrics indices. Defaults to apm-*.
-
xpack.apm.indices.sourcemap
- Matcher for all source map indices. Defaults to apm-*.
-
xpack.apm.maxSuggestions
-
Maximum number of suggestions fetched in autocomplete selection boxes. Defaults to
100
-
xpack.apm.searchAggregatedTransactions
-
Whether to use metric instead of transaction documents to render the UI. Available options are
always
,never
orauto
. Defaults toauto
. -
xpack.apm.ui.maxTraceItems
-
Maximum number of child items displayed when viewing trace details.
Defaults to
1000
. Any positive value is valid. To learn more, check APM settings in Kibana. -
xpack.apm.ui.enabled
-
Set to
false
to disable X-Pack APM UI.
On this page
- Supported Kibana settings
- Version 8.12.0+
- Version 8.11.0+
- Version 8.9.0+
- Version 8.7.0+
- Version 8.6.0+
- Version 8.4.0+
- Version 8.3.0+
- Version 8.2.0+
- Version 8.1.0+
- Supported versions before 8.x
- All supported versions
- Map settings
- SAML settings
- Version 8.0.0+
- All supported versions
- All supported versions before 8.x
- OpenID Connect
- Anonymous authentication
- Supported versions before 8.0.0
- All supported versions
- X-Pack configuration settings
- Version 8.16+
- Version 8.8+
- Version 8.7+
- Version 8.6+
- Version 8.5+
- Version 8.3+
- Version 8.2+
- Version 8.1+
- Version 8.0+
- Version 7.17.4+, 8.3+
- Version 7.17.2+, 8.2+
- All supported versions
- Content security policy configuration
- Permissions policy configuration
- Banner settings
- Reporting settings
- Version 8.13.0+
- All supported versions
- Logging and audit settings
- Version 8.0+
- Supported 7.x versions
- All supported versions
- Version 8.15.0+
- APM
- Version 8.0.0+
- Version 7.16.0 to 8.6.2
- Version 7.16.0 to 8.0.0
- Supported versions before 8.x
- All supported versions
ElasticON events are back!
Learn about the Elastic Search AI Platform from the experts at our live events.
Register now