Condividi tramite


Microsoft.App processi 2023-05-01

Definizione di risorsa Bicep

Il tipo di risorsa processi può essere distribuito con operazioni destinate a:

  • gruppi di risorse - Vedere i comandi di distribuzione del gruppo di risorse

Per un elenco delle proprietà modificate in ogni versione dell'API, vedere log delle modifiche.

Formato risorsa

Per creare una risorsa Microsoft.App/jobs, aggiungere il bicep seguente al modello.

resource symbolicname 'Microsoft.App/jobs@2023-05-01' = {
  identity: {
    type: 'string'
    userAssignedIdentities: {
      {customized property}: {}
    }
  }
  location: 'string'
  name: 'string'
  properties: {
    configuration: {
      eventTriggerConfig: {
        parallelism: int
        replicaCompletionCount: int
        scale: {
          maxExecutions: int
          minExecutions: int
          pollingInterval: int
          rules: [
            {
              auth: [
                {
                  secretRef: 'string'
                  triggerParameter: 'string'
                }
              ]
              metadata: any(Azure.Bicep.Types.Concrete.AnyType)
              name: 'string'
              type: 'string'
            }
          ]
        }
      }
      manualTriggerConfig: {
        parallelism: int
        replicaCompletionCount: int
      }
      registries: [
        {
          identity: 'string'
          passwordSecretRef: 'string'
          server: 'string'
          username: 'string'
        }
      ]
      replicaRetryLimit: int
      replicaTimeout: int
      scheduleTriggerConfig: {
        cronExpression: 'string'
        parallelism: int
        replicaCompletionCount: int
      }
      secrets: [
        {
          identity: 'string'
          keyVaultUrl: 'string'
          name: 'string'
          value: 'string'
        }
      ]
      triggerType: 'string'
    }
    environmentId: 'string'
    template: {
      containers: [
        {
          args: [
            'string'
          ]
          command: [
            'string'
          ]
          env: [
            {
              name: 'string'
              secretRef: 'string'
              value: 'string'
            }
          ]
          image: 'string'
          name: 'string'
          probes: [
            {
              failureThreshold: int
              httpGet: {
                host: 'string'
                httpHeaders: [
                  {
                    name: 'string'
                    value: 'string'
                  }
                ]
                path: 'string'
                port: int
                scheme: 'string'
              }
              initialDelaySeconds: int
              periodSeconds: int
              successThreshold: int
              tcpSocket: {
                host: 'string'
                port: int
              }
              terminationGracePeriodSeconds: int
              timeoutSeconds: int
              type: 'string'
            }
          ]
          resources: {
            cpu: int
            memory: 'string'
          }
          volumeMounts: [
            {
              mountPath: 'string'
              subPath: 'string'
              volumeName: 'string'
            }
          ]
        }
      ]
      initContainers: [
        {
          args: [
            'string'
          ]
          command: [
            'string'
          ]
          env: [
            {
              name: 'string'
              secretRef: 'string'
              value: 'string'
            }
          ]
          image: 'string'
          name: 'string'
          resources: {
            cpu: int
            memory: 'string'
          }
          volumeMounts: [
            {
              mountPath: 'string'
              subPath: 'string'
              volumeName: 'string'
            }
          ]
        }
      ]
      volumes: [
        {
          mountOptions: 'string'
          name: 'string'
          secrets: [
            {
              path: 'string'
              secretRef: 'string'
            }
          ]
          storageName: 'string'
          storageType: 'string'
        }
      ]
    }
    workloadProfileName: 'string'
  }
  tags: {
    {customized property}: 'string'
  }
}

Valori delle proprietà

Contenitore

Nome Descrizione Valore
argomenti Argomenti del comando di avvio del contenitore. string[]
comando Comando start del contenitore. string[]
Env Variabili di ambiente del contenitore. EnvironmentVar[]
immagine Tag immagine contenitore. corda
nome Nome del contenitore personalizzato. corda
Sonde Elenco di probe per il contenitore. ContainerAppProbe[]
risorse Requisiti delle risorse del contenitore. ContainerResources
volumeMounts Montaggi del volume del contenitore. VolumeMount []

ContainerAppProbe

Nome Descrizione Valore
failureThreshold Errori consecutivi minimi per il probe da considerare non riuscito dopo l'esito positivo. Il valore predefinito è 3. Il valore minimo è 1. Il valore massimo è 10. Int
httpGet HTTPGet specifica la richiesta HTTP da eseguire. ContainerAppProbeHttpGet
initialDelaySeconds Numero di secondi dopo l'avvio del contenitore prima dell'avvio dei probe di attività. Il valore minimo è 1. Il valore massimo è 60. Int
periodSeconds Frequenza (in secondi) per eseguire il probe. Il valore predefinito è 10 secondi. Il valore minimo è 1. Il valore massimo è 240. Int
successThreshold Numero minimo di successi consecutivi che il probe deve essere considerato riuscito dopo aver avuto esito negativo.Minimum consecutive successful for the probe to be consider successful after having failed. Il valore predefinito è 1. Deve essere 1 per la vita e l'avvio. Il valore minimo è 1. Il valore massimo è 10. Int
tcpSocket TCPSocket specifica un'azione che coinvolge una porta TCP. Hook TCP non ancora supportati. ContainerAppProbeTcpSocket
terminationGracePeriodSeconds La durata facoltativa in secondi del pod deve terminare normalmente in caso di errore del probe. Il periodo di tolleranza è la durata in secondi dopo che i processi in esecuzione nel pod vengono inviati un segnale di terminazione e il tempo in cui i processi vengono interrotti forzatamente con un segnale di terminazione. Impostare questo valore più lungo del tempo di pulizia previsto per il processo. Se questo valore è nil, verrà usata la terminazione del podGracePeriodSeconds. In caso contrario, questo valore esegue l'override del valore fornito dalla specifica del pod. Il valore deve essere un numero intero non negativo. Il valore zero indica l'arresto immediato tramite il segnale kill (nessuna opportunità di arresto). Si tratta di un campo alfa e richiede l'abilitazione del controllo delle funzionalità ProbeTerminationGracePeriod. Il valore massimo è 3600 secondi (1 ora) Int
timeoutSeconds Numero di secondi dopo il quale si verifica il timeout del probe. Il valore predefinito è 1 secondo. Il valore minimo è 1. Il valore massimo è 240. Int
digitare Tipo di probe. 'Liveness'
'Idoneità'
'Startup'

