É possível acessar o mesmo disco de várias instâncias de máquina virtual (VM) ou bare metal anexando o disco a cada instância. É possível anexar um disco no modo somente leitura ou multigravação a uma instância.
Com o modo somente leitura, várias instâncias só podem ler dados do disco. Nenhuma das instâncias pode gravar no disco. O compartilhamento de um disco no modo somente leitura entre instâncias é menos caro do que ter cópias dos mesmos dados em vários discos.
Com o modo de vários gravadores, várias instâncias podem ler e gravar no mesmo disco. Isso é útil para sistemas de arquivos compartilhados e bancos de dados altamente disponíveis (HA), como a infraestrutura do cluster de failover do SQL Server (FCI).
É possível compartilhar um disco zonal apenas entre instâncias na mesma zona. Os discos regionais só podem ser compartilhados com instâncias nas mesmas zonas que as réplicas do disco.
Não há custos adicionais associados ao compartilhamento de um disco entre instâncias. As instâncias do Compute Engine não precisam usar o mesmo tipo de máquina para compartilhar um disco, mas cada instância precisa usar um tipo de máquina que ofereça suporte ao compartilhamento de disco.
Este documento discute o compartilhamento de disco de vários gravadores e somente leitura no Compute Engine, incluindo os tipos de disco e as considerações de desempenho compatíveis.
Antes de começar
-
Configure a autenticação, caso ainda não tenha feito isso.
A autenticação é
o processo de verificação da sua identidade para acesso a serviços e APIs do Google Cloud.
Para executar códigos ou amostras de um ambiente de desenvolvimento local, autentique-se no
Compute Engine selecionando uma das seguintes opções:
Select the tab for how you plan to use the samples on this page:
Console
When you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication.
gcloud
-
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
- Set a default region and zone.
- Modo de gravação única (
READ_WRITE_SINGLE
): é o modo de acesso padrão. Permite que o disco seja anexado a, no máximo, uma instância por vez. A instância tem acesso de leitura e gravação ao disco. - Modo somente leitura (
READ_ONLY_MANY
): permite anexos simultâneos a várias instâncias no modo somente leitura. As instâncias não podem gravar no disco nesse modo. Obrigatório para compartilhamento somente leitura. - Modo de vários gravadores (
READ_WRITE_MANY
): permite anexos simultâneos a várias instâncias no modo leitura-gravação. Obrigatório para compartilhamento com vários gravadores. - Modo de gravador único
- Modo de vários gravadores
- Modo de gravador único
- Modo somente leitura
- Modo de gravador único
- Hyperdisk ML
- Disco permanente equilibrado regional e zonal.
- Disco permanente SSD
- Disco permanente padrão
- Se você compartilhar um volume do Hyperdisk ML no modo somente leitura, não será possível reativar o acesso de gravação ao disco.
- É possível anexar um volume do Hyperdisk ML a até 100 instâncias durante cada intervalo de 30 segundos.
O número máximo de instâncias a que um disco pode ser anexado varia de acordo com o tipo de disco:
Para volumes do Hyperdisk ML, o número máximo de instâncias depende do tamanho provisionado, conforme segue:
- Volumes com menos de 256 GiB: 2.500 VMs
- Volumes com capacidade entre 256 GiB e 1 TiB: 1.500 VMs
- Volumes com capacidade entre 1 TiB e 2 TiB: 600 VMs
- Volumes com mais de 2 TiB de capacidade: 30 VMs
- Os volumes de disco permanente balanceado regional ou zonal no modo somente leitura têm suporte para, no máximo, 10 instâncias.
- Para o disco persistente SSD, o Google recomenda no máximo 100 instâncias.
- Para volumes de disco permanente padrão, o máximo recomendado é 10 instâncias.
- Implementação da infraestrutura do cluster de failover (FCI) do SQL Server
- Sistemas de arquivos em cluster em que várias instâncias gravam no mesmo disco
- Sistemas de alta disponibilidade no modo ativo-ativo ou ativo-passivo. A anexação do mesmo disco a várias instâncias pode evitar interrupções, porque, se uma instância falhar, outras ainda terão acesso ao disco e poderão continuar executando a carga de trabalho.
- Filestore, a solução de armazenamento de arquivos gerenciados do Google
- Cloud Storage
- Um servidor de arquivos de rede no Compute Engine
- Reservas persistentes (PR), principalmente para sistemas de HA, como o SQL Server FCI e o NetApp ONTAP. O Google recomenda o uso de comandos de PR para fornecer o isolamento de E/S e manter a integridade de dados. Para conferir uma lista dos comandos de PR aceitos, consulte Proteção de E/S com reservas persistentes.
- Sistemas de arquivos em cluster que oferecem suporte a várias instâncias de gravação no mesmo volume. Exemplos desses sistemas de arquivos incluem OCFS2, VMFS e GFS2.
- Sistemas de software em escala horizontal, como Lustre e IBM Spectrum Scale.
- Seu próprio mecanismo de sincronização para coordenar leituras e gravações simultâneas.
- É possível anexar um único volume do Hyperdisk equilibrado ou do Hyperdisk Balanced High Availability no modo de vários gravadores a no máximo 8 instâncias.
- Não é possível clonar um disco no modo de vários gravadores.
- Não é possível criar snapshots, imagens de máquina ou imagens de disco em discos no modo de vários gravadores.
- Não é possível criar um volume do Hyperdisk no modo de vários gravadores ao criar ou editar uma instância. Primeiro, é preciso criar o disco separadamente e, em seguida, anexá-lo à instância.
- Não é possível redimensionar um disco no modo de vários gravadores, a menos que você o tenha desanexado de todas as instâncias.
É possível fazer as seguintes mudanças em um disco que está no modo de vários gravadores, mesmo se o disco já estiver anexado a várias instâncias:
- Modificar as IOPS ou a capacidade de processamento provisionadas
- Anexar o disco a outras instâncias
Quando você faz uma dessas mudanças, o Compute Engine redistribui o desempenho provisionado do disco em todas as instâncias anexadas. Esse processo pode levar até 6 horas para ser concluído.
Não é possível criar uma imagem de um disco no modo de vários gravadores.
Não é possível ativar a exclusão automática para discos no modo de vários gravadores.
Não é possível usar um disco no modo de vários gravadores como o disco de inicialização de uma instância.
Os discos no modo de vários gravadores não podem ser usados com instâncias em nós de locação única.
É necessário usar o mesmo tipo de interface do disco de inicialização da instância.
Não é possível mudar o tipo de máquina de uma instância que está conectada a um disco no modo multigravador.
Os pools de armazenamento não oferecem suporte a discos no modo de vários gravadores.
- Exclusiva de gravação: haverá um único titular da reserva e um único gravador. Todos os outros responsáveis ou não pelo registro só terão acesso de leitura.
- Exclusiva para gravação: somente para responsáveis pelo registro: haverá um único titular da reserva. Todos os responsáveis pelo registro terão acesso de leitura e gravação ao disco. Os não responsáveis pelo registro só terão acesso de leitura.
- Gravação exclusiva: todos os responsáveis pelo registro
- Acesso exclusivo
- Acesso exclusivo: apenas para responsáveis pelo registro
- Acesso exclusivo: todos os responsáveis pelo registro
- Definir recursos: identificador do host
- Notificações de reserva:
- Página de obtenção de registro
- Máscara de notificação de reserva
- Ação de registro de reserva (
RREGA
): substituir/registrar/cancelar o registro -IEKEY
- Ação de aquisição de reserva (
RACQA
): aquisição/preempção -IEKEY
- Ação de liberação de reserva (
RRELA
): liberação/limpeza -IEKEY
- Relatório de reservas
- Campo de recursos de reserva (
RESCAP
) na estrutura de dados do namespace de identificação. - Forçar a interrupção e cancelar
- Desativação da persistência durante a perda de energia (PTPL). O PTPL está sempre ativado.
- Crie o disco, definindo o modo de acesso como Vários gravadores.
- Anexe o disco a cada instância.
- Remova o disco de todas as instâncias.
- Defina o modo de acesso do disco como Vários gravadores.
- Anexe o disco a cada instância.
- Conectar as instâncias ao Cloud Storage
- Conectar suas instâncias ao Filestore
- Criar um servidor de arquivos de rede no Compute Engine
- ENTRADA {REPORT CAPABILITIES, READ FULL STATUS, READ RESERVATION, READ KEYS}
- SAÍDA {REGISTER, REGISTER AND IGNORE EXISTING KEY, RESERVE, PREEMPT, CLEAR, RELEASE}
- O encapsulamento de E/S usando os comandos de SCSI PR resulta em um estado consistente de falha dos dados do disco permanente. Alguns sistemas de arquivos não têm consistência de falhas e, portanto, poderão ficar corrompidos se você usar comandos SCSI PR.
- Muitos sistemas de arquivos, como EXT4, XFS e NTFS, não são projetados para ser usados com armazenamento em blocos compartilhado e não têm mecanismos para sincronizar ou executar operações originadas de várias instâncias de VM.
- Antes de usar os volumes do Persistent Disk no modo de vários gravadores, entenda o sistema de arquivos e como ele pode ser usado com segurança com armazenamento em blocos compartilhado e acesso simultâneo de várias instâncias.
- O modo com vários gravadores só é compatível com volumes de disco permanente do tipo SSD.
- É possível criar um volume de disco permanente no modo de vários gravadores em
qualquer zona, mas só é possível anexá-lo às VMs nos seguintes locais:
australia-southeast1
europe-west1
us-central1
(somente zonasus-central1-a
eus-central1-c
)us-east1
(apenas para a zonaus-east1-d
)us-west1
(somente zonasus-west1-b
eus-west1-c
)
- As instâncias anexadas precisam ter um tipo de máquina N2.
- O tamanho mínimo do disco é de 10 GiB.
- Os discos no modo de vários gravadores não são compatíveis com a anexação de mais de 2 VMs por vez. Os volumes do Persistent Disk no modo com vários gravadores não são compatíveis com as métricas do Persistent Disk.
- Não é possível mudar discos que estejam no modo de vários gravadores para o modo somente leitura.
- Não é possível usar imagens de disco ou snapshots para criar volumes do Persistent Disk no modo de vários gravadores.
- Não é possível criar snapshots ou imagens de volumes do Persistent Disk no modo de vários gravadores.
- Limites menores de IOPS. Consulte o desempenho do disco para saber detalhes.
- Não é possível redimensionar um volume de disco permanente com vários gravadores.
- Ao criar uma instância usando a Google Cloud CLI, não é possível criar um
volume Persistent Disk de vários gravadores com a flag
--create-disk
. Use o comando
gcloud beta compute disks create
para criar um volume de disco permanente zonal. Inclua a sinalização--multi-writer
para indicar que o disco precisa ser compartilhável entre as VMs no modo de vários gravadores.gcloud beta compute disks create DISK_NAME \ --size DISK_SIZE \ --type pd-ssd \ --multi-writer
Substitua:
DISK_NAME
: o nome do novo discoDISK_SIZE
: o tamanho, em GB, do novo disco. Os tamanhos aceitáveis variam de 1 GB a 65.536 GB para volumes de disco permanente SSD ou de 200 GB a 65.536 GB para volumes de disco permanente padrão em vários gravadores mais recente.
Depois de criar o disco, anexe-o a qualquer VM em execução ou parada com um tipo de máquina N2. Use o comando
gcloud compute instances attach-disk
:gcloud compute instances attach-disk INSTANCE_NAME \ --disk DISK_NAME
Substitua:
INSTANCE_NAME
: o nome da VM N2 em que você está adicionando o novo volume zonal do Persistent DiskDISK_NAME
: o nome do novo disco que você está anexando à VM.
Repita o comando
gcloud compute instances attach-disk
, mas substitua INSTANCE_NAME pelo nome da segunda VM.Na API, crie uma solicitação
POST
para criar um volume de disco permanente zonal usando o métododisks.insert
. Inclua as propriedadesname
,sizeGb
etype
. Para criar esse novo disco como um disco que não será usado para inicialização e sem formatação, não especifique uma imagem ou um snapshot de origem para esse disco. Inclua a propriedademultiWriter
com um valorTrue
para indicar que o disco precisa ser compartilhável entre as VMs no modo de vários gravadores.POST https://compute.googleapis.com/compute/beta/projects/PROJECT_ID/zones/ZONE/disks { "name": "DISK_NAME", "sizeGb": "DISK_SIZE", "type": "zones/ZONE/diskTypes/pd-ssd", "multiWriter": "True" }
Substitua:
PROJECT_ID
: ID do projetoZONE
: a zona em que a VM e o novo disco estão localizados.DISK_NAME
: o nome do novo discoDISK_SIZE
: o tamanho, em GB, do novo disco. Os tamanhos aceitáveis variam de 1 GB a 65.536 GB para volumes de disco permanente SSD ou de 200 GB a 65.536 GB para volumes de disco permanente padrão em vários gravadores mais recente.
Para anexar o disco a uma instância, crie uma solicitação
POST
para o métodocompute.instances.attachDisk
. Inclua o URL do volume do disco permanente zonal que você acabou de criar:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/attachDisk { "source": "/compute/v1/projects/PROJECT_ID/zones/ZONE/disks/DISK_NAME" }
Substitua:
PROJECT_ID
: ID do projetoZONE
: a zona em que a VM e o novo disco estão localizados.INSTANCE_NAME
: o nome da VM em que você está adicionando o novo volume do Persistent Disk.DISK_NAME
: o nome do novo disco.
Para anexar o disco a uma segunda VM, repita o comando
instances.attachDisk
da etapa anterior. DefinaINSTANCE_NAME
como o nome da segunda VM.- Saiba mais sobre a replicação síncrona de disco entre zonas.
- Saiba mais sobre a Replicação assíncrona de disco permanente.
REST
Para usar as amostras da API REST nesta página em um ambiente de desenvolvimento local, use as credenciais fornecidas para gcloud CLI.
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
Para mais informações, consulte Autenticar para usar REST na documentação de autenticação do Google Cloud.
Ativar o compartilhamento de disco
É possível anexar um volume do Hyperdisk ou do Persistent Disk a várias instâncias. No entanto, para volumes do Hyperdisk, primeiro é necessário colocar o disco no modo de vários gravadores ou somente leitura definindo o modo de acesso.
O modo de acesso de um volume do Hyperdisk é uma propriedade que determina como as instâncias podem acessar o disco.
Os modos de acesso disponíveis são os seguintes:
O suporte para cada modo de acesso varia de acordo com o tipo de Hyperdisk, conforme indicado na tabela a seguir. Não é possível definir o modo de acesso para volumes do Hyperdisk Throughput ou do Hyperdisk Extreme.
Tipo de Hyperdisk Modos de acesso compatíveis Hiperdisco equilibrado
Hyperdisk equilibrado de alta disponibilidade (pré-lançamento)Hyperdisk ML Capacidade de processamento do Hyperdisk
Hiperdisco extremo
Para discos que podem ser compartilhados entre instâncias, é possível definir o modo de acesso durante ou após a criação do disco. Para instruções sobre como definir o modo de acesso, consulte definir o modo de acesso do disco.
Modo somente leitura para Hyperdisk e Persistent Disk
Esta seção discute o compartilhamento de um único disco no modo somente leitura entre várias instâncias.
Tipos de disco compatíveis com o modo somente leitura
É possível anexar estes tipos de disco a várias instâncias no modo somente leitura:
Desempenho no modo somente leitura
Anexar um disco no modo somente leitura a várias instâncias não afeta o desempenho do disco. Cada instância ainda pode alcançar o desempenho máximo de disco possível para o tipo de máquina da instância.
Limitações para compartilhar discos no modo somente leitura
Como compartilhar um disco no modo somente leitura entre instâncias
Se você não estiver usando o Hyperdisk ML, anexe o disco a várias instâncias seguindo as instruções em Anexar um disco que não é de inicialização a uma instância.
Para anexar um volume do Hyperdisk ML no modo somente leitura a várias instâncias, primeiro defina o modo de acesso do disco como somente leitura. Depois de definir o modo de acesso, anexe o volume do Hyperdisk ML às suas instâncias.
Modo de vários gravadores para Hyperdisk
Os discos no modo de vários gravadores são adequados para casos de uso como estes:
Se o objetivo principal for o armazenamento de arquivos compartilhados entre instâncias de computação, considere uma destas opções:
Tipos de Hyperdisk e de máquina com suporte para o modo de vários gravadores
É possível usar volumes do Hyperdisk equilibrado e do Hyperdisk Balanced High Availability (pré-lançamento) no modo de vários gravadores. É possível anexar um volume no modo de vários gravadores a no máximo 8 instâncias.
O Hyperdisk equilibrado oferece suporte ao modo de vários gravadores para os seguintes tipos de máquina:
O Hyperdisk Balanced High Availability oferece suporte ao modo de vários gravadores (pré-lançamento) para os seguintes tipos de máquina:
O modo de vários gravadores para o Hyperdisk oferece suporte à interface NVMe. Se você estiver anexando um disco no modo multigravador a uma instância, o disco de inicialização da instância também precisará ser anexado com NVMe.
Sistemas de arquivos com suporte para o modo de vários gravadores
Para acessar um disco de várias instâncias, use uma destas opções:
Desempenho do Hyperdisk no modo de vários gravadores
Quando você anexa um disco no modo de vários gravadores a várias instâncias, o desempenho provisionado do disco é compartilhado igualmente entre todas as instâncias. O desempenho é dividido de maneira uniforme entre todas as instâncias, mesmo entre as que não estão em execução ou que não estão usando ativamente o disco. No entanto, a performance máxima de cada instância é limitada pelos limites de capacidade de processamento e IOPS de cada tipo de máquina da instância.
Por exemplo, suponha que você anexe um volume Hyperdisk equilibrado provisionado com 100.000 IOPS a duas instâncias. Cada instância recebe 50.000 IOPS simultaneamente.
A tabela a seguir mostra a performance que cada instância neste exemplo teria, dependendo de quantas instâncias o disco está anexado. Sempre que você anexa um disco a outra instância, o Compute Engine ajusta de forma assíncrona o desempenho alocado para cada instância anexada anteriormente.
Nº de instâncias anexadas 1 2 3 4 5 6 7 8 Máximo de IOPS
por instância100.000 50.000 ~33.333 25.000 20.000 ~16.667 14285 12.500 Capacidade máxima de processamento
por instância
em MiBps1.200 600 400 300 240 200 ~172 150 Limitações para compartilhar volumes do Hyperdisk no modo de vários gravadores
Regiões disponíveis
O modo de vários gravadores tem suporte em todas as regiões em que o Hyperdisk equilibrado e o Hyperdisk Balanced High Availability estão disponíveis.
Isolamento de E/S com reservas persistentes
O Google recomenda o uso de reservas persistentes (PR) com discos no modo de vários gravadores para fornecer isolamento de E/S. As reservas permanentes gerenciam o acesso ao disco entre as instâncias. Isso evita que os dados sejam corrompidos por instâncias que gravam simultaneamente na mesma parte do disco.
Os volumes do Hyperdisk no modo de vários gravadores oferecem suporte a reservas NVMe (especificação 1.2.1).
Modos de reserva compatíveis
Os seguintes modos de reserva são compatíveis:
Os seguintes modos de reserva não são compatíveis:
NVMe
Get Features - Host Identifier
é compatível. O número da instância é usado como o ID do host padrão.Os seguintes recursos de reserva do NVMe não são compatíveis:
Comandos compatíveis
As reservas NVMe são compatíveis com os seguintes comandos:
As reservas NVMe não são compatíveis com os seguintes comandos:
Como compartilhar um disco no modo de vários gravadores
Antes de anexar um disco no modo de vários gravadores a várias instâncias, defina o modo de acesso do disco como Vários gravadores. Você pode definir o modo de acesso de um disco ao criá-lo.
Também é possível definir o modo de acesso para um disco existente, mas primeiro é necessário desanexar o disco de todas as instâncias.
Para criar e usar um novo disco no modo de vários gravadores, siga estas etapas:
Para usar um disco no modo de vários gravadores, siga estas etapas:
Modo de vários gravadores para volumes de Persistent Disk
É possível anexar um volume de disco permanente SSD no modo de vários gravadores com até duas instâncias de máquina virtual (VM, na sigla em inglês) N2 simultaneamente, para que ambas as VMs possam ler e gravar no disco.
Se você tiver mais de duas VMs N2 ou estiver usando qualquer outra série de máquinas, use uma das seguintes opções:
Para ativar o modo de vários gravadores em novos discos permanentes, crie um volume de disco permanente e especifique a sinalização
--multi-writer
na CLI gcloud ou a propriedademultiWriter
na API Compute Engine.Os volumes de discos permanentes no modo de vários gravadores fornecem um recurso de armazenamento em blocos compartilhado e apresentam uma base infraestruturada para criar sistemas de armazenamento distribuídos e serviços semelhantes altamente disponíveis. Ao usar volumes de discos permanentes no modo de vários gravadores, use um sistema de software de armazenamento de escalonamento horizontal com a capacidade de coordenar o acesso a dispositivos de disco permanente em várias VMs. Exemplos desses sistemas de armazenamento incluem Lustre e o IBM Spectrum Scale. A maioria dos sistemas de arquivos de VM única, como EXT4, XFS e NTFS, não foi projetada para ser usada com o armazenamento em blocos compartilhados.
Para mais informações, consulte Práticas recomendadas neste documento. Se você precisar de um armazenamento de arquivos totalmente gerenciado, monte um compartilhamento de arquivos do Filestore nas suas instâncias do Compute Engine.
Os volumes do Persistent Disk no modo de vários gravadores são compatíveis com um subconjunto de comandos do Persistent Reservations SCSI-3 (SCSI PR). Aplicativos de alta disponibilidade podem usar esses comandos para configurações de encapsulamento e failover de E/S.
Os seguintes comandos SCSI PR são compatíveis:
Para instruções, consulte Compartilhar um volume de disco permanente SSD no modo de vários gravadores entre as VMs.
Tipos de Persistent Disk com suporte para o modo de vários gravadores
É possível anexar simultaneamente um disco permanente SSD no modo de vários gravadores a até duas VMs N2.
Práticas recomendadas para o modo de vários gravadores
Desempenho do Persistent Disk no modo de vários gravadores
Os volumes de discos permanentes criados no modo de várias gravações têm limites de capacidade e de IOPS específicos.
Modo de vários gravadores para Discos permanentes SSD zonais IOPS máximas sustentadas IOPS de leitura por GB 30 IOPS de gravação por GB 30 IOPS de leitura por instância 15.000–100.000* IOPS de gravação por instância 15.000–100.000* Capacidade sustentada máxima (MB/s) Capacidade de leitura por GB 0,48 Capacidade de gravação por GB 0,48 Capacidade de leitura por instância 240–1.200* Capacidade de gravação por instância 240–1.200* * O desempenho das IOPS e da capacidade do disco permanente depende do tamanho do disco, do número de vCPUs da instância e do tamanho do bloco de E/S, entre outros fatores.A anexação de um disco de vários gravadores a várias instâncias de máquina virtual não afeta o desempenho ou o custo agregado. Cada máquina recebe uma parcela do limite de desempenho por disco.
Para saber como compartilhar discos permanentes entre várias VMs, consulte Compartilhar discos permanentes entre VMs.Restrições para compartilhar um disco no modo de vários gravadores
Compartilhar um volume de disco permanente SSD no modo de vários gravadores entre as VMs
É possível compartilhar um volume de disco permanente SSD no modo de vários gravadores entre VMs N2 na mesma zona. Consulte Modo de vários gravadores em discos permanentes para detalhes sobre como ele funciona. Crie e anexe volumes do Persistent Disk com vários gravadores usando o seguinte processo:
gcloud
Crie e anexe um volume de disco permanente zonal usando a CLI gcloud:
Depois de criar e anexar um novo disco a uma instância, formate e monte o disco usando um sistema de arquivos de disco compartilhado. A maioria dos sistemas de arquivos não usa armazenamento compartilhado. Confirme se o sistema de arquivos é compatível com esses recursos antes de usá-los com o disco permanente de vários gravadores. Não é possível ativar o disco em várias VMs usando o mesmo processo que você normalmente usaria para ativar o disco em uma única VM.
REST
Use a API Compute Engine para criar e anexar um volume de disco permanente SSD às VMs N2 no modo de vários gravadores.
Depois de criar e anexar um novo disco a uma instância, formate e monte o disco usando um sistema de arquivos de disco compartilhado. A maioria dos sistemas de arquivos não usa armazenamento compartilhado. Confirme se o sistema de arquivos é compatível com esses recursos antes de usá-los com o Persistent Disk de vários gravadores.
A seguir
Exceto em caso de indicação contrária, o conteúdo desta página é licenciado de acordo com a Licença de atribuição 4.0 do Creative Commons, e as amostras de código são licenciadas de acordo com a Licença Apache 2.0. Para mais detalhes, consulte as políticas do site do Google Developers. Java é uma marca registrada da Oracle e/ou afiliadas.
Última atualização 2024-12-22 UTC.
-