Przenoszenie danych między projektami

Na tej stronie dowiesz się, jak korzystać z funkcji zarządzanego importu i eksportu, aby przenosić dane Cloud Firestore z jednego projektu do drugiego. Może to być przydatne podczas konfigurowania środowiska programistycznego lub w ramach trwałej migracji aplikacji do innego projektu. Przykład na tej stronie pokazuje, jak wyeksportować dane z projektu źródłowego, a następnie zaimportować je do projektu docelowego. Przenoszenie danych między projektami obejmuje te kroki:

  1. Utwórz zasobnik Cloud Storage, w którym będą przechowywane dane z projektu źródłowego.
  2. Wyeksportuj dane z projektu źródłowego do zasobnika.
  3. Przyznaj projektowi docelowemu uprawnienia do odczytu z zasobnika.
  4. Zaimportuj dane z zasobnika do projektu docelowego.

Zanim zaczniesz

Zanim zaczniesz korzystać z usługi zarządzanego eksportu i importu, musisz wykonać te czynności:

  1. Włącz płatności w projekcie źródłowym i docelowym. Tylko projekty Google Cloud z włączonymi płatnościami mogą korzystać z funkcji eksportowania i importowania.
  2. Upewnij się, że Twoje konto ma wymagane uprawnienia Cloud IAM w projekcie źródłowym i docelowym. Jeśli jesteś właścicielem obu projektów, Twoje konto ma wymagane uprawnienia. W przeciwnym razie te role Cloud IAM przyznają niezbędne uprawnienia do Cloud Firestore operacji eksportu i importu:

    Owner, Cloud Datastore Owner lub Cloud Datastore Import Export Admin

    Właściciel projektu może przyznać jedną z tych ról, wykonując czynności opisane w artykule Udzielanie dostępu.

  3. Skonfiguruj narzędzie wiersza poleceń gcloud i połącz się z projektem na jeden z tych sposobów:

  4. Skonfiguruj indeksy w nowym projekcie. Indeksy złożone powinny być zgodne w projektach źródłowym i docelowym. Indeksy należy skonfigurować w pierwszej kolejności, aby uniknąć wielokrotnego przetwarzania każdego dokumentu.

Eksportowanie danych z projektu źródłowego

Wyeksportuj dane, tworząc Cloud Storagezasobnik na pliki eksportuCloud Firestore i rozpoczynając operację eksportowania.

Utwórz zasobnik Cloud Storage

Utwórz zasobnikCloud Storage w tej samej lokalizacji co baza danych Cloud Firestore. Aby wyświetlić lokalizację bazy danych, sprawdź ustawienia lokalizacji projektu. Nie możesz używać zasobnika „Płatnik żąda” do operacji eksportu i importu.

Jeśli zasobnik Cloud Storage nie znajduje się wprojekcie źródłowym, musisz przyznać domyślnemu kontu usługi projektu źródłowego dostęp do zasobnika. Każdy Google CloudprojektGoogle Cloud ma automatycznie utworzone domyślne konto usługi o nazwie PROJECT_ID@appspot.gserviceaccount.com. Cloud Firestore Operacje eksportu używają tego domyślnego konta usługi do autoryzacji operacji na Cloud Storage zasobnikach. Aby przyznać domyślnemu kontu usługi dostęp do zasobnika źródłowego, przypisz mu rolę Storage Admin.

Możesz przyznać tę rolę za pomocą gsutilnarzędzia dostępnego w Cloud Shell:

Rozpocznij Cloud Shell

gsutil iam ch serviceAccount:[service-PROJECT_NUMBER]@gcp-sa-firestore.iam.gserviceaccount.com :roles/storage.admin\
gs://[BUCKET_NAME]@

Tę rolę możesz też przyznać w Google Cloudkonsoli.

Wyłącz operacje zapisu (opcjonalnie)

Jeśli aplikacja nadal zapisuje dane w bazie danych podczas eksportowania, w plikach eksportu mogą nie zostać uwzględnione wszystkie te zapisy. Aby wyeksportować dane w spójnym stanie, wyłącz zapisywanie w bazie danych, aktualizując reguły zabezpieczeń i wstrzymując wszystkie operacje pakietu Admin SDK.

  1. Zaktualizuj reguły zabezpieczeń

    Na karcie Cloud Firestore Reguły w konsoli zaktualizuj reguły zabezpieczeń projektu źródłowego, aby odrzucać wszystkie operacje zapisu. Przykład:

      // Deny write access to all users under any conditions
      service cloud.firestore {
        match /databases/{database}/documents {
          match /{document=**} {
            allow write: if false;
          }
          // Reads do not affect export operations
          // Add your read rules here
        }
      }
    
  2. Wstrzymywanie zapisów z pakietów Admin SDK

    Reguły zabezpieczeń nie blokują zapisów pochodzących z uprzywilejowanych środowisk serwera utworzonych za pomocą pakietu Firebase Admin SDK lub biblioteki klienta serwera Google Cloud. Zatrzymaj operacje zapisu na serwerach administracyjnych, wyłączając lub aktualizując serwery.