ContainerAppProbeHttpGet

Nome Descrizione Valore
ospite Nome host a cui connettersi, per impostazione predefinita viene impostato l'indirizzo IP del pod. È probabile che si voglia impostare "Host" in httpHeaders. corda
httpHeaders Intestazioni personalizzate da impostare nella richiesta. HTTP consente intestazioni ripetute. ContainerAppProbeHttpGetHttpGetHttpHeadersItem[]
sentiero Percorso di accesso nel server HTTP. corda
porto Nome o numero della porta a cui accedere nel contenitore. Il numero deve essere compreso nell'intervallo compreso tra 1 e 65535. Il nome deve essere un IANA_SVC_NAME. int (obbligatorio)
schema Schema da usare per la connessione all'host. Il valore predefinito è HTTP. 'HTTP'
'HTTPS'

ContainerAppProbeHttpGetHttpHeadersItem

Nome Descrizione Valore
nome Nome del campo dell'intestazione stringa (obbligatorio)
valore Valore del campo dell'intestazione stringa (obbligatorio)

ContainerAppProbeTcpSocket

Nome Descrizione Valore
ospite Facoltativo: nome host a cui connettersi, per impostazione predefinita viene impostato l'indirizzo IP del pod. corda
porto Numero o nome della porta a cui accedere nel contenitore. Il numero deve essere compreso nell'intervallo compreso tra 1 e 65535. Il nome deve essere un IANA_SVC_NAME. int (obbligatorio)

ContainerResources

Nome Descrizione Valore
CPU CPU necessaria nei core, ad esempio 0,5 Int
memoria Memoria necessaria, ad esempio "250 Mb" corda

EnvironmentVar

Nome Descrizione Valore
nome Nome della variabile di ambiente. corda
secretRef Nome del segreto dell'app contenitore da cui eseguire il pull del valore della variabile di ambiente. corda
valore Valore della variabile di ambiente non segreto. corda

InitContainer

Nome Descrizione Valore
argomenti Argomenti del comando di avvio del contenitore. string[]
comando Comando start del contenitore. string[]
Env Variabili di ambiente del contenitore. EnvironmentVar[]
immagine Tag immagine contenitore. corda
nome Nome del contenitore personalizzato. corda
risorse Requisiti delle risorse del contenitore. ContainerResources
volumeMounts Montaggi del volume del contenitore. VolumeMount []

JobConfiguration

Nome Descrizione Valore
eventTriggerConfig Attivare la configurazione di un processo basato su eventi. JobConfigurationEventTriggerConfig
manualTriggerConfig Configurazione del trigger manuale per un singolo processo di esecuzione. Replica delle proprietàCompletionCount e parallelismo sono impostati su 1 per impostazione predefinita JobConfigurationManualTriggerConfig
Registri Raccolta di credenziali del registro contenitori privato usate da un processo app contenitore RegistryCredentials[]
replicaRetryLimit Numero massimo di tentativi prima di non riuscire il processo. Int
replicaTimeout Numero massimo di secondi per l'esecuzione di una replica. int (obbligatorio)
scheduleTriggerConfig Pianificazione del trigger ripetuto formattato Cron ("* * * * *") per cronjobs. I completamenti delle proprietà e il parallelismo vengono impostati su 1 per impostazione predefinita JobConfigurationScheduleTriggerConfig
segreti Raccolta di segreti usati da un processo di app contenitore segreto[]
triggerType Tipo di trigger del processo 'Event'
'Manual'
'Schedule' (obbligatorio)

JobConfigurationEventTriggerConfig

Nome Descrizione Valore
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int
scala Ridimensionamento delle configurazioni per i processi basati su eventi. JobScale

JobConfigurationManualTriggerConfig

Nome Descrizione Valore
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int

JobConfigurationScheduleTriggerConfig

Nome Descrizione Valore
cronExpression Pianificazione ripetuta formattata Cron ("* * * * *") di un processo Cron. stringa (obbligatorio)
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int

Proprietà processo

Nome Descrizione Valore
configurazione Proprietà di configurazione processo app contenitore. JobConfiguration
environmentId ID risorsa dell'ambiente. corda
sagoma Definizione del processo app contenitore. JobTemplate di
workloadProfileName Nome del profilo del carico di lavoro da aggiungere per l'esecuzione del processo delle app contenitore. corda

JobScale

Nome Descrizione Valore
maxExecutions Numero massimo di esecuzioni di processi create per un trigger, valore predefinito 100. Int
minExecutions Numero minimo di esecuzioni di processi create per un trigger, valore predefinito 0 Int
pollingInterval Intervallo per controllare ogni origine evento in secondi. Il valore predefinito è 30s Int
norme Regole di ridimensionamento. JobScaleRule []

JobScaleRule

Nome Descrizione Valore
Auth Segreti di autenticazione per la regola di scalabilità. ScaleRuleAuth[]
metadati Proprietà dei metadati per descrivere la regola di scalabilità. qualunque
nome Nome regola di scalabilità corda
digitare Tipo della regola di scalabilità
ad esempio: azure-servicebus, redis e così via.
corda

JobTemplate

Nome Descrizione Valore
contenitori Elenco di definizioni di contenitori per l'app contenitore. contenitore []
initContainers Elenco di contenitori specializzati eseguiti prima dei contenitori dell'app. InitContainer[]
Volumi Elenco delle definizioni di volume per l'app contenitore. volume []

