Configura una policy di archiviazione

Questo documento mostra come configurare un criterio di archiviazione VM per un cluster Google Distributed Cloud.

Panoramica

In vSphere, Storage Policy Based Management (SPBM) consente di allineare lo spazio di archiviazione alle esigenze delle applicazioni delle macchine virtuali. Fornisce un framework di criteri di archiviazione che funge da unico pannello di controllo unificato per un'ampia gamma di servizi dati e soluzioni di archiviazione.

In Google Distributed Cloud, puoi specificare le norme di archiviazione come alternativa alla specifica dei datastores. Definisci le norme di archiviazione in base ai requisiti dell'applicazione e poi vSphere seleziona e gestisce automaticamente i datastore. In questo modo è possibile ridurre le spese generali e la manutenzione associate all'archiviazione.

Ereditarietà

Puoi specificare un criterio di archiviazione per un cluster utente, un pool di nodi in un cluster utente o un insieme di nodi del control plane in un cluster utente. Puoi anche specificare un criterio di archiviazione per un cluster di amministrazione, a condizione che il cluster di amministrazione disponga di un control plane ad alta disponibilità e non abbia pool di nodi Windows.

Se specifichi un criterio di archiviazione per un cluster utente, il criterio viene ereditato dai pool di nodi nel cluster utente. Se specifichi una policy di archiviazione per un pool di nodi individuale, viene utilizzata questa policy anziché quella a livello di cluster. Allo stesso modo, se specifichi un datastore per un singolo pool di nodi, questo viene utilizzato al posto della policy di archiviazione a livello di cluster.

In un cluster utente in cui è abilitato Controlplane V2, la norma di archiviazione a livello di cluster viene ereditata dai nodi del control plane. Se specifichi una policy di archiviazione o un datastore per i nodi del control plane, vengono utilizzati la policy di archiviazione o il datastore anziché la policy di archiviazione a livello di cluster.

Applicazione delle norme di archiviazione ai datastore

Puoi applicare una norma di archiviazione a un singolo datastore o a più datastore. Se applichi un criterio di archiviazione a più datastore, le risorse di archiviazione per un cluster di amministrazione, un cluster utente o un pool di nodi possono essere distribuite tra i datastore.

Esempio: crea una policy di archiviazione e un cluster utente

Questa sezione fornisce un esempio di creazione di un criterio di archiviazione e di un cluster utente. Questo esempio illustra l'idea che una policy di archiviazione può essere applicata a due datastore.

Applicare tag ai datastore

Per eseguire i passaggi di questo esempio, l'ambiente vSphere deve avere almeno due datastores.

Il cluster vSphere che ospiterà i nodi del cluster utente deve avere accesso ai datastore che prevedi di utilizzare per questo esercizio. Esiste un controllo preflight che lo verifica.

L'account vCenter che utilizzi per applicare i tag deve disporre dei seguenti privilegi di tagging vSphere sul server vCenter root:

  • vSphere Tagging.Create vSphere Tag
  • vSphere Tagging.Create vSphere Tag Category
  • vSphere Tagging.Assign o Unassign vSphere Tag

In vSphere Client, assegna lo stesso tag a ogni datastore che hai scelto di utilizzare per questo esercizio. Per istruzioni, vedi Assegnare tag ai datastore.

Per ulteriori informazioni, vedi Tag e attributi vSphere.

Crea una policy di archiviazione

In vSphere Client, crea una policy di archiviazione VM per il posizionamento basato su tag. Nel criterio di archiviazione, specifica il tag che hai applicato ai datastore che hai scelto. Per istruzioni, vedi Creare una policy di archiviazione VM per il posizionamento basato su tag.

Per ulteriori informazioni, consulta la policy di archiviazione delle VM.

Se utilizzi un datastore vSAN, consulta Policy di archiviazione vSAN.

Creazione di un cluster utente

In questo esercizio, crei un cluster utente con un piano di controllo ad alta disponibilità, quindi ci sono tre nodi del piano di controllo. Oltre ai nodi del piano di controllo, ci sono sei nodi worker, tre in un pool di nodi e tre in un secondo pool di nodi. Tutti i nodi utilizzano indirizzi IP statici.

Inizia seguendo le istruzioni riportate in Creare un cluster utente.

