Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

_tier_preference docs changes for 7.16 #81401

Merged
merged 6 commits into from
Dec 7, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,8 @@ To switch to using node roles:
settings>> from your {ilm} policy.
. <<stop-setting-custom-hot-attribute, Stop setting the custom hot attribute>>
on new indices.
. <<enforce-default-tier-preference, Enforce a default tier preference>>
on new indices.
. Update existing indices to <<set-tier-preference, set a tier preference>>.


Expand Down Expand Up @@ -136,9 +138,29 @@ DELETE _template/.cloud-hot-warm-allocation-0

If you're using a custom index template, update it to remove the <<shard-allocation-filtering, attribute-based allocation filters>> you used to assign new indices to the hot tier.

[discrete]
[[enforce-default-tier-preference]]
==== Enforce a default tier preference on new indices

Setting <<enforcing-a-default-tier-preference,`cluster.routing.allocation.enforce_default_tier_preference`>> to `true`
ensures that newly created indices will have a <<tier-preference-allocation-filter,_tier_preference>>, overriding the
<<indices-create-index,create index>> API or an associated <<index-templates,index template>>, if either of those
specifies `null` for the setting.

[source,console]
----
PUT _cluster/_settings
{
"persistent": {
"cluster.routing.allocation.enforce_default_tier_preference": true
}
}
----
// TEST[continued]

[discrete]
[[set-tier-preference]]
==== Set a tier preference for existing indices.
==== Set a tier preference for existing indices

{ilm-init} automatically transitions managed indices through the available
data tiers by automatically injecting a <<ilm-migrate,migrate action>>
Expand All @@ -148,7 +170,7 @@ To enable {ilm-init} to move an _existing_ managed index
through the data tiers, update the index settings to:

. Remove the custom allocation filter by setting it to `null`.
. Set the <<data-tier-shard-filtering,tier preference>>.
. Set the <<tier-preference-allocation-filter,tier preference>>.

For example, if your old template set the `data` attribute to `hot`
to allocate shards to the hot tier, set the `data` attribute to `null`
Expand Down
9 changes: 5 additions & 4 deletions docs/reference/ilm/apis/migrate-to-data-tiers.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,13 @@ Migrating away from custom node attributes routing can be manually performed
as indicated in the <<migrate-index-allocation-filters, Migrate index allocation
filters to node roles>> page.

This API provides an automated way of executing three out of the four manual steps listed
in the <<data-tier-migration, migration guide>>:
This API provides an automated way of executing four out of the five manual steps listed
in the <<migrate-index-allocation-filters, migration guide>>:

. <<stop-setting-custom-hot-attribute, Stop setting the custom hot attribute on new indices>>
. <<remove-custom-allocation-settings, Remove custom allocation settings from existing {ilm-init} policies>>
. <<set-tier-preference, Replace custom allocation settings from existing indices>> with the corresponding <<data-tier-shard-filtering,tier preference>>
. <<enforce-default-tier-preference, Enforce a default tier preference on new indices>>
. <<set-tier-preference, Replace custom allocation settings from existing indices>> with the corresponding <<tier-preference-allocation-filter,tier preference>>

[[ilm-migrate-to-data-tiers-request]]
==== {api-request-title}
Expand Down Expand Up @@ -137,4 +138,4 @@ If the request succeeds, a response like the following will be received:
<1> Shows the name of the legacy index template that was deleted. This will be missing
if no legacy index template was deleted.
<2> The ILM policies that were updated.
<3> The indices that were migrated to <<data-tier-shard-filtering,tier preference>> routing.
<3> The indices that were migrated to <<tier-preference-allocation-filter,tier preference>> routing.
18 changes: 18 additions & 0 deletions docs/reference/modules/cluster/misc.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -201,3 +201,21 @@ left the cluster, for example), are impacted by this setting.
This setting controls how often assignment checks are performed to react to
these factors. The default is 30 seconds. The minimum permitted value is 10
seconds.


[[enforcing-a-default-tier-preference]]
===== Enforcing a default _tier_preference

Newly created indices have <<tier-preference-allocation-filter, `index.routing.allocation.include._tier_preference`>>
automatically assigned <<data-tier-allocation, by default>>.
This can be overridden by setting the `_tier_preference` to `null`
via the <<indices-create-index,create index>> API or using an <<index-templates,index template>>.

In 8.0, it will not be possible to bypass this behavior by setting the
`_tier_preference` to `null` -- all newly created indices will always
have an associated `_tier_preference`.

`cluster.routing.allocation.enforce_default_tier_preference`::
(<<dynamic-cluster-setting,Dynamic>>)
Enforce that newly created indices must always have a non-null `_tier_preference`,
bypassing request or template settings. Defaults to `false`.