Storage Transfer Service supporta il trasferimento di file o oggetti specifici, specificati utilizzando un manifest. Un manifest è un file CSV, caricato su Cloud Storage, che contiene un elenco di file o oggetti su cui Storage Transfer Service deve agire.
Un manifest può essere utilizzato per i seguenti trasferimenti:
Da AWS S3, spazio di archiviazione compatibile con S3, Azure Blobstore o Cloud Storage a un bucket Cloud Storage.
Da un file system a un bucket Cloud Storage.
Da un bucket Cloud Storage a un file system.
Tra due file system.
Da un'origine HTTP/HTTPS accessibile pubblicamente a un bucket Cloud Storage. Segui le istruzioni riportate in Creare un elenco di URL, poiché il formato del manifest è univoco per gli elenchi di URL.
Creare un manifest
I file manifest hanno i seguenti requisiti:
- I manifest devono essere formattati come CSV.
- Possono contenere qualsiasi carattere UTF-8.
- La prima colonna deve essere un nome file o un nome oggetto. Il nome è relativo a percorso root o al bucket e alla cartella specificati nel job di trasferimento. Per i dettagli, consulta Trasferimenti di file system e Trasferimenti di archiviazione di oggetti.
- I file manifest non supportano i caratteri jolly. I nomi delle cartelle senza un nome file o oggetto non sono supportati.
- Se un nome file o oggetto contiene una virgola, il nome deve essere racchiuso tra virgolette doppie. Ad esempio,
"doe,john.txt". - Non esiste un limite alla dimensione del file manifest.
Ti consigliamo di testare il trasferimento con un piccolo sottoinsieme di file o oggetti per evitare chiamate API non necessarie a causa di errori di configurazione.
Puoi monitorare lo stato dei trasferimenti di file dalla pagina Job di trasferimento. I file o gli oggetti di cui non è stato eseguito il trasferimento sono elencati nei log di trasferimento.
Trasferimenti di file system
Per creare un manifest dei file in un file system, crea un file CSV con una singola colonna contenente i percorsi dei file relativi alla directory root specificata nella creazione del job di trasferimento.
Ad esempio, per trasferire i seguenti file del file system:
| Percorso file |
|---|
rootdir/dir1/subdir1/file1.txt |
rootdir/file2.txt |
rootdir/dir2/subdir1/file3.txt |
Il manifest dovrebbe essere simile all'esempio seguente:
dir1/subdir1/file1.txt
file2.txt
dir2/subdir1/file3.txt
Salva il file manifest con qualsiasi nome file e un'estensione .csv.
Trasferimenti di archiviazione di oggetti
Per creare un manifest di oggetti, crea un file CSV la cui prima colonna contiene i nomi degli oggetti relativi al nome e al percorso del bucket specificati nella creazione del job di trasferimento. Tutti gli oggetti devono trovarsi nello stesso bucket.
Puoi anche specificare una seconda colonna facoltativa con il numero di generazione di Cloud Storage della versione specifica da trasferire.
Ad esempio, potresti voler trasferire i seguenti oggetti:
| Percorso oggetto | Numero di generazione di Cloud Storage |
|---|---|
SOURCE_PATH/object1.pdf |
1664826685911832 |
SOURCE_PATH/object2.pdf |
|
SOURCE_PATH/object3.pdf |
1664826610699837 |
Il manifest dovrebbe essere simile all'esempio seguente:
object1.pdf,1664826685911832
object2.pdf
object3.pdf,1664826610699837
Salva il file manifest con qualsiasi nome file e un'estensione .csv.
Trasferimenti HTTP/HTTPS
Per trasferire file specifici da un'origine HTTP o HTTPS, consulta le istruzioni riportate in Creare un elenco di URL.
Pubblicare il manifest
Una volta creato il manifest, devi renderlo disponibile per Storage Transfer Service. Storage Transfer Service può accedere al file in un bucket Cloud Storage o nel file system.
Caricare il manifest su Cloud Storage
Puoi archiviare il file manifest in qualsiasi bucket Cloud Storage.
Il service agent che esegue il trasferimento deve disporre dell'autorizzazione storage.objects.get per il bucket contenente il manifest. Per istruzioni su come trovare l'ID del service agent e concedere le autorizzazioni a questo service agent su un bucket, consulta Concedere le autorizzazioni richieste.
Per istruzioni su come caricare il manifest in un bucket, consulta Caricare oggetti nella documentazione di Cloud Storage.
Ad esempio, per utilizzare la gcloud CLI per caricare un file su Cloud Storage,
utilizza il comando gcloud storage cp:
gcloud storage cp MANIFEST.CSV gs://DESTINATION_BUCKET_NAME/
Sostituisci quanto segue:
MANIFEST.CSVè il percorso locale del file manifest. Ad esempio,Desktop/manifest01.csv.DESTINATION_BUCKET_NAMEè il nome del bucket in cui stai caricando l'oggetto. Ad esempio,my-bucket.
In caso di esito positivo, la risposta sarà simile all'esempio seguente:
Completed files 1/1 | 164.3kiB/164.3kiB
Puoi criptare un manifest utilizzando le chiavi di crittografia Cloud KMS gestite dal cliente. In questo caso, assicurati che a tutti i service account che accedono al manifest siano assegnate le chiavi di crittografia applicabili. Le chiavi fornite dal cliente non sono supportate.
Archiviare il manifest in un file system
Puoi archiviare il file manifest nel file system di origine o di destinazione.
La posizione del file deve essere accessibile agli agenti di trasferimento. Se limiti l'accesso alle directory per gli agenti, assicurati che il file manifest si trovi all'interno di una directory montata.
Avviare un trasferimento
Non modificare il file manifest finché non viene completata un'operazione di trasferimento. Ti consigliamo di bloccare il file manifest durante un trasferimento.
console Cloud
Per avviare un trasferimento con un manifest dalla console Cloud:
Segui le istruzioni riportate in Creare trasferimenti per selezionare l' origine, la destinazione e le opzioni.
Nell'ultimo passaggio, Scegli impostazioni, seleziona la casella di controllo Fornisci l'elenco dei file da trasferire tramite il file manifest.
Inserisci la posizione del file manifest.
gcloud
Per trasferire i file o gli oggetti elencati nel manifest, includi il
--manifest-file=MANIFEST_FILE flag con il tuo
gcloud transfer jobs create comando.
gcloud transfer jobs create SOURCE DESTINATION \
--manifest-file=MANIFEST_FILE
MANIFEST_FILE può essere uno dei seguenti valori:
Il percorso del file CSV in un bucket Cloud Storage:
--manifest-file=gs://my_bucket/sample_manifest.csvPer i dettagli sulle autorizzazioni richieste, se il bucket o il file non è pubblico, consulta Caricare il manifest su Cloud Storage.
Il percorso relativo dall'origine del file system SOURCE, incluso qualsiasi percorso specificato:
--manifest-file=source://relative_path/sample_manifest.csvIl percorso relativo dal file system DESTINATION, incluso qualsiasi percorso specificato:
--manifest-file=destination://relative_path/sample_manifest.csv
REST + Librerie client
REST
Per trasferire i file o gli oggetti elencati nel manifest, effettua una chiamata API createTransferJob che specifica un transferSpec con il campo transferManifest aggiunto. Ad esempio:
POST https://storagetransfer.googleapis.com/v1/transferJobs
...
"transferSpec": {
"posixDataSource": {
"rootDirectory": "/home/",
},
"gcsDataSink": {
"bucketName": "GCS_NEARLINE_SINK_NAME",
"path": "GCS_SINK_PATH",
},
"transferManifest": {
"location": "gs://my_bucket/sample_manifest.csv"
}
}
Il file manifest può essere archiviato in un bucket Cloud Storage o nel file system di origine o di destinazione. I bucket Cloud Storage devono utilizzare il prefisso gs:// e includere il percorso completo, incluso il nome del bucket. Le posizioni del file system devono utilizzare un prefisso source:// o destination:// e sono relative all'origine o alla destinazione del file system e alla directory root facoltativa.
Vai
Java
Node.js
Python
Gli oggetti o i file nel manifest non vengono necessariamente trasferiti nell' ordine in cui sono elencati.
Se il manifest include file già esistenti nella destinazione, questi file vengono ignorati, a meno che non sia specificata l'opzione Sovrascrivi gli oggetti già esistenti nel sink.
Se il manifest include oggetti esistenti in una versione diversa nella destinazione, l'oggetto nella destinazione viene sovrascritto con la versione di origine dell'oggetto. Se la destinazione è un bucket con controllo delle versioni, viene creata una nuova versione dell'oggetto.
Passaggi successivi
- Scopri come filtrare gli oggetti dai trasferimenti.
- Scopri come pianificare i job di trasferimento.