ManagedServiceIdentity

Nome Descrizione Valore
digitare Tipo di identità del servizio gestito (in cui sono consentiti sia i tipi SystemAssigned che UserAssigned). 'Nessuno'
'SystemAssigned'
'SystemAssigned,UserAssigned'
'UserAssigned' (obbligatorio)
userAssignedIdentities Set di identità assegnate dall'utente associate alla risorsa. Le chiavi del dizionario userAssignedIdentities saranno ID risorsa ARM nel formato : '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. I valori del dizionario possono essere oggetti vuoti ({}) nelle richieste. UserAssignedIdentities

Microsoft.App/jobs

Nome Descrizione Valore
identità Identità gestite necessarie da un processo dell'app contenitore per interagire con altri servizi di Azure per non gestire segreti o credenziali nel codice. ManagedServiceIdentity
ubicazione Posizione geografica in cui risiede la risorsa stringa (obbligatorio)
nome Nome della risorsa corda

Vincoli:
Pattern = ^[-\w\._\(\)]+$ (obbligatorio)
proprietà Proprietà specifiche della risorsa processo app contenitore. JobProperties
Tag Tag delle risorse Dizionario di nomi e valori di tag. Vedere tag nei modelli

RegistryCredentials

Nome Descrizione Valore
identità Identità gestita da usare per l'autenticazione con Registro Azure Container. Per le identità assegnate dall'utente, usare l'ID risorsa di identità assegnato dall'utente completo. Per le identità assegnate dal sistema, usare 'system' corda
passwordSecretRef Nome del segreto che contiene la password di accesso del Registro di sistema corda
server Server registro contenitori corda
nome utente Nome utente registro contenitori corda

ScaleRuleAuth

Nome Descrizione Valore
secretRef Nome del segreto da cui eseguire il pull dei parametri di autenticazione. corda
triggerParameter Parametro trigger che usa il segreto corda

Segreto

Nome Descrizione Valore
identità ID risorsa di un'identità gestita per l'autenticazione con Azure Key Vault o Sistema per l'uso di un'identità assegnata dal sistema. corda
keyVaultUrl URL di Azure Key Vault che punta al segreto a cui fa riferimento l'app contenitore. corda
nome Nome segreto. corda
valore Valore segreto. corda

Vincoli:
Valore sensibile. Passare come parametro sicuro.

SecretVolumeItem

Nome Descrizione Valore
sentiero Percorso del segreto del progetto. Se non viene specificato alcun percorso, il percorso predefinito è il nome del segreto elencato in secretRef. corda
secretRef Nome del segreto dell'app contenitore da cui eseguire il pull del valore del segreto. corda

TrackedResourceTags

Nome Descrizione Valore

UserAssignedIdentities

Nome Descrizione Valore

UserAssignedIdentity

Nome Descrizione Valore

Volume

Nome Descrizione Valore
mountOptions Opzioni di montaggio usate durante il montaggio di AzureFile. Deve essere una stringa delimitata da virgole. corda
nome Nome del volume. corda
segreti Elenco dei segreti da aggiungere nel volume. Se non vengono forniti segreti, tutti i segreti nella raccolta verranno aggiunti al volume. SecretVolumeItem[]
storageName Nome della risorsa di archiviazione. Non è necessario specificare emptyDir e secret. corda
storageType Tipo di archiviazione per il volume. Se non specificato, usare EmptyDir. 'AzureFile'
'EmptyDir'
'Secret'

VolumeMount

Nome Descrizione Valore
mountPath Percorso all'interno del contenitore in cui deve essere montato il volume. Non deve contenere ':'. corda
subPath Percorso all'interno del volume da cui deve essere montato il volume del contenitore. Il valore predefinito è "" (radice del volume). corda
volumeName Deve corrispondere al nome di un volume. corda

Definizione di risorsa del modello di Resource Manager

Il tipo di risorsa processi può essere distribuito con operazioni destinate a:

  • gruppi di risorse - Vedere i comandi di distribuzione del gruppo di risorse

Per un elenco delle proprietà modificate in ogni versione dell'API, vedere log delle modifiche.

Formato risorsa

Per creare una risorsa Microsoft.App/jobs, aggiungere il codice JSON seguente al modello.

{
  "type": "Microsoft.App/jobs",
  "apiVersion": "2023-05-01",
  "name": "string",
  "identity": {
    "type": "string",
    "userAssignedIdentities": {
      "{customized property}": {
      }
    }
  },
  "location": "string",
  "properties": {
    "configuration": {
      "eventTriggerConfig": {
        "parallelism": "int",
        "replicaCompletionCount": "int",
        "scale": {
          "maxExecutions": "int",
          "minExecutions": "int",
          "pollingInterval": "int",
          "rules": [
            {
              "auth": [
                {
                  "secretRef": "string",
                  "triggerParameter": "string"
                }
              ],
              "metadata": {},
              "name": "string",
              "type": "string"
            }
          ]
        }
      },
      "manualTriggerConfig": {
        "parallelism": "int",
        "replicaCompletionCount": "int"
      },
      "registries": [
        {
          "identity": "string",
          "passwordSecretRef": "string",
          "server": "string",
          "username": "string"
        }
      ],
      "replicaRetryLimit": "int",
      "replicaTimeout": "int",
      "scheduleTriggerConfig": {
        "cronExpression": "string",
        "parallelism": "int",
        "replicaCompletionCount": "int"
      },
      "secrets": [
        {
          "identity": "string",
          "keyVaultUrl": "string",
          "name": "string",
          "value": "string"
        }
      ],
      "triggerType": "string"
    },
    "environmentId": "string",
    "template": {
      "containers": [
        {
          "args": [ "string" ],
          "command": [ "string" ],
          "env": [
            {
              "name": "string",
              "secretRef": "string",
              "value": "string"
            }
          ],
          "image": "string",
          "name": "string",
          "probes": [
            {
              "failureThreshold": "int",
              "httpGet": {
                "host": "string",
                "httpHeaders": [
                  {
                    "name": "string",
                    "value": "string"
                  }
                ],
                "path": "string",
                "port": "int",
                "scheme": "string"
              },
              "initialDelaySeconds": "int",
              "periodSeconds": "int",
              "successThreshold": "int",
              "tcpSocket": {
                "host": "string",
                "port": "int"
              },
              "terminationGracePeriodSeconds": "int",
              "timeoutSeconds": "int",
              "type": "string"
            }
          ],
          "resources": {
            "cpu": "int",
            "memory": "string"
          },
          "volumeMounts": [
            {
              "mountPath": "string",
              "subPath": "string",
              "volumeName": "string"
            }
          ]
        }
      ],
      "initContainers": [
        {
          "args": [ "string" ],
          "command": [ "string" ],
          "env": [
            {
              "name": "string",
              "secretRef": "string",
              "value": "string"
            }
          ],
          "image": "string",
          "name": "string",
          "resources": {
            "cpu": "int",
            "memory": "string"
          },
          "volumeMounts": [
            {
              "mountPath": "string",
              "subPath": "string",
              "volumeName": "string"
            }
          ]
        }
      ],
      "volumes": [
        {
          "mountOptions": "string",
          "name": "string",
          "secrets": [
            {
              "path": "string",
              "secretRef": "string"
            }
          ],
          "storageName": "string",
          "storageType": "string"
        }
      ]
    },
    "workloadProfileName": "string"
  },
  "tags": {
    "{customized property}": "string"
  }
}

