-
Notifications
You must be signed in to change notification settings - Fork 1.9k
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
Make some long running operations execute asynchronously and can be tracked by _tasks API #6228
Comments
I think it makes sense to have an asynchronous option for any potentially long running operation, and it also makes sense to have a consistent async experience across APIs. Therefore using the existing |
…nsearch-project#6228) Signed-off-by: Gao Binlong <[email protected]>
#6434) * Add wait_for_completion parameter to resize&open&forcemerge APIs (#6228) Signed-off-by: Gao Binlong <[email protected]> * Modify changelog Signed-off-by: Gao Binlong <[email protected]> * fix test failure Signed-off-by: Gao Binlong <[email protected]> * Fix test failure Signed-off-by: Gao Binlong <[email protected]> * change header of new file Signed-off-by: Gao Binlong <[email protected]> * modify changelog Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]>
opensearch-project#6434) * Add wait_for_completion parameter to resize&open&forcemerge APIs (opensearch-project#6228) Signed-off-by: Gao Binlong <[email protected]> * Modify changelog Signed-off-by: Gao Binlong <[email protected]> * fix test failure Signed-off-by: Gao Binlong <[email protected]> * Fix test failure Signed-off-by: Gao Binlong <[email protected]> * change header of new file Signed-off-by: Gao Binlong <[email protected]> * modify changelog Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]> (cherry picked from commit 3fec567) Modify the yaml test file Signed-off-by: Gao Binlong <[email protected]>
… forcemerge APIs (#6855) * Add wait_for_completion parameter to resize, open, and forcemerge APIs (#6434) * Add wait_for_completion parameter to resize&open&forcemerge APIs (#6228) Signed-off-by: Gao Binlong <[email protected]> * Modify changelog Signed-off-by: Gao Binlong <[email protected]> * fix test failure Signed-off-by: Gao Binlong <[email protected]> * Fix test failure Signed-off-by: Gao Binlong <[email protected]> * change header of new file Signed-off-by: Gao Binlong <[email protected]> * modify changelog Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]> (cherry picked from commit 3fec567) Modify the yaml test file Signed-off-by: Gao Binlong <[email protected]> * Modify package name Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]> Co-authored-by: Andrew Ross <[email protected]>
Close this issue as the related PR has been merged yet, @andrross thanks for your support, really appreciate it. |
opensearch-project#6434) * Add wait_for_completion parameter to resize&open&forcemerge APIs (opensearch-project#6228) Signed-off-by: Gao Binlong <[email protected]> * Modify changelog Signed-off-by: Gao Binlong <[email protected]> * fix test failure Signed-off-by: Gao Binlong <[email protected]> * Fix test failure Signed-off-by: Gao Binlong <[email protected]> * change header of new file Signed-off-by: Gao Binlong <[email protected]> * modify changelog Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]> Signed-off-by: Valentin Mitrofanov <[email protected]>
Is your feature request related to a problem? Please describe.
Currently, only reindex, update_by_query and delete_by_query operations can be tracked by the
_tasks
API, but there are some other long running operations such as shrink/split/clone/open/forcemerge cannot be tracked by_tasks
API, users have to wait until the operation is completed when they call shrink or split API. The problem is that we don't have an uniform way to check the status of all these long running operations, it's hard to monitor and manage these operations, and if we want to send notification to the users when these long running operations completes, we have to use different methods to check the status for different operations, which is tricky.Describe the solution you'd like
I think we can have an uniform way to manage all these long running operations, similar to
reindex
API, we can add a request parameterwait_for_completion
to shrink/split/clone/open/forcemerge APIs, when the parameter is set tofalse
, the API will return a taskId which can be used to check the status of the operation, and the task's result will be recorded into.tasks
index. Additionally, some operations may fail because of the settings or the performance of the cluster, so we can add another parameter liketask_execution_timeout
to set the task's status tofailed
when the timeout expires, this will reduce some cost of resource because we have to launch a single thread for each operation to check its status. For example, when shrink operation occurs, if some primary shards of the new shrunken index cannot be allocated because of hardware failure, after 1h or 2h, we set the task's status tofailed
and unregister the task.At least two benefits we can get if we implement this function:
Task Management
page which list all the running or completed tasks, if we implement this function, the frontend node server only need to call the_tasks
API to get all the running tasks..tasks
index, we can monitor the.task
index, if a new long running operation is completed or failed then we will send notification to the user.Describe alternatives you've considered
We have to use different method for each long operation to check it's progress, for reindex, we use
_tasks/{taskId}
API to check the status of the reindex operation; for shrink/split, we use the_recovery
API to check the status of all the shards of the new shrunken or split index; for force merge, we do not have a method to check it's progress currently.Additional context
This issue originates from #5479, the original idea is that we want to have a generic solution to send notification to users when the long running operation completes. After many internal discussion, we think we can make all the long operations can be tracked by
_tasks
API firstly, then we will have an uniform way to get every operation's result and then send notification. But as said above, this function will also benefit the future feature likeTask Management
page in OpenSearch-Dashboards.The text was updated successfully, but these errors were encountered: