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

Add warnings about cloning index templates #1408

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

kilfoyle
Copy link
Contributor

@kilfoyle kilfoyle commented Oct 24, 2024

As part of #1395, this updates the Best practices for integration assets page to add new warnings.

@lucabelluccini one question: i've added the warning about "Cloning the index template of an integration package" as suggested in the issue, but isn't this kind of repeating what's already covered in the warning about Copying Fleet and Elastic Agent integration assets?

Anyhow, please let me know whatever changes we might need.

Closes: #1395


Screenshot 2024-10-24 at 4 10 43 PM

Copy link

A documentation preview will be available soon.

Request a new doc build by commenting
  • Rebuild this PR: run docs-build
  • Rebuild this PR and all Elastic docs: run docs-build rebuild

run docs-build is much faster than run docs-build rebuild. A rebuild should only be needed in rare situations.

If your PR continues to fail for an unknown reason, the doc build pipeline may be broken. Elastic employees can check the pipeline status here.

@kilfoyle
Copy link
Contributor Author

@elasticmachine run docs-build

@lucabelluccini
Copy link
Contributor

@lucabelluccini one question: i've added the warning about "Cloning the index template of an integration package" as suggested in the issue, but isn't this kind of repeating what's already covered in the warning about Copying Fleet and Elastic Agent integration assets?

No, it's not the same thing - let me expand.

A very common task for users is to customize the ILM policy.

Customizing the ILM policy for integration data streams should be done just using the @custom component template of a specific data stream.
Example: I want metrics-elastic_agent.metricbeat* data streams to have an ILM policy which deletes data after 1 day?
I create metrics-elastic_agent.metricbeat@custom component template, I add the ILM policy in its setting and I rollover. The metrics-elastic_agent.metricbeat@custom will be picked up automatically by the default Index Template of the integration.

Unfortunately, we dedicate a whole page to how to customize the ILM policy of a namespace specific data stream (here).
This is an even more power-user use-case, where the customer uses separate namespaces for their data streams.
But it seems users see this as the "default" way of customizing ILM policies.

The technique of cloning the index templates to make them namespace specific is known to lead to possible problems on stack upgrades which introduce major changes to the index templates.
We have a major issue on ES side on how to make those customizations without the need of cloning index templates elastic/elasticsearch#97664 (comment).

So my recommendation with this doc PR is:

  • If the user just wants to change the ILM Policy or the number of shards (or other stuff) for the datastreams of one or more integrations, but they do not need to be namespace specific, then we should promote the use of the <package>@custom component template. This usually is fine and doesn't interfere in upgrades (except if users start to use it for heavy customizations). This should be the PROMINENT/MOST ADVERTISED option as it's likely to generate less problems to users.
  • If the user wants to change the ILM Policy or the number of shards (or other stuff) for the datastreams of one or more integrations, but they really need to be namespace specific, then we can recommend what we say in this doc page.

@lucabelluccini
Copy link
Contributor

I've read the changes you've done @kilfoyle and they seem excellent.

I would rework the part we've mentioned in #1408 (comment)

@kilfoyle
Copy link
Contributor Author

kilfoyle commented Oct 30, 2024

Thanks for the explanation @lucabelluccini! Sorry it took me a while to circle back to this PR.

screen2


  • In the "Customize data retention policies" tutorial, the cloning happens in Step 3, so there I've added in similar guidance with the two different options you mentioned:

screen


Please let me know whatever needs fixing up.

@kilfoyle
Copy link
Contributor Author

Hi @lucabelluccini When you have a few minutes, please let me know if the latest changes (in red above) look okay. Thanks!

@lucabelluccini
Copy link
Contributor

Hello @kilfoyle

In the "Customize data retention policies" tutorial, the cloning happens in Step 3, so there I've added in similar guidance with the two different options you mentioned:

IMHO it is still a trap. This cannot be something in a info box.

To just customize the ILM policies of a data stream regardless of a namespace (which is likely 95% of cases), it would be enough to just follow the step 2 of https://www.elastic.co/guide/en/fleet/current/data-streams-ilm-tutorial.html#data-streams-ilm-two

Instead, we're "suggesting" customers to clone the index template and then create a component template, which is only necessary if someone wants to customize something at a namespace level.

The page should be split into 2 separate sections:

  • How to customize ILM policy for a data stream belonging to an integration: simple case, 95% of situations, just create/edit the <package>@custom component template and add the ILM policy.
  • How to customize ILM policies for a data stream belonging to an integration for a specific namespace: advanced case, 5% of situations, steps as they're described now

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
2 participants