Quando compili il file di configurazione del cluster utente:

  • Imposta il valore di vCenter.storagePolicyName sul nome di una policy di archiviazione esistente. Non impostare un valore per vCenter.datastore.

  • Specifica due node pool. Per il primo pool di nodi, non specificare un datastore e non specificare una policy di archiviazione. Per il secondo pool di nodi, imposta il valore di vsphere.datastore sul nome di un datastore esistente.

File di configurazione del cluster di esempio

Di seguito è riportato un esempio di file di blocco IP e di una parte di un file di configurazione del cluster utente.

user-ipblock.yaml

blocks:
  - netmask: 255.255.255.0
    gateway: 172.16.21.1
    ips:
    - ip: 172.16.21.2
    - ip: 172.16.21.3
    - ip: 172.16.21.4
    - ip: 172.16.21.5
    - ip: 172.16.21.6
    - ip: 172.16.21.7
    - ip: 172.16.21.8

user-cluster-yaml

apiVersion: v1
kind: UserCluster
...
vCenter:
  storagePolicyName: "my-storage-policy"
network:
  hostConfig:
    dnsServers:
    - "203.0.113.2"
    - "198.51.100.2"
    ntpServers:
    - "216.239.35.4"
  ipMode:
    type: "static"
    ipBlockFilePath: "user-ipblock.yaml"
  controlPlaneIPBlock:
    netmask: "255.255.255.0"
    gateway: "172.16.21.1"
    ips:
    - ip: "172.16.21.9"
      hostname: "cp-vm-1"
    - ip: "172.16.21.10"
      hostname: "cp-vm-2"
    - ip: "172.16.21.11"
      hostname: "cp-vm-3"
loadBalancer:
  vips:
    controlPlaneVIP: "172.16.21.40"
    ingressVIP: "172.16.21.30"
  kind: MetalLB
  metalLB:
    addressPools:
    - name: "address-pool-1"
      addresses:
    - "172.16.21.30-172.16.21.39"
...
enableControlplaneV2: true
masterNode:
  cpus: 4
  memoryMB: 8192
  replicas: 3
nodePools:
- name: "worker-pool-1"
  enableLoadBalancer: true
- name: "worker-pool-2"
  vSphere:
    datastore: "my-np2-datastore"
...

Ecco i punti importanti da comprendere nell'esempio precedente:

  • Gli indirizzi IP statici per i nodi worker sono specificati in un file di blocco IP. Il file di blocco IP contiene sette indirizzi anche se ci sono solo sei nodi di lavoro. L'indirizzo IP aggiuntivo è necessario durante l'upgrade, l'aggiornamento e la riparazione automatica del cluster.

  • Gli indirizzi IP statici per i tre nodi del control plane sono specificati nella sezione network.controlPlaneIPBlock del file di configurazione del cluster utente. Non è necessario un indirizzo IP aggiuntivo in questo blocco.

  • Il campo masterNode.replicas è impostato su 3, quindi ci saranno tre nodi del control plane. In masterNode, non è specificato nulla per vsphere.datastore o vsphere.storagePolicyName. Pertanto, i nodi del control plane utilizzeranno la policy di archiviazione specificata in vCenter.storagePolicyName.

  • Il file di configurazione del cluster utente include un valore per vCenter.storagePolicy, ma non include un valore per vCenter.datastore. La policy di archiviazione specificata verrà utilizzata dai nodi di qualsiasi pool che non specifica una propria policy di archiviazione o un proprio datastore.

  • In node-pool-1, non è specificato nulla per vsphere.datastore o vsphere.storagePolicyName. Pertanto, i nodi in node-pool-1 utilizzeranno la policy di archiviazione specificata in vCenter.storagePolicyName.

  • In node-pool-2, il valore di vsphere.datastore è my-np2-datastore, quindi i nodi in node-pool-2 utilizzano questo datastore e non utilizzano un criterio di archiviazione.

Continua a creare il cluster utente come descritto in Creazione di un cluster utente.

Creazione di un cluster utente in un data center separato dal cluster di amministrazione

Un cluster utente può trovarsi in un data center separato dal cluster di amministrazione. I due data center possono utilizzare la stessa istanza di vCenter Server o istanze diverse di vCenter Server.

Questa sezione fornisce un esempio di come creare un cluster utente che utilizza un'istanza separata di vCenter Server dal cluster di amministrazione. Poiché i cluster utente e amministratore utilizzano istanze separate di vCenter Server, si trovano anche in data center separati.

