Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Este artigo mostra como excluir contêineres com a biblioteca de clientes do Armazenamento do Microsoft Azure para Java. Se você tiver habilitado a exclusão temporária do contêiner, poderá restaurar contêineres excluídos.
Pré-requisitos
- Assinatura do Azure - criar uma gratuitamente
- Conta de armazenamento do Azure – criar uma conta de armazenamento
- Java Development Kit (JDK) versão 8 ou posterior (recomendamos a versão 17 para a melhor experiência possível)
- O Apache Maven é usado para o gerenciamento de projetos neste exemplo
Configure seu ambiente
Se você não tiver um projeto existente, esta seção irá lhe mostrar como configurar um projeto para que funcione com a biblioteca de cliente do Armazenamento de Blobs do Azure para Java. Para obter mais informações, confira Introdução ao Armazenamento de Blobs do Azure e ao Java.
Para trabalhar com os exemplos de código neste artigo, siga estas etapas para configurar seu projeto.
Observação
Este artigo usa a ferramenta de build do Maven para compilar e executar o exemplo de código. Outras ferramentas de build, como o Gradle, também funcionam com o SDK do Azure para Java.
Instalar Pacotes
Abra o arquivo pom.xml no editor de texto. Instale os pacotes incluindo o arquivo BOM ou incluindo uma dependência direta.
Adicionar instruções de importação
Adicione as seguintes declarações de import :
import com.azure.storage.blob.*;
import com.azure.storage.blob.models.*;
Autorização
O mecanismo de autorização precisa ter as permissões necessárias para excluir ou restaurar um contêiner. Para autorização com o Microsoft Entra ID (recomendado), você precisa da função interna de Colaborador de Dados de Blob de Armazenamento ou superior do RBAC do Azure. Para saber mais, confira as diretrizes de autorização para Excluir Contêiner (API REST) e Restaurar Contêiner (API REST).
Criar um objeto cliente
Para conectar um aplicativo ao Armazenamento de Blobs, crie uma instância do BlobServiceClient.
O exemplo a seguir usa o BlobServiceClientBuilder para criar um objeto de BlobServiceClient usando DefaultAzureCredential e mostra como criar clientes de blob e de contêiner, se for preciso:
// Azure SDK client builders accept the credential as a parameter
// TODO: Replace <storage-account-name> with your actual storage account name
BlobServiceClient blobServiceClient = new BlobServiceClientBuilder()
.endpoint("https://<storage-account-name>.blob.core.windows.net/")
.credential(new DefaultAzureCredentialBuilder().build())
.buildClient();
// If needed, you can create a BlobContainerClient object from the BlobServiceClient
BlobContainerClient containerClient = blobServiceClient
.getBlobContainerClient("<container-name>");
// If needed, you can create a BlobClient object from the BlobContainerClient
BlobClient blobClient = containerClient
.getBlobClient("<blob-name>");
Para saber mais sobre como criar e gerenciar objetos clientes, confira Criar e gerenciar objetos de cliente que interagem com recursos de dados.
Excluir um contêiner
Para excluir um contêiner no Java, use um dos seguintes métodos da classe BlobServiceClient:
Você também pode excluir um contêiner usando um dos seguintes métodos da classe BlobContainerClient:
Depois de excluir um contêiner, não será possível criar um contêiner com o mesmo nome por pelo menos 30 segundos. A tentativa de criar um contêiner com o mesmo nome falhará com o código de erro HTTP 409 (Conflict). Qualquer outra operação no contêiner ou nos blobs que ele contém falhará com o código de erro HTTP 404 (Not Found).
O exemplo a seguir usa um objeto BlobServiceClient para excluir um contêiner específico:
public void deleteContainer(BlobServiceClient blobServiceClient, String containerName) {
// Delete the container using the service client
blobServiceClient.deleteBlobContainer(containerName);
}
O exemplo a seguir mostra como excluir todos os contêineres que começam com um prefixo especificado:
public void deleteContainersWithPrefix(BlobServiceClient blobServiceClient) {
ListBlobContainersOptions options = new ListBlobContainersOptions()
.setPrefix("container-");
// Delete the container with the specified prefix using the service client
for (BlobContainerItem containerItem : blobServiceClient.listBlobContainers(options, null)) {
BlobContainerClient containerClient = blobServiceClient.getBlobContainerClient(containerItem.getName());
containerClient.delete();
}
}
Restaurar um contêiner excluído
Quando a exclusão temporária de contêineres está habilitada em uma conta de armazenamento, um contêiner excluído e seu conteúdo podem ser recuperados dentro de um período de retenção especificado. Para saber mais sobre a exclusão temporária de contêiner, confira Habilitar e gerenciar a exclusão temporária de contêineres. Você pode restaurar um contêiner excluído temporariamente chamando o seguinte método da classe BlobServiceClient:
O exemplo a seguir localiza um contêiner excluído, obtém a versão do contêiner excluído e, em seguida, passa essa versão para o método undeleteBlobContainer a fim de restaurar o contêiner.
public void restoreContainer(BlobServiceClient blobServiceClient) {
ListBlobContainersOptions options = new ListBlobContainersOptions();
options.getDetails().setRetrieveDeleted(true);
// Delete the container with the specified prefix using the service client
for (BlobContainerItem deletedContainerItem : blobServiceClient.listBlobContainers(options, null)) {
BlobContainerClient containerClient = blobServiceClient
.undeleteBlobContainer(deletedContainerItem.getName(), deletedContainerItem.getVersion());
}
}
Recursos
Para saber mais sobre como criar um contêiner usando a biblioteca de clientes do Armazenamento de Blobs do Azure para Java, consulte os recursos a seguir:
Exemplos de código
Operações da API REST
O SDK do Azure para Java contém bibliotecas que criam sobre a API REST do Azure, permitindo a interação com as operações de API REST por meio de paradigmas conhecidos do Java. Os métodos da biblioteca de clientes para excluir ou restaurar um contêiner usam as seguintes operações da API REST:
- Excluir contêiner (API REST)
- Restaurar contêiner (API REST)
Recursos da biblioteca de clientes
- Documentação de referência da biblioteca de clientes
- Código-fonte da biblioteca de clientes
- Pacote (Maven)
Confira também
Conteúdo relacionado
- Este artigo faz parte do guia para desenvolvedores do Armazenamento de Blobs para Java. Para saber mais, veja a lista completa de artigos do guia do desenvolvedor em Criar seu aplicativo Java.