Skip to content

Commit

Permalink
Create a logs@custom index template reference (#3593)
Browse files Browse the repository at this point in the history
  • Loading branch information
mdbirnstiehl authored Feb 20, 2024
1 parent f284e93 commit ecf1c57
Show file tree
Hide file tree
Showing 3 changed files with 75 additions and 2 deletions.
2 changes: 2 additions & 0 deletions docs/en/observability/index.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,8 @@ include::inspect-log-anomalies.asciidoc[leveloffset=+3]

include::configure-logs-sources.asciidoc[leveloffset=+3]

include::logs-index-template.asciidoc[leveloffset=+2]

include::logs-troubleshooting.asciidoc[leveloffset=+2]

// Infrastructure
Expand Down
12 changes: 10 additions & 2 deletions docs/en/observability/logs-checklist.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -104,11 +104,19 @@ The following resources provide information on viewing and monitoring your logs:
== Application logs

Application logs provide valuable insight into events that have occurred within your services and applications.
See <<application-logs>>.
Refer to <<application-logs>>.

[discrete]
[[logs-alerts-checklist]]
== Create a logs threshold alert

You can create a rule to send an alert when the log aggregation exceeds a threshold.
See <<logs-threshold-alert>>.

Refer to <<logs-threshold-alert>>.

[discrete]
[[logs-template-checklist]]

Configure the default `logs` template using the `logs@custom` component template.

Refer to the <<logs-index-template>>.
63 changes: 63 additions & 0 deletions docs/en/observability/logs-index-template.asciidoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
[[logs-index-template]]
= Logs index template reference

Index templates are used to configure the backing indices of data streams as they're created.
These index templates are composed of multiple {ref}/indices-component-template.html[component templates]—reusable building blocks
that configure index mappings, settings, and aliases.

You can view the default `logs` index template in {kib}.
Navigate to **{stack-manage-app}** → **Index Management** → **Index Templates**, and search for `logs`.
Select the `logs` index templates to view relevant component templates.

[discrete]
[[custom-logs-template-edit]]
== Edit the `logs` index template

The default `logs` index template for the `logs-*-*` index pattern is composed of the following component templates:

* `logs@mappings`
* `logs@settings`
* `logs@custom`
* `ecs@mappings`

You can use the `logs@custom` component template to customize your {es} indices. The `logs@custom` component template is not installed by default, but you can create a component template named `logs@custom` to override and extend default mappings or settings. To do this:

. Open {kib} and navigate to **{stack-manage-app}** → **Index Management** → **Component Templates**.
. Click *Create component template*.
. Name the component template logs@custom.
. Add any custom metadata, index settings, or mappings.

Changes to component templates are not applied retroactively to existing indices. For changes to take effect, create a new write index for impacted data streams by triggering a rollover. Do this using the {es} {ref}/indices-rollover-index.html[Rollover API]. For example, to roll over the `logs-generic-default` data stream, run:

[source,console]
----
POST /logs-generic-default/_rollover/
----

[discrete]
[[custom-logs-template-default-field]]
=== Set the `default_field` using the custom template

The `logs` index template uses `default_field: [*]` meaning queries without specified fields will search across all fields.
You can update the `default_field` to search in the `message` field instead of all fields using the `logs@custom` component template.

If you haven't already created the `logs@custom`component template, create it as outlined in the previous section. Then, follow these steps to update the *Index settings* of the component template:

. Open {kib} and navigate to **{stack-manage-app}** → **Index Management** → **Component Templates**.
. Search for `logs` and find the `logs@custom` component template.
. Open the **Actions** menu and select **Edit**.
. Select **Index settings** and add the following code:
+
[source,json]
----
{
"index": {
"query": {
"default_field": [
"message"
]
}
}
}
----
. Click **Next** through to the **Review** page and save the component template.

0 comments on commit ecf1c57

Please sign in to comment.