Valori delle proprietà

Contenitore

Nome Descrizione Valore
argomenti Argomenti del comando di avvio del contenitore. string[]
comando Comando start del contenitore. string[]
Env Variabili di ambiente del contenitore. EnvironmentVar[]
immagine Tag immagine contenitore. corda
nome Nome del contenitore personalizzato. corda
Sonde Elenco di probe per il contenitore. ContainerAppProbe[]
risorse Requisiti delle risorse del contenitore. ContainerResources
volumeMounts Montaggi del volume del contenitore. VolumeMount []

ContainerAppProbe

Nome Descrizione Valore
failureThreshold Errori consecutivi minimi per il probe da considerare non riuscito dopo l'esito positivo. Il valore predefinito è 3. Il valore minimo è 1. Il valore massimo è 10. Int
httpGet HTTPGet specifica la richiesta HTTP da eseguire. ContainerAppProbeHttpGet
initialDelaySeconds Numero di secondi dopo l'avvio del contenitore prima dell'avvio dei probe di attività. Il valore minimo è 1. Il valore massimo è 60. Int
periodSeconds Frequenza (in secondi) per eseguire il probe. Il valore predefinito è 10 secondi. Il valore minimo è 1. Il valore massimo è 240. Int
successThreshold Numero minimo di successi consecutivi che il probe deve essere considerato riuscito dopo aver avuto esito negativo.Minimum consecutive successful for the probe to be consider successful after having failed. Il valore predefinito è 1. Deve essere 1 per la vita e l'avvio. Il valore minimo è 1. Il valore massimo è 10. Int
tcpSocket TCPSocket specifica un'azione che coinvolge una porta TCP. Hook TCP non ancora supportati. ContainerAppProbeTcpSocket
terminationGracePeriodSeconds La durata facoltativa in secondi del pod deve terminare normalmente in caso di errore del probe. Il periodo di tolleranza è la durata in secondi dopo che i processi in esecuzione nel pod vengono inviati un segnale di terminazione e il tempo in cui i processi vengono interrotti forzatamente con un segnale di terminazione. Impostare questo valore più lungo del tempo di pulizia previsto per il processo. Se questo valore è nil, verrà usata la terminazione del podGracePeriodSeconds. In caso contrario, questo valore esegue l'override del valore fornito dalla specifica del pod. Il valore deve essere un numero intero non negativo. Il valore zero indica l'arresto immediato tramite il segnale kill (nessuna opportunità di arresto). Si tratta di un campo alfa e richiede l'abilitazione del controllo delle funzionalità ProbeTerminationGracePeriod. Il valore massimo è 3600 secondi (1 ora) Int
timeoutSeconds Numero di secondi dopo il quale si verifica il timeout del probe. Il valore predefinito è 1 secondo. Il valore minimo è 1. Il valore massimo è 240. Int
digitare Tipo di probe. 'Liveness'
'Idoneità'
'Startup'

ContainerAppProbeHttpGet

Nome Descrizione Valore
ospite Nome host a cui connettersi, per impostazione predefinita viene impostato l'indirizzo IP del pod. È probabile che si voglia impostare "Host" in httpHeaders. corda
httpHeaders Intestazioni personalizzate da impostare nella richiesta. HTTP consente intestazioni ripetute. ContainerAppProbeHttpGetHttpGetHttpHeadersItem[]
sentiero Percorso di accesso nel server HTTP. corda
porto Nome o numero della porta a cui accedere nel contenitore. Il numero deve essere compreso nell'intervallo compreso tra 1 e 65535. Il nome deve essere un IANA_SVC_NAME. int (obbligatorio)
schema Schema da usare per la connessione all'host. Il valore predefinito è HTTP. 'HTTP'
'HTTPS'

ContainerAppProbeHttpGetHttpHeadersItem

Nome Descrizione Valore
nome Nome del campo dell'intestazione stringa (obbligatorio)
valore Valore del campo dell'intestazione stringa (obbligatorio)

ContainerAppProbeTcpSocket

Nome Descrizione Valore
ospite Facoltativo: nome host a cui connettersi, per impostazione predefinita viene impostato l'indirizzo IP del pod. corda
porto Numero o nome della porta a cui accedere nel contenitore. Il numero deve essere compreso nell'intervallo compreso tra 1 e 65535. Il nome deve essere un IANA_SVC_NAME. int (obbligatorio)

