O guia a seguir mostra como implementar o protocolo NFSv4.1 com uma nova instância do Filestore.
Sobre o NFSv4.1
O Filestore oferece suporte ao protocolo NFSv4.1 para instâncias criadas nos seguintes níveis de serviço:
- Zonal
- Regional
- Enterprise
Esse recurso pode ser integrado ao Serviço gerenciado para o Microsoft Active Directory (Microsoft AD gerenciado) para oferecer suporte a cargas de trabalho que exigem autenticação de cliente e servidor, verificações de integridade de dados de mensagens e criptografia de dados em trânsito, recursos que antes não estavam disponíveis no Filestore.
A autenticação é compatível com LDAP e Kerberos e inclui as seguintes configurações de segurança:
- Autenticação de cliente e servidor (
krb5
). - Verificações de integridade da mensagem (
krb5i
). Inclui os recursos da configuração anterior. - Criptografia de dados em trânsito (
krb5p
). Inclui os recursos do configuração anterior.
- Autenticação de cliente e servidor (
O Microsoft AD gerenciado é a única solução do Google Cloud totalmente gerenciada que oferece suporte ao LDAP e Kerberos, os requisitos para sobre o protocolo NFSv4.1 e os benefícios de segurança e privacidade. Embora a integração com o Microsoft AD gerenciado não seja obrigatória, é altamente recomendável que uma experiência de usuário ideal do Google Cloud gerencie contas de usuário e grupos e permissões variáveis.
Você precisa usar o NFSv4.1?
Muitas organizações empresariais dependem de sistemas legados para operações essenciais de negócios. Muitos desses sistemas exigem autenticação e em trânsito e criptografia para o armazenamento de arquivos em rede. O NFSv3 não foi projetado com com a autenticação em mente. A integração do protocolo NFSv4.1 do Filestore com o Microsoft AD gerenciado agora atende a esse requisito importante do usuário.
Objetivos
Neste guia, você vai aprender a realizar as seguintes tarefas:
- Crie uma instância do Filestore que use o NFSv4.1.
- Conectar ou desconectar o Microsoft AD gerenciado de uma instância do Filestore.
Criar uma instância do Filestore que use o NFSv4.1
Para usar o Microsoft AD gerenciado com uma instância do Filestore, o O domínio do Microsoft AD gerenciado precisa ser criado antes do Filestore instância.
Antes de começar
O domínio do Microsoft AD gerenciado e o Filestore precisa usar a mesma VPC enquanto estão no mesmo projeto.
Se o serviço do Microsoft AD gerenciado estiver hospedado em um projeto separado do a instância do Filestore que você quer usar e o arquivo A rede VPC precisa estar em peering com o domínio do Microsoft AD gerenciado.
Para mais informações, consulte Implantar o Microsoft AD gerenciado com acesso entre projetos usando peering de domínio.
Conclua todas as etapas de configuração para criar uma instância do Filestore.
Verifique se os usuários do Microsoft AD gerenciado têm os campos POSIX RFC 2307 e RFC 2307bis preenchidos, semelhante ao seguinte.
Para mais informações sobre como configurar objetos no Microsoft AD gerenciado, consulte Objetos gerenciados do Active Directory.
Usuários e computadores do Active Directory
As etapas a seguir descrevem os atributos que você precisa definir para o LDAP usuários e grupos. É possível gerenciar atributos POSIX usando o snap-in do MMC Usuários e computadores do Active Directory.
Abra o Editor de atributos da seguinte forma:
- Clique em Iniciar.
Clique em Ferramentas administrativas do Windows e selecione Usuários e computadores do Active Directory.
A janela Usuários e computadores do Active Directory é aberta.
Selecione o nome de domínio que você quer consultar. Para expandir o conteúdo, Clique na seta
de expansão.No menu View (Visualizar) dos usuários e computadores do Active Directory, selecione Advanced Features (Recursos avançados).
No painel à esquerda, clique duas vezes em Usuários.
Na lista de usuários, clique duas vezes em um usuário para acessar a guia Editor de atributos.
Os usuários LDAP precisam ter os seguintes atributos definidos:
uid
uidNumber
cn
gidNumber
objectClass
Cada usuário precisa ter um
uidNumber
exclusivo. Observe que o valor do atributo O atributouid
diferencia maiúsculas de minúsculas. Para o atributoobjectClass
,user
é a configuração padrão na maioria das implantações do Active Directory (AD). Veja um exemplo abaixo.uid: Alice uidNumber: 139 gidNumber: 555 objectClass: user
Os grupos LDAP precisam ter os seguintes atributos definidos:
cn
gidNumber
objectClass
Cada grupo precisa ter um
gidNumber
exclusivo. Observe que o valor do atributo O atributocn
diferencia maiúsculas de minúsculas. Para o atributoobjectClass
,group
é a configuração padrão na maioria das implantações do AD. Confira um exemplo:cn: AliceGroup gidNumber: 555 objectClass: group
Conceda acesso ao Filestore para criar e gerenciar objetos no Microsoft AD gerenciado usando o
gcloud projects add-iam-policy-binding
comando:gcloud projects add-iam-policy-binding MANAGED_MICROSOFT_AD_PROJECT_ID \ --member=serviceAccount:service-$(gcloud projects describe PROJECT_ID \ --format='value(projectNumber)')@cloud-filer.iam.gserviceaccount.com \ --role=roles/managedidentities.filestoreintegrator
Substitua:
- MANAGED_MICROSOFT_AD_PROJECT_ID é o ID do projeto do projeto em que o domínio do Microsoft AD gerenciado está localizado.
- PROJECT_ID é o ID do projeto em que a instância do Filestore está localizada.
Talvez você encontre um erro semelhante a este:
INVALID_ARGUMENT: Service account service-123456789012@cloud-filer.iam.gserviceaccount.com does not exist.
Se sim, use o seguinte comando para resolver o problema:
gcloud beta services identity create --service=file.googleapis.com --project \ MANAGED_MICROSOFT_AD_PROJECT_ID
Criar uma instância do Filestore com ou sem o Microsoft AD gerenciado
Nesta seção, você vai criar uma instância do Filestore configurada para uso com o protocolo NFSv4.1. Etapas opcionais estão incluídas para usuários que optam por não usar o Microsoft AD gerenciado.
Verifique se você tem cota suficiente.
Os intervalos de cota de instâncias variam de acordo com a localização da região e o nível de serviço que você quer usar. Para aumentar a cota disponível, envie uma solicitação de aumento de cota.
Console do Google Cloud
Configurar os parâmetros da instância
No console do Google Cloud, acesse as instâncias do Filestore página.
Clique em Criar instância.
Especifique os parâmetros básicos da instância, incluindo nome, instância tipo e capacidade:
- No campo ID da instância, digite o nome que você quer usar para instância do Filestore.
Em Tipo de instância, selecione Regional ou Zonal.
Para criar uma instância empresarial, é necessário executar operações diretamente pela API Filestore.
Em Capacidade alocada, insira a capacidade que você quer usar. Você deve inserir um valor entre 1 TB e 10 TB, em incrementos de 256 GiB (0,25 TiB).
Em Região, selecione a região que você quer usar.
Em Rede VPC, selecione a rede que você quer usar instância do Filestore e clientes NFS.
- Se o Managed Microsoft AD estiver no mesmo projeto que a instância do Filestore, a rede VPC precisará ser autorizada no domínio do Managed Microsoft AD.
- Se o Microsoft AD gerenciado estiver em um projeto separado, a VPC rede deve ser configurada com peering de rede do Active Directory ativado a configuração do Microsoft AD gerenciado.
Em Intervalo de IP alocado, selecione Usar um intervalo de IP alocado automaticamente (recomendado).
Em Protocolo, selecione NFSv4.1.
Configurar as configurações de autenticação da instância
- Configure as configurações de autenticação da instância.
- Clique em Autenticação.
- Selecione o projeto que hospeda o Managed Microsoft AD. Para os fins deste guia, vamos supor que o projeto atual é o que queremos usar.
- Na lista Vincular a um domínio do Active Directory, selecione o domínio do Microsoft AD gerenciado que você quer usar.
- No campo Nome da conta de computador, insira o nome da conta de computador que você quer usar para identificar a instância do Filestore no domínio do Managed Microsoft AD. O nome é limitado a 15 caracteres alfanuméricos.
- No campo Nome do compartilhamento de arquivos, digite o nome do compartilhamento. serão usados pelos clientes NFSv4.1.
No painel Controle de acesso, siga uma destas etapas:
Se estiver usando o Microsoft AD gerenciado, selecione Restringir acesso por endereço IP ou intervalo.
- Defina a regra de acesso por IP ou sub-rede. Para o finalidade deste guia, use as seguintes configurações:
- No campo Endereço IP ou intervalo 1, digite o endereço IP. ou intervalo que você quer usar.
- Clique na lista suspensa Acesso 1 e selecione Administrador.
- Clique na lista suspensa Montar
sec=
1 e selecione as sys.
O proprietário
/
padrão do Filestore éroot
. Para permitir o acesso à instância para outros usuários e grupos, crie uma regra de acesso que permita o acesso à VM de gerenciamento usando o papelAdmin
e a configuração de segurançasec=sys
.Se você não usa o Microsoft AD gerenciado, selecione Conceda acesso a todos os clientes na rede VPC.
Se o Microsoft AD gerenciado não for usado, o único configuração de segurança é
sec=sys
.
Clique em Criar para criar a instância.
gcloud
Instale e inicialize a CLI gcloud.
Se a gcloud CLI já estiver instalada, execute o seguinte comando para atualizá-la:
gcloud components update
Siga uma destas etapas:
Se estiver usando o Microsoft AD gerenciado, execute o seguinte:
gcloud beta filestore instances create
para criar uma zona do Filestore, regional ou empresarial:gcloud beta filestore instances create INSTANCE-ID \ --description="DESCRIPTION" \ --region=LOCATION \ --tier=TIER \ --protocol=PROTOCOL \ --file-share=name="FILE_SHARE_NAME",capacity=CAPACITYTB \ --network=name="VPC_NETWORK",connect-mode=CONNECT_MODE,reserved-ip-range="RESERVED_IP_RANGE" \ --managed-ad=domain=projects/MANAGED_AD_PROJECT_ID/locations/global/domains/MANAGED_AD_DOMAIN_NAME,computer=DOMAIN_COMPUTER_ACCOUNT \ --project=CONSUMER_PROJECT_ID
Substitua:
- INSTANCE_ID é o ID da instância do Filestore; que você quer criar. Consulte Nomear sua instância.
- DESCRIPTION é uma descrição da instância que você quer usar.
- LOCATION é o local em que você quer instância do Filestore para residir.
- TIER é o nível de serviço. que você quer usar.
- PROTOCOL é
NFS_v4_1
. - FILE_SHARE_NAME é o nome que você especifica para o compartilhamento de arquivos NFS que é exibido pela instância.
- CAPACITY é o tamanho que você quer que o compartilhamento de arquivos tenha, entre 1 e 10 TiB.
VPC_NETWORK é o nome da VPC. rede que a instância usará. Consulte Selecionar a rede VPC. Se você quiser especificar uma VPC compartilhada de um serviço projeto, especifique o nome da rede totalmente qualificado, que está no formato
projects/HOST_PROJECT_ID/global/networks/SHARED_VPC_NAME
e você precisa especificarconnect-mode=PRIVATE_SERVICE_ACCESS
, semelhante para o seguinte:--network=name=projects/host/global/networks/shared-vpc-1,connect-mode=PRIVATE_SERVICE_ACCESS
Não é possível especificar uma rede legada para o valor vpc_network. Se necessário, crie uma nova rede VPC a ser usada seguindo as instruções em Criar uma rede VPC de modo automático.
MANAGED_AD_PROJECT_ID é o ID do projeto em que O serviço do Microsoft AD gerenciado está localizado.
MANAGED_AD_DOMAIN_NAME é o nome de domínio do Serviço gerenciado do Microsoft AD que você quer usar. É o domínio o nome escolhido ao criar um Microsoft AD gerenciado. domínio.
DOMAIN_COMPUTER_ACCOUNT é qualquer nome que você quer que o cluster seja chamado no domínio.
CONSUMER_PROJECT_ID é o ID do projeto que contém a instância do Filestore.
CONNECT_MODE é
DIRECT_PEERING
ouPRIVATE_SERVICE_ACCESS
. Se você especificar uma VPC compartilhada como a rede, também precisará especificarPRIVATE_SERVICE_ACCESS
como o modo de conexão. Essa flag é necessária para o peering de rede VPC, que é um requisito ao usar o Microsoft AD gerenciado.RESERVED_IP_RANGE é o intervalo de endereços IP da instância do Filestore. Se você está especificando
connect-mode=PRIVATE_SERVICE_ACCESS
e quer usar um intervalo de endereços IP reservado, especifique o nome de um intervalo de endereço alocado em vez de um intervalo CIDR. Consulte Configurar um endereço IP reservado. Recomendamos que você pule essa flag para permitir que o Filestore encontre automaticamente um intervalo de endereços IP gratuito e o atribua à instância.
Se você não estiver usando o Microsoft AD gerenciado, execute o mesmo comando do etapa anterior para criar uma instância do Filestore; omitindo as sinalizações
--managed-ad
e as sinalizações de peering de rede VPC, ou seja,connect-mode
ereserved-ip-range
. Use o seguinte como exemplo:gcloud beta filestore instances create INSTANCE-ID \ --description="DESCRIPTION" \ --region=LOCATION \ --tier=TIER \ --protocol=PROTOCOL \ --file-share=name="FILE_SHARE_NAME",capacity=CAPACITYTB \ --network=name="VPC_NETWORK" \ --project=CONSUMER_PROJECT_ID
Entender as listas de controle de acesso (ACLs) baseadas em rede no NFSv4.1.
No NFSv3, somente o tipo de segurança sys
é aceito. Esta configuração considera
o usuário uid
e gid
fornecidos pelo cliente durante a montagem.
No protocolo NFSv4.1 do Filestore, várias variações de segurança de ACL de rede ou configurações estiverem disponíveis:
krb5
Autentica o cliente usando um tíquete do Kerberos, que é validado com o servidor Kerberos do Microsoft AD gerenciado.
krb5i
Inclui a autenticação fornecida pelo
krb5
e também usa o Kerberos para executar verificações de integridade de mensagens em todo o tráfego de rede de e para a instância.krb5p
Inclui a autenticação fornecida pelo
krb5
e as verificações de integridade da mensagem dekrb5i
e também usa o Kerberos para criptografia de dados em trânsito.
Para aproveitar essas opções, a integração do serviço gerenciado para o Microsoft Active Directory é obrigatório.
Se um serviço gerenciado para o domínio do Microsoft Active Directory não for especificado, apenas o tipo de segurança sys
será aceito.
Saiba mais em Limitações do NFSv4.1.
Como montar instâncias NFSv4.1 do Filestore em clientes Linux
As etapas a seguir mostram como montar instâncias em clientes Linux.
Faça a montagem com
sec=sys
para permissões NFS padrão:sudo mount -vvvv -t nfs4 -o vers=4.1,sec=sys,rw \ FILESTORE-INSTANCE-FQDN:/INSTANCE_SHARE_POINT /MOUNT_POINT
Ative com
sec=krb5
para autenticação baseada em Kerberos:sudo mount -vvvv -t nfs4 -o vers=4.1,sec=krb5i,rw \ FILESTORE-INSTANCE-FQDN:/INSTANCE_SHARE_POINT /MOUNT_POINT
Montagem com
sec=krb5i
para autenticação baseada em Kerberos e verificações de integridade de mensagens:sudo mount -vvvv -t nfs4 -o vers=4.1,sec=krb5i,rw \ FILESTORE-INSTANCE-FQDN:/INSTANCE_SHARE_POINT /MOUNT_POINT
Monte com
sec=krb5p
para autenticação baseada em Kerberos, verificações de integridade e criptografia em trânsito:sudo mount -vvvv -t nfs4 -o vers=4.1,sec=krb5p,rw \ FILESTORE-INSTANCE-FQDN:/INSTANCE_SHARE_POINT /MOUNT_POINT
Substitua:
- FILESTORE-INSTANCE-FQDN é o nome de domínio totalmente qualificado em que a instância do Filestore está localizada.
- INSTANCE_SHARE_POINT é o nome do compartilhamento de arquivos da instância do Filestore que você quer conectar.
- MOUNT_POINT é o ponto de montagem ou o nome do diretório que você quer montar.
Configuração do cliente Linux
Uma instância do Filestore NFSv4.1 permite que os clientes realizem operações NFS usando vários tipos de segurança. Esses tipos são configurados pelo administrador da instância por ACLs de rede na instância do Filestore NFSv4.1 durante a criação ou se forem atualizados após a criação.
O tipo de segurança sys
usa a autenticação padrão do Unix, enquanto os tipos krb5
,
krb5i
e krb5p
usam a autenticação baseada no Kerberos.
Os tipos krb5
, krb5i
e krb5p
exigem que os clientes estejam conectados ao
mesmo domínio do Microsoft AD gerenciado da instância do Filestore.
Conclua as etapas a seguir adequadas ao seu ambiente.
Imagem do Ubuntu
- Faça SSH na instância do Compute Engine.
Execute os comandos a seguir para ingressar no domínio do Microsoft AD gerenciado.
Execute o comando de configuração a seguir:
sudo apt-get update \ sudo apt-get -y -qq install adcli realmd sssd sssd-tools packagekit krb5-user \ nfs-common expect retry
Quando solicitado o realm, substitua a entrada atual pelo domínio do Microsoft AD gerenciado usado na instância do Filestore. Digite o valor em maiúsculas e pressione a tecla de seta para selecionar OK e pressione Enter.
Quando for solicitado, deixe o campo vazio e prossiga.
Siga uma destas etapas:
Para VMs com um nome de host com menos ou igual a 15 caracteres, execute o comando a seguir:
sudo realm join -vU JOIN_DOMAIN_USER --automatic-id-mapping=no MANAGED_AD_DOMAIN_NAME
Substitua:
- JOIN_DOMAIN_USER é o nome da conta de usuário. usado para fazer parte do domínio.
- MANAGED_AD_DOMAIN_NAME é o nome de domínio do Serviço gerenciado do Microsoft AD que você quer usar.
Para VMs com um nome de host com mais de 15 caracteres, execute o seguinte comando:
sudo realm join -vU JOIN_DOMAIN_USER --automatic-id-mapping=no \ --user-principal=host/`hostname -f`@MANAGED_AD_REALM_NAME MANAGED_AD_DOMAIN_NAME
Substitua:
- JOIN_DOMAIN_USER é o nome da conta de usuário usada para ingressar no domínio.
- MANAGED_AD_REALM_NAME é o nome do domínio do serviço do Microsoft AD gerenciado que você quer usar.
- MANAGED_AD_DOMAIN_NAME é o nome de domínio do Serviço gerenciado do Microsoft AD que você quer usar.
Atualizar configuração do Kerberos. Atualize
/etc/krb5.conf
com o valor definição de realm e mapeamento de domínio de realm:[realms] DOMAIN_NAME = { kdc = DOMAIN_NAME default_domain = DOMAIN_NAME } [domain_realm] .domain_name_lowercase = DOMAIN_NAME domain_name_lowercase = DOMAIN_NAME
Substitua:
- DOMAIN_NAME é o nome de domínio que você quer usar, inserido em maiúsculas.
- domain_name_lowercase é o nome de domínio que você quer usar, digitado em letras minúsculas.
Confira o exemplo a seguir:
[realms] FILE.DEMO.LOCAL = { kdc = FILE.DEMO.LOCAL default_domain = FILE.DEMO.LOCAL } [domain_realm] .file.demo.local = FILE.DEMO.LOCAL file.demo.local = FILE.DEMO.LOCAL
Execute o serviço rpc-gssd. Adicione o seguinte valor de atributo
No-Strip
à seção[General]
dentro de/etc/idmapd.conf
:[General] No-Strip = both
Execute este comando:
sudo systemctl restart rpc-gssd
Imagem de Centos
- Faça SSH para a instância do Compute Engine.
Participe do domínio do Microsoft AD gerenciado:
sudo yum update \ sudo yum install -y adcli realmd sssd samba-common-tools krb5-workstation nfs-utils \ bind-utils openldap-clients
Siga uma destas etapas:
Para VMs com um nome de host com menos ou igual a 15 caracteres, execute o comando abaixo:
sudo realm join -vU JOIN_DOMAIN_USER --automatic-id-mapping=no MANAGED_AD_DOMAIN_NAME
Substitua:
- JOIN_DOMAIN_USER é o nome da conta de usuário usada para ingressar no domínio.
- MANAGED_AD_DOMAIN_NAME é o nome de domínio do Serviço gerenciado do Microsoft AD que você quer usar.
Para VMs com um nome de host com mais de 15 caracteres, execute o seguinte comando:
sudo realm join -vU JOIN_DOMAIN_USER --automatic-id-mapping=no \ --user-principal=host/`hostname -f`@MANAGED_AD_REALM_NAME MANAGED_AD_DOMAIN_NAME
Substitua:
- JOIN_DOMAIN_USER é o nome da conta de usuário. usado para fazer parte do domínio.
- MANAGED_AD_REALM_NAME é o nome do domínio do Serviço gerenciado do Microsoft AD que você quer usar.
- MANAGED_AD_DOMAIN_NAME é o nome de domínio do serviço do Managed Microsoft AD que você quer usar.
Verifique se o serviço sssd está em execução:
sudo systemctl status sssd
Executar o serviço rpc-gssd. Adicione o seguinte abaixo do valor do atributo
No-Strip
à seção[General]
em/etc/idmapd.conf
:[General] No-Strip = both
Execute o comando a seguir. Esse comando ajuda a garantir que o cliente NFS não retira o nome de domínio do nome do host do servidor NFS. Para mais informações, consulte Arquivos da lista Ganesha do NFS e Arch Linux Archive:
sudo systemctl start rpc-gssd
Desconecte e reconecte-se ao Microsoft AD gerenciado de uma instância do Filestore.
Console do Google Cloud
Desconectar um Microsoft AD gerenciado de uma instância do Filestore
Desconecte uma instância do Filestore conectada ao Microsoft AD gerenciado.
No Console do Google Cloud, acesse a página "Instâncias do Filestore".
Clique no código da instância que você quer editar.
No painel Ponto de montagem do NFS, em Protocolo, ao lado de Nome do serviço de diretório, clique em
Desconecte o domínio do AD.Na janela Falha na desconexão do domínio, leia o alerta e clique em Editar instância.
Pelo menos uma regra em Controle de acesso precisa ser mapeada para o papel de administrador com a configuração de segurança de montagem
sys
, por exemplo: Access=Admin Mount esec=
sys.No painel Editar compartilhamento, localize a regra em que O Acesso está definido como Administrador. Clique em Montar
sec=
... e selecionesys
para adicionar essa opção à configuração existente.Clique em OK.
Clique em Salvar.
Ao lado de Nome do serviço de diretório, clique em
Desconecte o domínio do AD.No campo da janela Desconectar do domínio?, digite o nome do domínio que você quer desconectar.
Clique em Desconectar.
Editar as regras de acesso
Atualize a página. Observe que o Nome do serviço de diretório agora está definido como Nenhum.
Clique em Editar.
No painel Editar compartilhamento, localize qualquer regra que defina o acesso para um papel diferente de Administrador, como Editor. Na regra, clique em Monte
sec=
... e selecionesys
para adicioná-la ao do ambiente. Clique em OK.Clique em Salvar.
Atualize a página.
As configurações da regra são atualizadas.
Reconectar um Microsoft AD gerenciado a uma instância do Filestore
Reconectar uma instância do Filestore ao Microsoft AD gerenciado.
No painel Ponto de montagem do NFS, em Protocolo, ao lado de Nome do serviço de diretório, clique em
Participar do domínio do AD.Na janela Juntar esta instância a um domínio do Active Directory, Selecione Usar domínios do projeto atual, no No menu Participe de um domínio do Active Directory, selecione o domínio que você quer usar.
No menu Nome da conta do computador, digite um nome.
Clique em Join Domain.
Atualize a página. O nome do serviço do diretório foi atualizado com sua seleção.
Clique em Editar.
No painel Editar compartilhamento, clique em Monte
sec=
... em todas as regras aplicáveis e remova asys
Clique em OK.Clique em Salvar.
Atualize a página.
As configurações da regra são atualizadas.
A seguir
- Edite uma instância do Filestore.
- Crie uma instância em uma rede VPC compartilhada em projetos de serviço.