Rozpoczynanie eksportowania

Użyj polecenia gcloud firestore export, aby wyeksportować dane z projektu źródłowego. Możesz wyeksportować wszystkie dane lub tylko określone grupy zbiorów. Zastąp [SOURCE_BUCKET] nazwą zasobnika Cloud Storage:

Eksportowanie wszystkich danych
gcloud firestore export gs://[SOURCE_BUCKET] --async
Eksportowanie określonych grup kolekcji
gcloud firestore export gs://[SOURCE_BUCKET] --collection-ids=[COLLECTION_GROUP_ID_1],[COLLECTION_GROUP_ID_2] --async

Zapisz outputURIPrefix operacji eksportu, ponieważ będzie on potrzebny później. Domyślnie Cloud Firestore dodaje do wyeksportowanych plików prefiks na podstawie sygnatury czasowej:

outputUriPrefix: gs://[SOURCE_BUCKET]/2019-03-05T20:58:23_56418

Podczas wykonywania operacji eksportowania możesz użyć polecenia firestore operations list, aby wyświetlić postęp operacji:

gcloud firestore operations list

Importowanie danych do projektu docelowego

Następnie przyznaj docelowemu projektowi dostęp do plików danych Cloud Firestore i rozpocznij operację importowania.

Przyznaj projektowi docelowemu dostęp do plików danych.

Zanim rozpoczniesz operację importowania, musisz się upewnić, że projekt docelowy ma dostęp do Cloud Firestoreplików danych.

Przenoszenie plików danych do lokalnego zasobnika

Jeśli lokalizacja zasobnika źródłowego jest inna niż lokalizacja projektu docelowegoCloud Firestore, musisz przenieść pliki danych do zasobnikaCloud Storage w tej samej lokalizacji co projekt docelowy.

Przenieś pliki danych do innego Cloud Storage zasobnika, wykonując czynności opisane w artykule Przenoszenie i zmienianie nazwy zasobników. We wszystkich kolejnych krokach używaj tego nowego zasobnika jako [SOURCE_BUCKET].

Przyznaj kontu usługi projektu dostęp do zasobnika źródłowego

Jeśli zasobnik źródłowy nie znajduje się w projekcie docelowym, musisz przyznać domyślnemu kontu usługi projektu docelowego dostęp do zasobnika źródłowego. Domyślne konto usługi ma nazwę [DESTINATION_PROJECT_ID]@appspot.gserviceaccount.com. Aby przyznać domyślnemu kontu usługi dostęp do zasobnika źródłowego, przyznaj mu odpowiednie uprawnienia dostępu do zasobnika.

Możesz przyznać niezbędne role za pomocą gsutilnarzędzia dostępnego w Cloud Shell:

Rozpocznij Cloud Shell

gsutil iam ch serviceAccount:[DESTINATION_PROJECT_ID]@appspot.gserviceaccount.com:legacyBucketReader,legacyObjectReader \
gs://[SOURCE_BUCKET]

Tę rolę możesz też przyznać w Google Cloudkonsoli.

Rozpoczynanie operacji importu

Zanim rozpoczniesz importowanie, upewnij się, że gcloud jest skonfigurowany dla właściwego projektu:

gcloud config set project [DESTINATION_PROJECT_ID]

Aby zaimportować dane z zasobnika źródłowego do projektu docelowego, użyj polecenia gcloud firestore import:

gcloud firestore import gs://[SOURCE_BUCKET]/[EXPORT_PREFIX] --async

gdzie [EXPORT_PREFIX] odpowiada prefiksowi w operacji eksportowania outputUriPrefix. Przykład:

gcloud firestore import gs://[SOURCE_BUCKET]/2019-03-05T20:58:23_56418 --async

Podczas wykonywania operacji eksportowania możesz użyć polecenia firestore operations list, aby wyświetlić postęp operacji:

gcloud firestore operations list