Aktualizace CosmosDb indexování politiky prostřednictvím ARM šablon

hlasů
0

Snažím se používat ARM šablony aktualizovat indexování politiku pro vesmír kontejneru. Zkoušel jsem 2 způsoby, jeden jednoduše deklarovat politiku indexování a zároveň prohlašuje kontejner v ruce.

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

Druhým bylo použít pouze ARM nastavení nasadit kontejner jako takový:

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

Obě techniky nedojde k nasazení, ale indexování politika nezmění.

Chtěl bych ocenit pomoc.

Položena 14/02/2020 v 00:00
zdroj uživatelem
V jiných jazycích...                            


2 odpovědí

hlasů
0

To je příklad z referenčních šablona (vzhled mírně odlišné od toho, co děláte):

"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

Odpovězeno 14/02/2020 v 07:52
zdroj uživatelem

hlasů
0

Rozsah a hash index typy jsou ignorovány poskytovatel zdrojů Cosmos teď nových nádob nebo nádob, které byly vytvořeny v minulém roce nebo tak nějak. ARM neověřuje index politiku, která je důvod, proč bude šablona úspěšně nasadit.

index hash se nepoužívá pro tyto novější kontejneru, protože výkonnost indexu rozsahu v novém indexeru je předčí co hash index poskytované takže už není nutné.

Chcete-li vytvořit / změnit politiku indexu naleznete v tomto článku níže. Existuje několik příkladů index politik, které provádějí vše od velmi jednoduchý na složitější politiky, které obsahují složené indexy, prostorové indexy a jedinečné klíče.

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

Odpovězeno 16/02/2020 v 21:15
zdroj uživatelem

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