Atualizando política de indexação CosmosDb através de modelos ARM

votos
0

Eu estou tentando usar modelos ARM para atualizar a política de indexação para o recipiente cosmos. Eu tentei 2 métodos, um para simplesmente declarar a política de indexação na ao declarar o recipiente em 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')]
        }
      }
    },

O segundo foi a utilização de usar ARM a configuração do recipiente de implantação, tais como:

{
      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 as técnicas não falham implantação, mas a política de indexação não muda.

Gostaria de receber alguma ajuda.

Publicado 14/02/2020 em 00:00
fonte usuário
Em outras línguas...                            


2 respostas

votos
0

este é o exemplo da referência modelo (parece um pouco diferentes para o que está fazendo):

"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

Respondeu 14/02/2020 em 07:52
fonte usuário

votos
0

Faixa e índice hash tipos são ignorados pelo provedor de recursos Cosmos agora para novos contentores ou recipientes que foram criados dentro do ano passado ou assim. O ARM não validar a política de índice que é por isso que o modelo irá implantar com êxito.

índice hash foi depreciado por estes mais recente contêiner porque o desempenho do índice de intervalo no novo indexador é supera o hash de índice fornecidos por isso não era mais necessário.

Para criar / Política Modificar o índice se referem a este artigo abaixo. Existem vários exemplos de políticas de índice que implementam tudo, desde muito simples de políticas mais complexas que incluem índices compostos, índices espaciais e chaves únicas.

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

Respondeu 16/02/2020 em 21:15
fonte usuário

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