ContainerResources

Nome Descrizione Valore
CPU CPU necessaria nei core, ad esempio 0,5 Int
memoria Memoria necessaria, ad esempio "250 Mb" corda

EnvironmentVar

Nome Descrizione Valore
nome Nome della variabile di ambiente. corda
secretRef Nome del segreto dell'app contenitore da cui eseguire il pull del valore della variabile di ambiente. corda
valore Valore della variabile di ambiente non segreto. corda

InitContainer

Nome Descrizione Valore
argomenti Argomenti del comando di avvio del contenitore. string[]
comando Comando start del contenitore. string[]
Env Variabili di ambiente del contenitore. EnvironmentVar[]
immagine Tag immagine contenitore. corda
nome Nome del contenitore personalizzato. corda
risorse Requisiti delle risorse del contenitore. ContainerResources
volumeMounts Montaggi del volume del contenitore. VolumeMount []

JobConfiguration

Nome Descrizione Valore
eventTriggerConfig Attivare la configurazione di un processo basato su eventi. JobConfigurationEventTriggerConfig
manualTriggerConfig Configurazione del trigger manuale per un singolo processo di esecuzione. Replica delle proprietàCompletionCount e parallelismo sono impostati su 1 per impostazione predefinita JobConfigurationManualTriggerConfig
Registri Raccolta di credenziali del registro contenitori privato usate da un processo app contenitore RegistryCredentials[]
replicaRetryLimit Numero massimo di tentativi prima di non riuscire il processo. Int
replicaTimeout Numero massimo di secondi per l'esecuzione di una replica. int (obbligatorio)
scheduleTriggerConfig Pianificazione del trigger ripetuto formattato Cron ("* * * * *") per cronjobs. I completamenti delle proprietà e il parallelismo vengono impostati su 1 per impostazione predefinita JobConfigurationScheduleTriggerConfig
segreti Raccolta di segreti usati da un processo di app contenitore segreto[]
triggerType Tipo di trigger del processo 'Event'
'Manual'
'Schedule' (obbligatorio)

JobConfigurationEventTriggerConfig

Nome Descrizione Valore
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int
scala Ridimensionamento delle configurazioni per i processi basati su eventi. JobScale

JobConfigurationManualTriggerConfig

Nome Descrizione Valore
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int

JobConfigurationScheduleTriggerConfig

Nome Descrizione Valore
cronExpression Pianificazione ripetuta formattata Cron ("* * * * *") di un processo Cron. stringa (obbligatorio)
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int

Proprietà processo

Nome Descrizione Valore
configurazione Proprietà di configurazione processo app contenitore. JobConfiguration
environmentId ID risorsa dell'ambiente. corda
sagoma Definizione del processo app contenitore. JobTemplate di
workloadProfileName Nome del profilo del carico di lavoro da aggiungere per l'esecuzione del processo delle app contenitore. corda

JobScale

Nome Descrizione Valore
maxExecutions Numero massimo di esecuzioni di processi create per un trigger, valore predefinito 100. Int
minExecutions Numero minimo di esecuzioni di processi create per un trigger, valore predefinito 0 Int
pollingInterval Intervallo per controllare ogni origine evento in secondi. Il valore predefinito è 30s Int
norme Regole di ridimensionamento. JobScaleRule []

JobScaleRule

Nome Descrizione Valore
Auth Segreti di autenticazione per la regola di scalabilità. ScaleRuleAuth[]
metadati Proprietà dei metadati per descrivere la regola di scalabilità. qualunque
nome Nome regola di scalabilità corda
digitare Tipo della regola di scalabilità
ad esempio: azure-servicebus, redis e così via.
corda

JobTemplate

Nome Descrizione Valore
contenitori Elenco di definizioni di contenitori per l'app contenitore. contenitore []
initContainers Elenco di contenitori specializzati eseguiti prima dei contenitori dell'app. InitContainer[]
Volumi Elenco delle definizioni di volume per l'app contenitore. volume []

ManagedServiceIdentity

Nome Descrizione Valore
digitare Tipo di identità del servizio gestito (in cui sono consentiti sia i tipi SystemAssigned che UserAssigned). 'Nessuno'
'SystemAssigned'
'SystemAssigned,UserAssigned'
'UserAssigned' (obbligatorio)
userAssignedIdentities Set di identità assegnate dall'utente associate alla risorsa. Le chiavi del dizionario userAssignedIdentities saranno ID risorsa ARM nel formato : '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. I valori del dizionario possono essere oggetti vuoti ({}) nelle richieste. UserAssignedIdentities

Microsoft.App/jobs

Nome Descrizione Valore
apiVersion Versione dell'API '2023-05-01'
identità Identità gestite necessarie da un processo dell'app contenitore per interagire con altri servizi di Azure per non gestire segreti o credenziali nel codice. ManagedServiceIdentity
ubicazione Posizione geografica in cui risiede la risorsa stringa (obbligatorio)
nome Nome della risorsa corda

Vincoli:
Pattern = ^[-\w\._\(\)]+$ (obbligatorio)
proprietà Proprietà specifiche della risorsa processo app contenitore. JobProperties
Tag Tag delle risorse Dizionario di nomi e valori di tag. Vedere tag nei modelli
digitare Tipo di risorsa 'Microsoft.App/jobs'

RegistryCredentials

Nome Descrizione Valore
identità Identità gestita da usare per l'autenticazione con Registro Azure Container. Per le identità assegnate dall'utente, usare l'ID risorsa di identità assegnato dall'utente completo. Per le identità assegnate dal sistema, usare 'system' corda
passwordSecretRef Nome del segreto che contiene la password di accesso del Registro di sistema corda
server Server registro contenitori corda
nome utente Nome utente registro contenitori corda

ScaleRuleAuth

Nome Descrizione Valore
secretRef Nome del segreto da cui eseguire il pull dei parametri di autenticazione. corda
triggerParameter Parametro trigger che usa il segreto corda

Segreto

Nome Descrizione Valore
identità ID risorsa di un'identità gestita per l'autenticazione con Azure Key Vault o Sistema per l'uso di un'identità assegnata dal sistema. corda
keyVaultUrl URL di Azure Key Vault che punta al segreto a cui fa riferimento l'app contenitore. corda
nome Nome segreto. corda
valore Valore segreto. corda

Vincoli:
Valore sensibile. Passare come parametro sicuro.

SecretVolumeItem

Nome Descrizione Valore
sentiero Percorso del segreto del progetto. Se non viene specificato alcun percorso, il percorso predefinito è il nome del segreto elencato in secretRef. corda
secretRef Nome del segreto dell'app contenitore da cui eseguire il pull del valore del segreto. corda

TrackedResourceTags

Nome Descrizione Valore

UserAssignedIdentities

Nome Descrizione Valore

UserAssignedIdentity

Nome Descrizione Valore

Volume

Nome Descrizione Valore
mountOptions Opzioni di montaggio usate durante il montaggio di AzureFile. Deve essere una stringa delimitata da virgole. corda
nome Nome del volume. corda
segreti Elenco dei segreti da aggiungere nel volume. Se non vengono forniti segreti, tutti i segreti nella raccolta verranno aggiunti al volume. SecretVolumeItem[]
storageName Nome della risorsa di archiviazione. Non è necessario specificare emptyDir e secret. corda
storageType Tipo di archiviazione per il volume. Se non specificato, usare EmptyDir. 'AzureFile'
'EmptyDir'
'Secret'

VolumeMount

Nome Descrizione Valore
mountPath Percorso all'interno del contenitore in cui deve essere montato il volume. Non deve contenere ':'. corda
subPath Percorso all'interno del volume da cui deve essere montato il volume del contenitore. Il valore predefinito è "" (radice del volume). corda
volumeName Deve corrispondere al nome di un volume. corda

Definizione di risorsa Terraform (provider AzAPI)

Il tipo di risorsa processi può essere distribuito con operazioni destinate a:

  • gruppi di risorse

Per un elenco delle proprietà modificate in ogni versione dell'API, vedere log delle modifiche.

Formato risorsa

Per creare una risorsa Microsoft.App/jobs, aggiungere il modello Terraform seguente.

resource "azapi_resource" "symbolicname" {
  type = "Microsoft.App/jobs@2023-05-01"
  name = "string"
  identity = {
    type = "string"
    userAssignedIdentities = {
      {customized property} = {
      }
    }
  }
  location = "string"
  tags = {
    {customized property} = "string"
  }
  body = jsonencode({
    properties = {
      configuration = {
        eventTriggerConfig = {
          parallelism = int
          replicaCompletionCount = int
          scale = {
            maxExecutions = int
            minExecutions = int
            pollingInterval = int
            rules = [
              {
                auth = [
                  {
                    secretRef = "string"
                    triggerParameter = "string"
                  }
                ]
                metadata = ?
                name = "string"
                type = "string"
              }
            ]
          }
        }
        manualTriggerConfig = {
          parallelism = int
          replicaCompletionCount = int
        }
        registries = [
          {
            identity = "string"
            passwordSecretRef = "string"
            server = "string"
            username = "string"
          }
        ]
        replicaRetryLimit = int
        replicaTimeout = int
        scheduleTriggerConfig = {
          cronExpression = "string"
          parallelism = int
          replicaCompletionCount = int
        }
        secrets = [
          {
            identity = "string"
            keyVaultUrl = "string"
            name = "string"
            value = "string"
          }
        ]
        triggerType = "string"
      }
      environmentId = "string"
      template = {
        containers = [
          {
            args = [
              "string"
            ]
            command = [
              "string"
            ]
            env = [
              {
                name = "string"
                secretRef = "string"
                value = "string"
              }
            ]
            image = "string"
            name = "string"
            probes = [
              {
                failureThreshold = int
                httpGet = {
                  host = "string"
                  httpHeaders = [
                    {
                      name = "string"
                      value = "string"
                    }
                  ]
                  path = "string"
                  port = int
                  scheme = "string"
                }
                initialDelaySeconds = int
                periodSeconds = int
                successThreshold = int
                tcpSocket = {
                  host = "string"
                  port = int
                }
                terminationGracePeriodSeconds = int
                timeoutSeconds = int
                type = "string"
              }
            ]
            resources = {
              cpu = int
              memory = "string"
            }
            volumeMounts = [
              {
                mountPath = "string"
                subPath = "string"
                volumeName = "string"
              }
            ]
          }
        ]
        initContainers = [
          {
            args = [
              "string"
            ]
            command = [
              "string"
            ]
            env = [
              {
                name = "string"
                secretRef = "string"
                value = "string"
              }
            ]
            image = "string"
            name = "string"
            resources = {
              cpu = int
              memory = "string"
            }
            volumeMounts = [
              {
                mountPath = "string"
                subPath = "string"
                volumeName = "string"
              }
            ]
          }
        ]
        volumes = [
          {
            mountOptions = "string"
            name = "string"
            secrets = [
              {
                path = "string"
                secretRef = "string"
              }
            ]
            storageName = "string"
            storageType = "string"
          }
        ]
      }
      workloadProfileName = "string"
    }
  })
}

Valori delle proprietà

Contenitore

Nome Descrizione Valore
argomenti Argomenti del comando di avvio del contenitore. string[]
comando Comando start del contenitore. string[]
Env Variabili di ambiente del contenitore. EnvironmentVar[]
immagine Tag immagine contenitore. corda
nome Nome del contenitore personalizzato. corda
Sonde Elenco di probe per il contenitore. ContainerAppProbe[]
risorse Requisiti delle risorse del contenitore. ContainerResources
volumeMounts Montaggi del volume del contenitore. VolumeMount []

ContainerAppProbe

Nome Descrizione Valore
failureThreshold Errori consecutivi minimi per il probe da considerare non riuscito dopo l'esito positivo. Il valore predefinito è 3. Il valore minimo è 1. Il valore massimo è 10. Int
httpGet HTTPGet specifica la richiesta HTTP da eseguire. ContainerAppProbeHttpGet
initialDelaySeconds Numero di secondi dopo l'avvio del contenitore prima dell'avvio dei probe di attività. Il valore minimo è 1. Il valore massimo è 60. Int
periodSeconds Frequenza (in secondi) per eseguire il probe. Il valore predefinito è 10 secondi. Il valore minimo è 1. Il valore massimo è 240. Int
successThreshold Numero minimo di successi consecutivi che il probe deve essere considerato riuscito dopo aver avuto esito negativo.Minimum consecutive successful for the probe to be consider successful after having failed. Il valore predefinito è 1. Deve essere 1 per la vita e l'avvio. Il valore minimo è 1. Il valore massimo è 10. Int
tcpSocket TCPSocket specifica un'azione che coinvolge una porta TCP. Hook TCP non ancora supportati. ContainerAppProbeTcpSocket
terminationGracePeriodSeconds La durata facoltativa in secondi del pod deve terminare normalmente in caso di errore del probe. Il periodo di tolleranza è la durata in secondi dopo che i processi in esecuzione nel pod vengono inviati un segnale di terminazione e il tempo in cui i processi vengono interrotti forzatamente con un segnale di terminazione. Impostare questo valore più lungo del tempo di pulizia previsto per il processo. Se questo valore è nil, verrà usata la terminazione del podGracePeriodSeconds. In caso contrario, questo valore esegue l'override del valore fornito dalla specifica del pod. Il valore deve essere un numero intero non negativo. Il valore zero indica l'arresto immediato tramite il segnale kill (nessuna opportunità di arresto). Si tratta di un campo alfa e richiede l'abilitazione del controllo delle funzionalità ProbeTerminationGracePeriod. Il valore massimo è 3600 secondi (1 ora) Int
timeoutSeconds Numero di secondi dopo il quale si verifica il timeout del probe. Il valore predefinito è 1 secondo. Il valore minimo è 1. Il valore massimo è 240. Int
digitare Tipo di probe. 'Liveness'
'Idoneità'
'Startup'

ContainerAppProbeHttpGet

Nome Descrizione Valore
ospite Nome host a cui connettersi, per impostazione predefinita viene impostato l'indirizzo IP del pod. È probabile che si voglia impostare "Host" in httpHeaders. corda
httpHeaders Intestazioni personalizzate da impostare nella richiesta. HTTP consente intestazioni ripetute. ContainerAppProbeHttpGetHttpGetHttpHeadersItem[]
sentiero Percorso di accesso nel server HTTP. corda
porto Nome o numero della porta a cui accedere nel contenitore. Il numero deve essere compreso nell'intervallo compreso tra 1 e 65535. Il nome deve essere un IANA_SVC_NAME. int (obbligatorio)
schema Schema da usare per la connessione all'host. Il valore predefinito è HTTP. 'HTTP'
'HTTPS'

ContainerAppProbeHttpGetHttpHeadersItem

Nome Descrizione Valore
nome Nome del campo dell'intestazione stringa (obbligatorio)
valore Valore del campo dell'intestazione stringa (obbligatorio)

ContainerAppProbeTcpSocket

Nome Descrizione Valore
ospite Facoltativo: nome host a cui connettersi, per impostazione predefinita viene impostato l'indirizzo IP del pod. corda
porto Numero o nome della porta a cui accedere nel contenitore. Il numero deve essere compreso nell'intervallo compreso tra 1 e 65535. Il nome deve essere un IANA_SVC_NAME. int (obbligatorio)

ContainerResources

Nome Descrizione Valore
CPU CPU necessaria nei core, ad esempio 0,5 Int
memoria Memoria necessaria, ad esempio "250 Mb" corda

EnvironmentVar

Nome Descrizione Valore
nome Nome della variabile di ambiente. corda
secretRef Nome del segreto dell'app contenitore da cui eseguire il pull del valore della variabile di ambiente. corda
valore Valore della variabile di ambiente non segreto. corda

InitContainer

Nome Descrizione Valore
argomenti Argomenti del comando di avvio del contenitore. string[]
comando Comando start del contenitore. string[]
Env Variabili di ambiente del contenitore. EnvironmentVar[]
immagine Tag immagine contenitore. corda
nome Nome del contenitore personalizzato. corda
risorse Requisiti delle risorse del contenitore. ContainerResources
volumeMounts Montaggi del volume del contenitore. VolumeMount []

JobConfiguration

Nome Descrizione Valore
eventTriggerConfig Attivare la configurazione di un processo basato su eventi. JobConfigurationEventTriggerConfig
manualTriggerConfig Configurazione del trigger manuale per un singolo processo di esecuzione. Replica delle proprietàCompletionCount e parallelismo sono impostati su 1 per impostazione predefinita JobConfigurationManualTriggerConfig
Registri Raccolta di credenziali del registro contenitori privato usate da un processo app contenitore RegistryCredentials[]
replicaRetryLimit Numero massimo di tentativi prima di non riuscire il processo. Int
replicaTimeout Numero massimo di secondi per l'esecuzione di una replica. int (obbligatorio)
scheduleTriggerConfig Pianificazione del trigger ripetuto formattato Cron ("* * * * *") per cronjobs. I completamenti delle proprietà e il parallelismo vengono impostati su 1 per impostazione predefinita JobConfigurationScheduleTriggerConfig
segreti Raccolta di segreti usati da un processo di app contenitore segreto[]
triggerType Tipo di trigger del processo 'Event'
'Manual'
'Schedule' (obbligatorio)

JobConfigurationEventTriggerConfig

