-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[Fleet] Honor index_mode: time_series
setting during package installation
#146804
Comments
Pinging @elastic/fleet (Team:Fleet) |
As this has not been release yet, it gives us some time to discuss the defaults. In Elasticsearch, What this means that in a package to use time_series and synthetic source, only time series needs to be enabled. This has an effect on #147034 as what the default behaviours are would change slightly as soon as this is implemented. @nchaulet @martijnvg @jpountz Curious to hear your thoughts on the above proposal to have for data streams we configure through packages, have synthetic source enabled by default for time_series data streams. |
@ruflin I think it makes sense that for time series data streams / indices that synthetic source is enabled by default. I think most of the time synthetic source will be enabled in this context. In cases where the downsides of synthetic source (losing accuracy in _source and higher costs in synthesising _source during fetch phase or get api) start to matter then for these cases users can opt out. I will open an issue in the ES repository. |
I've opened: elastic/elasticsearch#92319 |
Thanks for the input @martijnvg It seems no matter of the outcome of elastic/elasticsearch#92319 we can enable it for integrations by default. If ES has it eventually by default too, even better. |
@jlind23 let's make sure this is not pushed to sprint 6, please... it's a blocker for o11y |
We need to make sure that the issue mentioned in elastic/integrations#4749 (comment) is resolved as part of closing this issue. In general, I still find the location of this setting in the integration policy settings confusing for both our developers and users. The setting applies to all instances of the integration today and is not a policy-level setting, but that's not how it's exposed in our UI and API (someone should double check me on the API part). I would still prefer there at least be a separate API for setting these package-level settings, if not also a separate UI for it as well. I imagine it should be similar to the proposed API in the "Customize API" section from this issue description: #121118 |
++. I think API is a must to make it clear this is not a policy feature. UI we can figure out in a second step. |
So as part of this issue, we want to:
Can we move the API changes to a new issue? As it would increase the scope substantially, I think it is more important to solve the original issue first to unblock Observability. |
@juliaElastic I think this is fine assuming these aren't APIs that are exposed to users and changing these could be a breaking change. At the same time, I think it is important we address it quickly afterwards. I started to dig a bit into the code #147684 and I'm a bit concerned that not having the "data management" fully separate could lead to potential bugs. |
These settings are currently part of our generic
|
Thinking loud here, do we really need a new API to support these features or should we leverage more the |
I assume in this scenario, |
Yes the default behavior defined in the package will go in the managed component template, what I was think is more to replace the |
Using Long-term we need a way to optionally define a component template with overrides to meet the various granularity needs as discussed in #146792 (comment). If we go with the ES API approach, we would need to work out a way to define these templates later as well. Ideally the index template API's I do like how flexible and clean that would be over modifying the package-defined fields. However, the Fleet API still needs some way to expose this functionality to the user who may not have Elasticsearch access. I don't think the package_policy API is the right one since it applies to the whole package. I'd prefer to have something at the dataset level since the templates are dataset-level today. |
It's clearly not the right place. We could have a customize API in fleet where you can pass the level that you want to customize /integration/dataset/namespace and this would update the correct |
#148057 should be fixed as well, else this will be quite a useless feature. We need to be able to leverage TSDB on all of the supported field types. |
@kpollich @nchaulet What will happen if a package has |
Yes it will be ignored in 8.5, it will probably be applied somehow in 8.6 if the package policy is edited in the UI as there was some code in the UI forcing an experimental datastream feature if |
Ref elastic/integrations#4749
Ref #144974
If a data stream includes
index_mode: time_series
in a package manifest, it should have its mappings/settings updated appropriately to support TSDB. This is the same process called out for synthetic source in #141211.EDIT (Julia): To confirm the scope of this issue based on the discussion in the comments:
index_mode: time_series
is set in the package manifestsynthetic_source
withindex_mode: time_series
by default on package installationThe text was updated successfully, but these errors were encountered: