Pour garantir une qualité élevée et être cohérente avec nos autres bibliothèques Cloud, la documentation du service de transfert de stockage utilise désormais les bibliothèques clientes Cloud au lieu des bibliothèques clientes de l'API Google. Voir Présentation des bibliothèques clientes des informations sur les deux options.
La bibliothèque cliente des API Google continue de recevoir des mises à jour, mais n'est plus référencées dans la documentation.
Ce guide présente les principales différences concernant l'utilisation du service de transfert de stockage et fournit des instructions pour mettre à jour vos clients lors de la migration vers la bibliothèque cliente Cloud.
Java
Mettre à jour les dépendances
Pour passer à la nouvelle bibliothèque, remplacez votre dépendance sur
google-api-services-storagetransfer
avec google-cloud-storage-transfer
.
<dependency> <groupId>com.google.cloud</groupId> <artifactId>google-cloud-storage-transfer</artifactId> <version>0.2.3</version> </dependency>
Si vous utilisez Gradle sans BOM, ajoutez ceci à vos dépendances:
implementation 'com.google.cloud:google-cloud-storage-transfer:0.2.3'
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.google.cloud</groupId>
<artifactId>libraries-bom</artifactId>
<version>24.1.0</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>com.google.cloud</groupId>
<artifactId>google-cloud-storage-transfer</artifactId>
</dependency>
Dans la plupart des cas, le code peut être facilement converti à partir du client API vers la bibliothèque cliente Cloud. Voici quelques différences clés entre les deux clients Java
Instanciation du client
La bibliothèque cliente Cloud réduit une grande partie du code récurrent associé à l'instanciation du client en le gérant en coulisses.
Bibliothèque cliente des API
GoogleCredentials credential = GoogleCredentials.getApplicationDefault();
if (credential.createScopedRequired()) {
credential = credential.createScoped(StoragetransferScopes.all());
}
Storagetransfer storageTransfer = new Storagetransfer.Builder(Utils.getDefaultTransport(),
Utils.getDefaultJsonFactory(), new HttpCredentialsAdapter(credential))
.build();
Bibliothèque cliente Cloud
StorageTransferServiceClient storageTransfer = StorageTransferServiceClient.create();
Compilateurs pour les classes de modèle
Les classes de modèle de la bibliothèque cliente Cloud utilisent des constructeurs au lieu de constructeurs.
Bibliothèque cliente de l'API
TransferJob transferJob =
new TransferJob()
.setStatus("ENABLED");
Bibliothèque cliente Cloud
TransferJob transferJob =
TransferJob.newBuilder()
.setStatus(Status.ENABLED)
.build();
Les opérations de liste renvoient des itérables
Les opérations de liste de la bibliothèque cliente Cloud renvoient des itérables simples au lieu des résultats paginés dans la bibliothèque cliente des API.
Bibliothèque cliente des API
public class StoragetransferExample {
public static void main(String args[]) throws IOException, GeneralSecurityException {
Storagetransfer storagetransferService = createStoragetransferService();
Storagetransfer.TransferJobs.List request = storagetransferService.transferJobs().list();
ListTransferJobsResponse response;
do {
response = request.execute();
if (response.getTransferJobs() == null) {
continue;
}
for (TransferJob transferJob : response.getTransferJobs()) {
System.out.println(transferJob);
}
request.setPageToken(response.getNextPageToken());
} while (response.getNextPageToken() != null);
}
public static Storagetransfer createStoragetransferService()
throws IOException, GeneralSecurityException {
HttpTransport httpTransport = GoogleNetHttpTransport.newTrustedTransport();
JsonFactory jsonFactory = JacksonFactory.getDefaultInstance();
GoogleCredential credential = GoogleCredential.getApplicationDefault();
}
return new Storagetransfer.Builder(httpTransport, jsonFactory, credential)
.build();
}
}
Bibliothèque cliente Cloud
public class StoragetransferExample {
public static void main(String args[]) throws Exception {
StorageTransferServiceClient storageTransfer = StorageTransferServiceClient.create();
ListTransferJobsRequest request = ListTransferJobsRequest.newBuilder().build();
for (TransferJob job : client.listTransferJobs(request).iterateAll()) {
System.out.println(job);
}
}
}
Exemples de comparaisons
Ici, nous incluons les anciens exemples de bibliothèques clientes d'API par rapport à leurs exemples équivalents à l'aide de la bibliothèque cliente Cloud. Si vous avez déjà utilisé ces exemples, vous pouvez utiliser cette comparaison pour comprendre comment migrer votre code vers la nouvelle bibliothèque cliente Cloud.
Transférer des données depuis Amazon S3
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Transférer vers Nearline
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Vérifier la dernière opération de transfert
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Python
Mettre à jour les dépendances
Pour utiliser la nouvelle bibliothèque, ajoutez une dépendance à google-cloud-storage-transfer
.
Il sera utilisé à la place du client de découverte
google-api-python-client
pip install --upgrade google-cloud-storage-transfer
Instanciation du client
Utilisez le module storage_transfer
au lieu de googleapiclient.discovery
.
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Exemples de comparaisons
Pour illustrer les différences entre les deux bibliothèques, voici les anciens exemples de client d'API côte à côte avec leurs équivalents dans la bibliothèque cliente Cloud.
Transférer des données depuis Amazon S3
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Transférer vers Nearline
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Notez l'importation de google.protobuf.duration_pb2.Duration
.
Vérifier la dernière opération de transfert
Bibliothèque cliente des API
Bibliothèque cliente Cloud
Notez l'utilisation de storage_transfer.TransferOperation.deserialize
.