Nome Descrizione Valore
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int
scala Ridimensionamento delle configurazioni per i processi basati su eventi. JobScale

JobConfigurationManualTriggerConfig

Nome Descrizione Valore
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int

JobConfigurationScheduleTriggerConfig

Nome Descrizione Valore
cronExpression Pianificazione ripetuta formattata Cron ("* * * * *") di un processo Cron. stringa (obbligatorio)
parallelismo Numero di repliche parallele di un processo che può essere eseguito in un determinato momento. Int
replicaCompletionCount Numero minimo di completamenti delle repliche riuscite prima del completamento complessivo del processo. Int

Proprietà processo

Nome Descrizione Valore
configurazione Proprietà di configurazione processo app contenitore. JobConfiguration
environmentId ID risorsa dell'ambiente. corda
sagoma Definizione del processo app contenitore. JobTemplate di
workloadProfileName Nome del profilo del carico di lavoro da aggiungere per l'esecuzione del processo delle app contenitore. corda

JobScale

Nome Descrizione Valore
maxExecutions Numero massimo di esecuzioni di processi create per un trigger, valore predefinito 100. Int
minExecutions Numero minimo di esecuzioni di processi create per un trigger, valore predefinito 0 Int
pollingInterval Intervallo per controllare ogni origine evento in secondi. Il valore predefinito è 30s Int
norme Regole di ridimensionamento. JobScaleRule []

JobScaleRule

Nome Descrizione Valore
Auth Segreti di autenticazione per la regola di scalabilità. ScaleRuleAuth[]
metadati Proprietà dei metadati per descrivere la regola di scalabilità. qualunque
nome Nome regola di scalabilità corda
digitare Tipo della regola di scalabilità
ad esempio: azure-servicebus, redis e così via.
corda

JobTemplate

Nome Descrizione Valore
contenitori Elenco di definizioni di contenitori per l'app contenitore. contenitore []
initContainers Elenco di contenitori specializzati eseguiti prima dei contenitori dell'app. InitContainer[]
Volumi Elenco delle definizioni di volume per l'app contenitore. volume []

ManagedServiceIdentity

Nome Descrizione Valore
digitare Tipo di identità del servizio gestito (in cui sono consentiti sia i tipi SystemAssigned che UserAssigned). 'Nessuno'
'SystemAssigned'
'SystemAssigned,UserAssigned'
'UserAssigned' (obbligatorio)
userAssignedIdentities Set di identità assegnate dall'utente associate alla risorsa. Le chiavi del dizionario userAssignedIdentities saranno ID risorsa ARM nel formato : '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}. I valori del dizionario possono essere oggetti vuoti ({}) nelle richieste. UserAssignedIdentities

Microsoft.App/jobs

Nome Descrizione Valore
identità Identità gestite necessarie da un processo dell'app contenitore per interagire con altri servizi di Azure per non gestire segreti o credenziali nel codice. ManagedServiceIdentity
ubicazione Posizione geografica in cui risiede la risorsa stringa (obbligatorio)
nome Nome della risorsa corda

Vincoli:
Pattern = ^[-\w\._\(\)]+$ (obbligatorio)
proprietà Proprietà specifiche della risorsa processo app contenitore. JobProperties
Tag Tag delle risorse Dizionario di nomi e valori di tag.
digitare Tipo di risorsa "Microsoft.App/jobs@2023-05-01"

RegistryCredentials

Nome Descrizione Valore
identità Identità gestita da usare per l'autenticazione con Registro Azure Container. Per le identità assegnate dall'utente, usare l'ID risorsa di identità assegnato dall'utente completo. Per le identità assegnate dal sistema, usare 'system' corda
passwordSecretRef Nome del segreto che contiene la password di accesso del Registro di sistema corda
server Server registro contenitori corda
nome utente Nome utente registro contenitori corda

ScaleRuleAuth

Nome Descrizione Valore
secretRef Nome del segreto da cui eseguire il pull dei parametri di autenticazione. corda
triggerParameter Parametro trigger che usa il segreto corda

Segreto

Nome Descrizione Valore
identità ID risorsa di un'identità gestita per l'autenticazione con Azure Key Vault o Sistema per l'uso di un'identità assegnata dal sistema. corda
keyVaultUrl URL di Azure Key Vault che punta al segreto a cui fa riferimento l'app contenitore. corda
nome Nome segreto. corda
valore Valore segreto. corda

Vincoli:
Valore sensibile. Passare come parametro sicuro.

SecretVolumeItem

Nome Descrizione Valore
sentiero Percorso del segreto del progetto. Se non viene specificato alcun percorso, il percorso predefinito è il nome del segreto elencato in secretRef. corda
secretRef Nome del segreto dell'app contenitore da cui eseguire il pull del valore del segreto. corda

TrackedResourceTags

Nome Descrizione Valore

UserAssignedIdentities

Nome Descrizione Valore

UserAssignedIdentity

Nome Descrizione Valore

Volume

Nome Descrizione Valore
mountOptions Opzioni di montaggio usate durante il montaggio di AzureFile. Deve essere una stringa delimitata da virgole. corda
nome Nome del volume. corda
segreti Elenco dei segreti da aggiungere nel volume. Se non vengono forniti segreti, tutti i segreti nella raccolta verranno aggiunti al volume. SecretVolumeItem[]
storageName Nome della risorsa di archiviazione. Non è necessario specificare emptyDir e secret. corda
storageType Tipo di archiviazione per il volume. Se non specificato, usare EmptyDir. 'AzureFile'
'EmptyDir'
'Secret'

VolumeMount

Nome Descrizione Valore
mountPath Percorso all'interno del contenitore in cui deve essere montato il volume. Non deve contenere ':'. corda
subPath Percorso all'interno del volume da cui deve essere montato il volume del contenitore. Il valore predefinito è "" (radice del volume). corda
volumeName Deve corrispondere al nome di un volume. corda