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. Pour en savoir plus sur ces deux options, consultez la section Présentation des bibliothèques clientes.
La bibliothèque cliente des API Google continue de recevoir des mises à jour, mais n'est plus référencée 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
par 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 de la bibliothèque cliente de l'API vers la bibliothèque cliente Cloud. Voici quelques différences majeures entre les deux clients Java :
Instanciation du client
La bibliothèque cliente Cloud réduit une grande partie du code répétitif associé à l'instanciation du client en le gérant en coulisses.
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();
StorageTransferServiceClient storageTransfer = StorageTransferServiceClient.create();
Constructeurs pour les classes de modèles
Les classes de modèle de la bibliothèque cliente Cloud utilisent des constructeurs au lieu de constructeurs.
TransferJob transferJob =
new TransferJob()
.setStatus("ENABLED");
TransferJob transferJob =
TransferJob.newBuilder()
.setStatus(Status.ENABLED)
.build();
Les opérations de liste renvoient des itérables
Les opérations de liste dans la bibliothèque cliente Cloud renvoient des itérables simples au lieu des résultats paginés dans la bibliothèque cliente de l'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();
}
}
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
Nous incluons ici les anciens exemples de bibliothèque cliente d'API, comparés à leurs équivalents utilisant 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
Transférer vers Nearline
Vérifier la dernière opération de transfert
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 de google-api-python-client
.
pip install --upgrade google-cloud-storage-transfer
Instanciation du client
Utilisez le module storage_transfer
à la place de googleapiclient.discovery
.
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
Transférer vers Nearline
Notez l'importation de google.protobuf.duration_pb2.Duration
.
Vérifier la dernière opération de transfert
Notez l'utilisation de storage_transfer.TransferOperation.deserialize
.