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

IGNITE-23655 Introduce CacheIdleVerifyCancelCommand #11673

Merged
merged 47 commits into from
Jan 13, 2025

Conversation

vladnovoren
Copy link
Contributor

Thank you for submitting the pull request to the Apache Ignite.

In order to streamline the review of the contribution
we ask you to ensure the following steps have been taken:

The Contribution Checklist

  • There is a single JIRA ticket related to the pull request.
  • The web-link to the pull request is attached to the JIRA ticket.
  • The JIRA ticket has the Patch Available state.
  • The pull request body describes changes that have been made.
    The description explains WHAT and WHY was made instead of HOW.
  • The pull request title is treated as the final commit message.
    The following pattern must be used: IGNITE-XXXX Change summary where XXXX - number of JIRA issue.
  • A reviewer has been mentioned through the JIRA comments
    (see the Maintainers list)
  • The pull request has been checked by the Teamcity Bot and
    the green visa attached to the JIRA ticket (see TC.Bot: Check PR)

Notes

If you need any help, please email [email protected] or ask anу advice on http://asf.slack.com #ignite channel.

@nizhikov nizhikov changed the title IGNITE-23655 CacheIdleVerifyCancelCommand v1. IGNITE-23655 Introduce CacheIdleVerifyCancelCommand Nov 28, 2024
/**
* Cancels idle_verify command.
*/
public class CacheIdleVerifyCancelCommand implements ComputeCommand<NoArg, Void>, Serializable {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Whe command implement Serializable?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

removed


/** {@inheritDoc} */
@Override public String description() {
return "Cancels idle_verify command.";
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please, remove, dot in the end of line.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

removed


/** {@inheritDoc} */
@Override protected Void run(NoArg arg) {
if (idleVerifyId().isPresent())
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can be replaced with ifPresent

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

refactored


int idleVerifyCnt = 0;

for (ComputeTaskView view : srv.context().systemView().<ComputeTaskView>view(TASKS_VIEW)) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

System view are local.
Let's iterate started servers and check them all.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

checked all servers

for (int i = 0; i < 100000; i++)
cache.put(i, i);

new Thread(() -> execute("--cache", "idle_verify") ).start();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

--cache idle_verify don't return while command ends?
If yes, we need to do the following:

  1. Start with GridTestUtils.runAsync which returns Future.
  2. Check future not done.
  3. Cancel command.
  4. Check future done.
  5. Other checks for all servers.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

refactored

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. Check future done.

AFAICS this not implemented.

@nizhikov
Copy link
Contributor

nizhikov commented Dec 5, 2024

We have some tests that check ./control.sh --help output.
Don't see changes in those tests.

Did you got bot visa for this PR?


srv.cluster().state(ACTIVE);

IgniteCache<Integer, Integer> cache = srv.createCache(DEFAULT_CACHE_NAME);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Default backup count are 0.
Which means idle_verify will run on one node only.
Let's configure gridsCnt == CacheConfiguration.backup == 3 in this test.

…er task views (it seems to be unnecessary). Added log listener and it fails.
}
});

List<LogListener> listeners = registerIdleVerifyCancelListeners();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks like registering and checking listeners can be moved to cancelIdleVerifyAndCheck

@@ -396,7 +396,6 @@ private class AskNeighbor extends GetPageHandler<Get> {
private final PageHandler<Get, Result> search;

/**
*
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we really need this change?

nizhikov and others added 25 commits January 9, 2025 15:32
Copy link

Quality Gate Failed Quality Gate failed

Failed conditions
5 New Code Smells (required ≤ 1)

See analysis details on SonarQube Cloud

Catch issues before they fail your Quality Gate with our IDE extension SonarQube for IDE

@nizhikov nizhikov merged commit 720c78a into apache:master Jan 13, 2025
8 of 9 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants