Заблокирован ли документ Firestore при чтении сервером (облачная функция) в транзакции? - PullRequest
4 голосов
/ 05 июня 2019

Я знаю, что Firestore использует блокировки для Транзакций в СЕРВЕРЕ (облачные функции), как объясняется в этом видео: https://www.youtube.com/watch?v=dOVSr0OsAoU

Видео подробно объясняет, как Транзакции работают в КЛИЕНТЕ (и он не используетблокируется там), но не делает такую ​​хорошую работу для транзакций SERVER.

Что из этого верно (о транзакциях SERVER) ?:

1) Документ заблокирован get s в Транзакции на сервере, поэтому другие Транзакции на сервере не могут get сделать это до завершения первой Транзакции.

2) Документ заблокирован get s в транзакции сервера, но только для записей, так что другие транзакции сервера могут получить его, но не изменить его до завершения первой транзакции.

3) Документ НЕ заблокирован get s в транзакции сервера, только запись.

РЕДАКТИРОВАТЬ: Мне нужны авторитетные источники (документация или некоторые ссылки ввидео или блоги от кого-то из команды Firebase).

Ответы [ 2 ]

3 голосов
/ 10 июня 2019

Транзакции на стороне сервера в целом работают подобно клиентским библиотекам, но вместо этой модели параллелизма, упомянутой в этом видео, работают традиционным способом блокировки данных.Поэтому даже если вы используете транзакцию для одного документа или запроса, эти документы будут заблокированы до завершения транзакции.

Чтобы ответить на ваш вопрос, поскольку транзакция, поступающая из облачной функции, принимаетвнутренне (может занять несколько миллисекунд), документы блокируются на это время.Это означает, что эти документы не могут быть приняты или изменены никакими другими транзакциями.

1) Документ блокируется при получении транзакции на сервере, поэтому другие транзакции на сервере не могут получить его до первой транзакции.Закончено.

Правильно.

2) Документ блокируется при получении транзакции на сервере, но только для записей, так что другие транзакции на сервере могут получить его, ноне изменяйте его до завершения первой транзакции.

Для другой транзакции не имеет смысла получать заблокированный документ.Зачем пытаться получить такой документ, поскольку его нельзя изменить?Более того, заблокированный документ может иметь к моменту завершения транзакции разные значения.Между началом транзакции и ее завершением изменяются некоторые свойства в документе.

3) Документ НЕ блокируется при получении транзакции на сервере, только запись.

Документ блокируется, как только облачная функция запускает транзакцию, и блокировка снимается, когда транзакция завершается.

Редактировать:

Itимеет смысл для другой транзакции получить заблокированный документ.Это не может быть изменено, но если это можно прочитать

Я имел в виду строго с точки зрения письменности.Все документы могут быть прочитаны, независимо от того, заблокирован документ или нет.

, если вы просто хотите прочитать значение

Если вы просто хотите прочитать значение, здесь не о чем беспокоиться.При чтении документов нет блокировок.

Возможно, вам нужно прочитать какое-то значение, чтобы принять решение об изменении другого документа или даже просто показать некоторую информацию пользователю.

Он будет отлично работать.

Также, в зависимости от транзакции, вам все равно, изменится ли документ в течение следующей секунды.Например, если пользователь хочет узнать сумму денег на своем банковском счете, вы можете отобразить значение за одну секунду до этого, без проблем.

Да, это правильно.Там нет никаких ограничений, когда речь идет об операциях чтения и в отношении вашего примера, да, это нормально.Это также работает в одном из моих проектов.

Не могли бы вы указать мне их источники?

Есть много ресурсов, которые объясняют, как традиционный способ блокировкиданные работают.Транзакции на стороне сервера работают таким образом, как подтвердил Тодд Керпельман в понравившемся видео.Цель этой блокировки - обслуживать и защищать общие ресурсы (документы).

Мне действительно нужно быть в этом абсолютно уверенным, поэтому мне нужны источники или кто-то из команды Firebase, подтверждающий их.

Будем также надеяться, что кто-то из команды Firebase найдет время и взглянет на это, но я не уверен, что понимаю, что вас беспокоит?Вы думаете, что во время транзакции вы не сможете читать документы?Или

0 голосов
/ 05 июня 2019

Согласно документации Firestore относительно Транзакций и Пакетных записей ,

Транзакция состоит из любого количества операций get(), за которыми следует любое количество операций записи, таких как set(), update() или delete(). В случае одновременного редактирования Cloud Firestore снова запускает всю транзакцию. Например, если транзакция читает документы, а другой клиент изменяет какой-либо из этих документов, Cloud Firestore повторяет транзакцию. Эта функция гарантирует, что транзакция выполняется на актуальных и согласованных данных.

Заключение : документ не заблокирован get() s в транзакции сервера. Но когда документ изменяется другой транзакцией после того, как он равен get() в текущей транзакции, будет повторяться попытка текущей транзакции, так что обновленный документ снова будет get().

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...