Actualización de la política de indexación CosmosDb a través de plantillas ARM

votos
0

Estoy tratando de utilizar las plantillas de ARM para actualizar la política de indexación para contenedores cosmos. Probé 2 métodos, uno para declarar simplemente la política de indexación en tiempo declarando el recipiente en 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')]
        }
      }
    },

El segundo era utilizar a utilizar ARM para implementar de fijación del recipiente como tal:

{
      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
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    },

Ambas técnicas no dejan de despliegue, pero la política de indexación no cambia.

Agradecería un poco de ayuda.

Publicado el 14/02/2020 a las 00:00
fuente por usuario
En otros idiomas...                            


2 respuestas

votos
0

este es el ejemplo de la referencia de la plantilla (aparece un poco diferente a lo que está haciendo):

"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

Respondida el 14/02/2020 a las 07:52
fuente por usuario

votos
0

Los tipos de rango y el índice hash son ignorados por el proveedor de recursos Cosmos ahora para nuevos envases o recipientes que fueron creados en el último año más o menos. ARM no valida la política de índice que es la razón por la plantilla desplegará con éxito.

índice hash está desfasada de estos nuevos contenedores debido a que el rendimiento del índice rango en el nuevo indexador es supera lo de hash índice proporcionado por lo que ya no era necesaria.

Para crear la política de índice / Modificar referirse a este artículo a continuación. Hay varios ejemplos de políticas que implementan índice de todo, desde muy simple a políticas más complejas que incluyen índices compuestos, los índices espaciales y claves únicas.

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

Respondida el 16/02/2020 a las 21:15
fuente por usuario

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