Я нашел несколько ссылок в руководстве MongoDB, которые решили мой собственный вопрос.
Какой тип блокировки использует MongoDB?
MongoDB использует многофакторную блокировку 1 , которая позволяет блокировать операции на глобальном уровне, уровне базы данных или коллекции, а также позволяет отдельным механизмам хранения реализовать собственный контроль параллелизма ниже уровня сбора (например, при уровень документа в WiredTiger).
MongoDB использует несколько уровней блокировки от коллекции, базы данных, затем к глобальной. Однако, хотя он поддерживает несколько уровней блокировки, единственный доступный уровень - это уровень коллекции, означает, что вы не можете создавать или удалять базы данных или коллекции в транзакциях. Это также означает, что получение одного документа заблокирован в коллекции приведет к блокировке всей коллекции.
Запрещенные операции
Следующие операции не разрешены в многодокументных транзакциях:
Операции, которые влияют на каталог базы данных, такие как создание или удаление коллекции или индекса. Например, многодокументная транзакция не может включать операцию вставки, которая привела бы к созданию новой коллекции.
Команды listCollections и listIndexes и их вспомогательные методы также исключаются.
Не CRUD и неинформационные операции, такие как createUser, getParameter, count и т. Д. И их помощники.
Для разрешения конфликтов MongoDB отправляет сообщения об ошибках посетителю, который не может получить блокировку при возникновении конфликта.
Повторить транзакцию
Отдельные операции записи внутри
транзакция не повторяется, независимо от того, является ли retryWrites
установить на true
.
Если операция обнаруживает ошибку, возвращаемая ошибка может иметь
Поле массива errorLabels. Если ошибка является временной ошибкой,
Поле массива errorLabels содержит «TransientTransactionError» как
элемент и транзакция в целом могут быть повторены.
Значение, когда посетитель получает MongoException
, а исключение .hasErrorLabel(MongoException.TRANSIENT_TRANSACTION_ERROR_LABEL)
, , посетитель должен закрыть сеанс и отменить транзакцию . Посетитель должен повторить и подтвердить, пока фиксация не будет успешной.
Вы можете просто использовать этот метод (модифицированный из ручного примера):
public static <T> T transactWithRetry(Callable<T> transactional) throws Exception {
while (true) {
try {
return transactional.call();
} catch (MongoException ex) {
if (!ex.hasErrorLabel(MongoException.TRANSIENT_TRANSACTION_ERROR_LABEL)) throw ex;
}
}
}
Дополнительные издания см. В руководствах ;)!
Ссылки
Транзакции & mdash; MongoDB Manual
FAQ: параллелизм & mdash; MongoDB Manual