AccountsUpdate: Clarify how eviction and reindex is done, and how it can be disabled

There are 2 places that take care about evicting and reindexing accounts
after an account update:

- ReindexAfterRefUpdate if the user branch is touched
- ExternalIdNotes if external IDs are updated (needed because external
  ID updates don't touch the user branch)

This means to disable eviction and reindexing two things need to be
done:

- bind GitReferenceUpdated#DISABLED
- create AccountsUpdate with ExternalIdNotes.FactoryNoReindex

The JavaDoc of AccountsUpdate wasn't precise about this.

Change-Id: I62e5d8cea4da4b94435f57b590cf5f0b2fa781b3
Signed-off-by: Edwin Kempin <ekempin@google.com>
This commit is contained in:
Edwin Kempin
2018-03-12 10:33:38 +01:00
parent ba6851811a
commit 05c36a0ad0

View File

@@ -92,11 +92,21 @@ import org.eclipse.jgit.lib.Repository;
* *
* <p>On updating an account the account is evicted from the account cache and thus reindexed. The * <p>On updating an account the account is evicted from the account cache and thus reindexed. The
* eviction from the account cache is done by the {@link ReindexAfterRefUpdate} class which receives * eviction from the account cache is done by the {@link ReindexAfterRefUpdate} class which receives
* the event about updating the user branch that is triggered by this class. By passing an {@link * the event about updating the user branch that is triggered by this class.
* com.google.gerrit.server.account.externalids.ExternalIdNotes.FactoryNoReindex} factory as *
* parameter of {@link AccountsUpdate.Factory#create(IdentifiedUser, ExternalIdNotesLoader)}, * <p>If external IDs are updated, the ExternalIdCache is automatically updated by {@link
* reindexing and flushing the account from the account cache can be disabled. If external IDs are * ExternalIdNotes}. In addition {@link ExternalIdNotes} takes care about evicting and reindexing
* updated, the ExternalIdCache is automatically updated. * corresponding accounts. This is needed because external ID updates don't touch the user branches.
* Hence in this case the accounts are not evicted and reindexed via {@link ReindexAfterRefUpdate}.
*
* <p>Reindexing and flushing accounts from the account cache can be disabled by
*
* <ul>
* <li>binding {@link GitReferenceUpdated#DISABLED} and
* <li>passing an {@link
* com.google.gerrit.server.account.externalids.ExternalIdNotes.FactoryNoReindex} factory as
* parameter of {@link AccountsUpdate.Factory#create(IdentifiedUser, ExternalIdNotesLoader)}
* </ul>
* *
* <p>If there are concurrent account updates updating the user branch in NoteDb may fail with * <p>If there are concurrent account updates updating the user branch in NoteDb may fail with
* {@link LockFailureException}. In this case the account update is automatically retried and the * {@link LockFailureException}. In this case the account update is automatically retried and the