Aggiornamento politica di indicizzazione CosmosDb tramite modelli ARM

voti
0

Sto cercando di utilizzare i modelli ARM per aggiornare il criterio di indicizzazione per cosmo contenitore. Ho provato 2 metodi, uno per dichiarare semplicemente il criterio di indicizzazione in mentre dichiara il contenitore in ARM.

{
      apiVersion: [variables('cosmosDbApiVersion')],
      type: Microsoft.DocumentDB/databaseAccounts/apis/databases/containers,
      dependsOn: [ /* resourceId */ ],
      name: /* containerName */,
      properties: {
        resource: {
          id: /* id */,
          partitionKey: {
            paths: [
              /partitionKey
            ],
            kind: Hash
          },
          indexes: [
            {
              indexingMode: consistent,
              automatic: true,
              includedPaths: [
                {
                  path: /*,
                  indexes: [
                    {
                      kind: Range,
                      dataType: Number,
                      precision: -1
                    },
                    {
                      kind: Hash,
                      dataType: String,
                      precision: 3
                    }
                  ]
                }
              ]
            }
          ],
          defaultTtl: [variables('defaultTtlValueToEnableTtl')]
        }
      }
    },

La seconda era di usare usare ARM per impostazione contenitore implementazione in quanto tale:

{
      apiVersion: [variables('cosmosDbApiVersion')],
      type: Microsoft.DocumentDB/databaseAccounts/apis/databases/containers/settings,
      name: [/* name */,
      dependsOn: [  /* container name */ ],
      properties: {
        resource: {
          throughput: /* some throughput */,
          indexes: [
            {
              indexingMode: consistent,
              automatic: true,
              includedPaths: [
                {
                  path: /*,
                  indexes: [
                    {
                      kind: Range,
                      dataType: Number,
                      precision: -1
                    },
                    {
                      kind: Hash,
                      dataType: String,
                      precision: 3
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    },

Entrambe le tecniche non mancano distribuzione ma la politica di indicizzazione non cambia.

Apprezzerebbe un certo aiuto.

È pubblicato 14/02/2020 alle 00:00
fonte dall'utente
In altre lingue...                            


2 risposte

voti
0

questo è l'esempio dal riferimento del modello (un aspetto leggermente diverso da quello che stai facendo):

"resource": {
  "id": "string",
  "indexingPolicy": {
    "automatic": "boolean",
    "indexingMode": "string",
    "includedPaths": [
      {
        "path": "string",
        "indexes": [
          {
            "dataType": "string",
            "precision": "integer",
            "kind": "string"
          }
        ]
      }
    ],
    "excludedPaths": [
      {
        "path": "string"
      }
    ],
    "spatialIndexes": [
      {
        "path": "string",
        "types": [
          "string"
        ]
      }
    ]
  },
  xxx
}

https://docs.microsoft.com/en-us/azure/templates/microsoft.documentdb/2019-08-01/databaseaccounts/sqldatabases/containers

Risposto il 14/02/2020 a 07:52
fonte dall'utente

voti
0

tipi Range e indice hash vengono ignorati dal provider di risorse Cosmo ora nuovi contenitori o contenitori che sono stati creati nel corso dell'ultimo anno o giù di lì. ARM non convalida la politica indice che è il motivo per cui il modello verrà distribuire correttamente.

Indice Hash è stata sconsigliata per questi contenitori più recente perché la performance dell'indice gamma della nuova indicizzatore è sorpassa quello di hash Index sono forniti in modo non era più necessario.

Per creare / polizza index Modifica fare riferimento a questo articolo qui sotto. Esistono numerosi esempi di index che implementano tutto da molto semplice politiche più complesse che includono indici compositi, indici spaziali e chiavi univoche.

https://docs.microsoft.com/en-us/azure/cosmos-db/manage-sql-with-resource-manager#create-resource

Risposto il 16/02/2020 a 21:15
fonte dall'utente

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more