Inizia seguendo le istruzioni riportate in Creare un cluster utente.

Quando compili il file di configurazione del cluster utente:

  • Imposta il valore di vCenter.storagePolicyName sul nome di una policy di archiviazione esistente. Non impostare un valore per vCenter.datastore.

  • In vCenter, specifica i valori per address, datacenter, cluster e resourcePool.

  • Specifica un valore per network.vCenter.networkName.

  • Specifica due node pool. Per il primo pool di nodi, non specificare un datastore e non specificare una policy di archiviazione. Per il secondo pool di nodi, imposta il valore di vsphere.datastore sul nome di un datastore esistente.

File di configurazione del cluster di esempio

Di seguito è riportato un esempio di file di blocco IP e di una parte di un file di configurazione del cluster utente.

user-ipblock.yaml

blocks:
  - netmask: 255.255.255.0
    gateway: 172.16.21.1
    ips:
    - ip: 172.16.21.2
    - ip: 172.16.21.3
    - ip: 172.16.21.4
    - ip: 172.16.21.5
    - ip: 172.16.21.6
    - ip: 172.16.21.7
    - ip: 172.16.21.8

user-cluster-yaml

apiVersion: v1
kind: UserCluster
...
vCenter:
  address: "my-vcenter-server-2.my-domain.example"
  datacenter: "my-uc-data-center"
  cluster: "my-uc-vsphere-cluster"
  resourcePool: "my-uc-resource-pool"
  storagePolicyName: "my-storage-policy"
network:
  vCenter:
    networkName: "my-uc-network"
  hostConfig:
    dnsServers:
    - "203.0.113.2"
    - "198.51.100.2"
    ntpServers:
    - "216.239.35.4"
  ipMode:
    type: "static"
    ipBlockFilePath: "user-ipblock.yaml"
  controlPlaneIPBlock:
    netmask: "255.255.255.0"
    gateway: "172.16.21.1"
    ips:
    - ip: "172.16.21.9"
      hostname: "cp-vm-1"
    - ip: "172.16.21.10"
      hostname: "cp-vm-2"
    - ip: "172.16.21.11"
      hostname: "cp-vm-3"
loadBalancer:
  vips:
    controlPlaneVIP: "172.16.21.40"
    ingressVIP: "172.16.21.30"
  kind: MetalLB
  metalLB:
    addressPools:
    - name: "address-pool-1"
      addresses:
    - "172.16.21.30-172.16.21.39"
...
enableControlplaneV2: true
masterNode:
  cpus: 4
  memoryMB: 8192
  replicas: 3
nodePools:
- name: "worker-pool-1"
  enableLoadBalancer: true
- name: "worker-pool-2"
  vSphere:
    datastore: "my-np2-datastore"
...

Ecco i punti importanti da comprendere nell'esempio precedente:

  • Il file di configurazione del cluster utente include un valore per vCenter.storagePolicy, ma non include un valore per vCenter.datastore. Il criterio di archiviazione specificato verrà utilizzato dai nodi in qualsiasi pool di nodi che non specifica un proprio criterio di archiviazione o un proprio datastore.

  • In vCenter, sono specificati i valori per address, datacenter, cluster e resourcePool. Pertanto, il cluster utente utilizzerà un server vCenter, un data center, un cluster vSphere e un pool di risorse diversi dal cluster di amministrazione.

  • È specificato un valore per network.vCenter.networkName.

  • Il campo masterNode.replicas è impostato su 3, quindi ci saranno tre nodi del control plane. In masterNode, non è specificato nulla per vsphere.datastore o vsphere.storagePolicyName. Pertanto, i nodi del control plane utilizzeranno la policy di archiviazione specificata in vCenter.storagePolicyName.

  • In node-pool-1, non è specificato nulla per vsphere.datastore o vsphere.storagePolicyName. Pertanto, i nodi in node-pool-1 utilizzeranno la policy di archiviazione specificata in vCenter.storagePolicyName.

  • In node-pool-2, il valore di vsphere.datastore è my-np2-datastore, quindi i nodi in node-pool-2 utilizzano questo datastore e non utilizzano un criterio di archiviazione.

Continua a creare il cluster utente come descritto in Creazione di un cluster utente.

Passaggi successivi