

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

# Bedingungen für eine Phase konfigurieren
<a name="stage-conditions"></a>

Sie können eine Bedingung für eine Phase angeben, z. B. die Überprüfung auf eine bestimmte Variable im Pipeline-Lauf, und dann ein Ergebnis für die Bedingung angeben, z. B. das Überspringen der Phase oder das Scheitern der Phase. Eine Pipeline kann so eingerichtet werden, dass sie während des Laufs nach Phasenbedingungen sucht. Dabei geben Sie Prüfungen für eine Phase an und geben dann an, wie die Phase fortgesetzt werden soll, wenn bestimmte Bedingungen erfüllt sind. Bedingungen enthalten eine oder mehrere Regeln, die in einer Liste von Regeln unter verfügbar sind CodePipeline. Wenn alle Regeln in einer Bedingung erfolgreich sind, ist die Bedingung erfüllt. Sie können Bedingungen so konfigurieren, dass das angegebene Ergebnis wirksam wird, wenn die Kriterien nicht erfüllt sind.

Jede Bedingung hat einen Regelsatz, bei dem es sich um einen geordneten Satz von Regeln handelt, die zusammen ausgewertet werden. Wenn also eine Regel in der Bedingung fehlschlägt, schlägt auch die Bedingung fehl. Sie können Regelbedingungen zur Laufzeit der Pipeline überschreiben.

Bedingungen werden für bestimmte Ausdruckstypen verwendet, und für jede dieser Bedingungen stehen spezifische Ergebnisoptionen wie folgt zur Verfügung: 
+ **Teilnahme** — Die Bedingungen für die Durchführung von Prüfungen, die, wenn sie erfüllt sind, den Eintritt in eine Phase ermöglichen. Regeln stehen mit den folgenden Ergebnisoptionen zur Verfügung: **Fehlgeschlagen** oder **Überspringen**
+ **Bei einem Fehler** — Die Bedingungen für die Durchführung von Prüfungen für die Phase, in der sie fehlschlägt. Regeln werden mit der folgenden Ergebnisoption aktiviert: **Rollback**
+ **Bei Erfolg** — Die Bedingungen für die Durchführung von Prüfungen für die erfolgreiche Phase. **Regeln stehen mit den folgenden Ergebnisoptionen zur Verfügung: **Rollback oder Fehlgeschlagen****

Bedingungen werden durch eine Reihe von *Regeln* für jeden Bedingungstyp unterstützt. 

Für jeden Bedingungstyp gibt es spezifische Aktionen, die durch die Bedingung festgelegt werden. Die Aktion ist das Ergebnis der erfolgreichen oder fehlgeschlagenen Zustandsprüfung. Beispiel: Die Eingangsbedingung (Eingangsbedingung) trifft auf einen Alarm (Regel), dann ist die Prüfung erfolgreich und das Ergebnis (Aktion) ist, dass der Stufeneintrag blockiert ist.

Sie können die AWS CodePipeline Konsole oder die auch verwenden AWS CLI , um eine Phase oder Aktionen in einer Phase manuell rückgängig zu machen oder erneut zu versuchen. Siehe [Bedingungen für eine Phase konfigurieren](#stage-conditions).

**Topics**
+ [Anwendungsfälle für Phasenbedingungen](#stage-conditions-cases)
+ [Überlegungen zu Ergebnissen, die für die Bedingungen der Phase konfiguriert wurden](#stage-conditions-considerations)
+ [Überlegungen zu Regeln, die für die Bedingungen der Phase konfiguriert wurden](#stage-conditions-considerations-rules)
+ [Teilnahmebedingungen erstellen](#stage-conditions-entry)
+ [Bedingungen bei Ausfall erstellen](#stage-conditions-onfailure)
+ [Bedingungen bei Erfolg erstellen](#stage-conditions-onsuccess)
+ [Löschen von Stufenbedingungen](#stage-conditions-delete)
+ [Stufenbedingungen überschreiben](#stage-conditions-override)

## Anwendungsfälle für Phasenbedingungen
<a name="stage-conditions-cases"></a>

Für die Festlegung der Freigabe- und Änderungssicherheit in Pipelines gibt es mehrere Anwendungsfälle unter bestimmten Bedingungen. Im Folgenden finden Sie Beispiele für Anwendungsfälle für Phasenbedingungen.
+ Verwenden Sie eine Eingabebedingung, um eine Bedingung zu definieren, die den CloudWatch Alarmstatus überprüft und dann eine Änderung blockiert, wenn sich die Produktionsumgebung nicht in einem fehlerfreien Zustand befindet.
+ Verwenden Sie eine Eingabebedingung mit einer Wartezeit von 60, um eine Bedingung zu definieren, die ausgewertet wird, wenn alle Aktionen in einer Phase erfolgreich abgeschlossen wurden, und setzen Sie die Änderungen dann rückgängig, wenn ein CloudWatch Alarm innerhalb von 60 Minuten in den ALARM-Status wechselt.
+ Verwenden Sie die Bedingung Bei Erfolg, um eine Bedingung zu definieren, sodass die Regel nach erfolgreichem Abschluss der Phase überprüft, ob die aktuelle Uhrzeit im Bereitstellungsfenster angezeigt wird, und dann, wenn die Regel erfolgreich ist, die Bereitstellung durchführt.

## Überlegungen zu Ergebnissen, die für die Bedingungen der Phase konfiguriert wurden
<a name="stage-conditions-considerations"></a>

Zu den Bedingungen in der Phase sollten folgende Überlegungen angestellt werden:
+ Sie können die automatische Wiederholung der Phase nicht mit OnFailure-Bedingungen verwenden.
+ Bei der Konfiguration einer Bedingung mit einem **Rollback-Ergebnis** kann die Phase nur dann zu einer vorherigen Ausführung zurückkehren, wenn sie in der aktuellen Pipeline-Strukturversion verfügbar ist.
+ Wenn Sie eine Bedingung mit einem **Rollback-Ergebnis** konfigurieren, können Sie nicht zu einer Zielausführungs-ID zurückkehren, bei der es sich um einen Rollback-Ausführungstyp handelt.
+ Bei Eingabebedingungen, die das Ergebnis „**Überspringen**“ verwenden, um die Phase zu überspringen, falls die Bedingung fehlschlägt, werden nur die `VariableCheck` Regeln `LambdaInvoke` und unterstützt.
+ Bei einer Phase mit dem Status **Übersprungen** können Sie keine manuelle Wiederholung der Phase durchführen.
+ **Sie können kein manuelles Rollback zu einer Phase mit dem Status Übersprungen durchführen.**
+ Sie können eine Bedingung nicht überschreiben, wenn die Bedingung mit dem Ergebnis „**Überspringen**“ konfiguriert ist.
+ Mit Ausnahme von „Ergebnisse **überspringen**“ können Sie eine Stufenbedingung überschreiben, wenn Sie eine Pipeline-Ausführung starten. Bei einer Stufenbedingung, bei der eine Überschreibung aktiviert ist, erfolgt die Ausführung wie in der folgenden Tabelle beschrieben.
+   
****    
[See the AWS documentation website for more details](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/stage-conditions.html)

## Überlegungen zu Regeln, die für die Bedingungen der Phase konfiguriert wurden
<a name="stage-conditions-considerations-rules"></a>

Zu den verfügbaren Regeln für Stufenbedingungen sollten folgende Überlegungen angestellt werden:
+ Für die `LambdaInvoke` Regel müssen Sie zuerst die Lambda-Funktion konfigurieren, die in der Regel verwendet werden soll. Halten Sie den ARN für die Lambda-Funktion bereit, wenn Sie die Regel konfigurieren. 
+ Für die `CloudWatchAlarm` Regel müssen Sie zunächst das Ereignis CloudWatch Ereignisse konfigurieren, das in der Regel verwendet werden soll. Halten Sie den Event-ARN bereit, um ihn bereitzustellen, wenn Sie die Regel konfigurieren.

## Teilnahmebedingungen erstellen
<a name="stage-conditions-entry"></a>

Sie können die Eintrittsbedingungen für eine Phase mithilfe der Konsole oder der CLI konfigurieren. Sie konfigurieren die entsprechenden Regeln und Ergebnisse für jede Bedingung. Für ein Rollback-Ergebnis kann die Pipeline nur dann zu einer vorherigen Ausführung zurückkehren, wenn die vorherige Ausführung in der aktuellen Pipeline-Strukturversion gestartet wurde.

Die Schritte stellen ein Beispiel für eine Eingabebedingung dar, die eine Monitorregel verwendet.

Weitere Informationen finden Sie unter [[RuleTypeId](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_RuleTypeId.html)Bedingung](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_Condition.html) und [RuleExecution](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_RuleExecution.html)im *CodePipeline API-Leitfaden*.

### Eingabebedingungen erstellen — Beispiel für eine CloudWatchAlarm Regel (Konsole)
<a name="stage-conditions-entry-console"></a>

Sie können die Teilnahmebedingungen für eine Phase zusammen mit den Regeln und Ergebnissen konfigurieren, die die Phase ausführen soll, wenn die Bedingungen erfüllt sind. 

**Konfigurieren Sie eine Eingabebedingung (Konsole)**

1. Erfüllen Sie alle Voraussetzungen, z. B. das Erstellen der Ressource und des ARN für eine Regel, für die eine Ressource bereitgestellt wird, z. B. die **AWS CloudWatchAlarm**.

1. Melden Sie sich bei der an AWS-Managementkonsole und öffnen Sie die CodePipeline Konsole unter [http://console.aws.amazon. com/codesuite/codepipeline/home](https://console.aws.amazon.com/codesuite/codepipeline/home).

   Die Namen und der Status aller Pipelines, die mit Ihrer verknüpft AWS-Konto sind, werden angezeigt. 

1. Wählen Sie im Feld **Name** den Namen der Pipeline aus, die Sie bearbeiten möchten.

1. Wählen Sie auf der Pipelinedetails-Seite **Edit** aus. 

1. Wählen Sie auf der Seite **Bearbeiten** für die Aktion, die Sie bearbeiten möchten, die Option **Phase bearbeiten** aus.

1. Wählen Sie **Eintragsbedingung hinzufügen** aus. Die Karte mit den **Bedingungen für den Eintritt in die Phase** wird angezeigt. Für diese Bedingung ist die Option **Fehlgeschlagen** verfügbar.

1. Wählen Sie **Regel hinzufügen** aus, und führen Sie dann die folgenden Schritte aus.

   1. Geben Sie im Feld **Regelname** einen Namen für Ihre Regel ein. Geben Sie für dieses Beispiel `MyAlarmRule` ein.

   1. Wählen Sie unter **Regelanbieter** den vorkonfigurierten Regelanbieter aus, den Sie zu Ihrer Bedingung hinzufügen möchten. Wählen Sie für dieses Beispiel aus **AWS CloudWatchAlarm**, und führen Sie dann die folgenden Schritte aus.

   1. Wählen Sie unter **Region** die Region für Ihre Bedingung aus, oder behalten Sie die Standardeinstellung bei.

   1. Wählen Sie im **Feld Alarmname** die CloudWatch Ressource aus, die für die Regel verwendet werden soll. Sie müssen die Ressource bereits in Ihrem Konto erstellt haben.

   1. (Optional) Geben Sie im Feld **Wartezeit** ein, wie lange gewartet CodePipeline werden soll, wenn sich der Alarm bei der ersten Auswertung im ALARM-Status befindet. Wenn der Alarm bei der ersten Überprüfung der Regel den Status OK hat, ist die Regel sofort erfolgreich.

   1. (Optional) Geben Sie alle spezifischen Alarmzustände ein, die überwacht werden sollen, und geben Sie gegebenenfalls den Rollen-ARN ein.

   1. Wenn Sie mit der Bearbeitung der Phase fertig sind, wählen Sie **Fertig**. Wählen Sie auf der Seite zur Bearbeitung der Pipeline die Option **Speichern** aus.

1. Sehen Sie sich nach dem Lauf das Ergebnis an.

### Eingabebedingungen mit „Ergebnis und `VariableCheck` Regel überspringen“ erstellen (Konsole)
<a name="stage-conditions-entry-skip"></a>

Sie können die Eingabebedingungen für eine Phase so konfigurieren, dass die Phase übersprungen wird, wenn die Eingabebedingung nicht erfüllt ist. Schlägt die Bedingung fehl, wird das Ergebnis aktiviert und die Phase wird übersprungen. **Wenn eine Phase übersprungen wird, lautet der Status der Phase „**Übersprungen**“ und der Aktionsstatus lautet „Nicht ausgeführt“.** Hinweise zu den Bedingungen in Phasen mit „Ergebnisse überspringen“ finden Sie unter. [Überlegungen zu Ergebnissen, die für die Bedingungen der Phase konfiguriert wurden](#stage-conditions-considerations)

Im folgenden Beispiel stellt die Regel zur Variablenprüfung fest, dass der Wert nicht übereinstimmt, und die Erstellungsphase wird übersprungen.

**Konfigurieren Sie eine Eingabebedingung mit einem **Skip-Ergebnis** (Konsole)**

1. Erfüllen Sie alle Voraussetzungen, z. B. das Erstellen der Ressource und des ARN für eine Regel, für die eine Ressource bereitgestellt wird, z. B. die **AWS CloudWatchAlarm**.

1. Melden Sie sich bei der an AWS-Managementkonsole und öffnen Sie die CodePipeline Konsole unter [http://console.aws.amazon. com/codesuite/codepipeline/home](https://console.aws.amazon.com/codesuite/codepipeline/home).

   Die Namen und der Status aller Pipelines, die mit Ihrer verknüpft AWS-Konto sind, werden angezeigt.

1. Wählen Sie im Feld **Name** den Namen der Pipeline aus, die Sie bearbeiten möchten.

1. Wählen Sie auf der Pipelinedetails-Seite **Edit** aus.

1. Wählen Sie auf der Seite **Bearbeiten** für die Aktion, die Sie bearbeiten möchten, die Option **Phase bearbeiten** aus.

1. Wählen Sie „**Eingabebedingung hinzufügen**“ und anschließend „**Überspringen**“ als Ergebnis aus.

1. Wählen Sie **Regel hinzufügen** und führen Sie dann die folgenden Schritte aus.

   1. Geben Sie im Feld **Regelname** einen Namen für Ihre Regel ein. Geben Sie für dieses Beispiel `MyAlarmRule` ein.

   1. Wählen Sie unter **Regelanbieter** den vorkonfigurierten Regelanbieter aus, den Sie zu Ihrer Bedingung hinzufügen möchten. Wählen Sie für dieses Beispiel aus **VariableCheck**, und führen Sie dann die folgenden Schritte aus.  
![Ein Beispiel für einen Release-Prozess mit CodePipeline.](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-cond-fail-skip.png)

   1. Wählen Sie unter **Region** die Region für Ihre Erkrankung aus, oder behalten Sie die Standardeinstellung bei.

   1. Wählen Sie **unter Variable** die Variable aus, mit der Sie vergleichen möchten, z. B. `#{SourceVariables.FullRepositoryName}` für eine Pipeline, die über eine Quellaktion GitHub (per GitHub App) verfügt. Geben Sie den Namen des Repositorys ein und wählen Sie den Operator aus, z. B. **Equals.**

   1. Wenn Sie mit der Bearbeitung der Phase fertig sind, wählen Sie **Fertig**. Wählen Sie auf der Seite zur Bearbeitung der Pipeline die Option **Speichern** aus.

1. Sehen Sie sich nach dem Lauf das Ergebnis an.  
![Ein Beispiel für einen Release-Prozess mit CodePipeline.](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-skipped.png)

1. Um Details zu überprüfen, wählen Sie **Überprüfen**. Das Detail im folgenden Beispiel zeigt, dass das konfigurierte Ergebnis für die Bedingung **Skip** lautet, was nicht überschrieben werden kann. Der Regelstatus lautet **Fehlgeschlagen**, da die Bedingung nicht erfüllt ist.  
![Ein Beispiel für eine Seite mit Bedingungsdetails, auf der die Bedingung „Ergebnis überspringen“ angezeigt wird CodePipeline.](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/condition-exec-details.png)

### Zugangsbedingungen erstellen (CLI)
<a name="stage-conditions-entry-cli"></a>

Um die AWS CLI zur Konfiguration einer Eingabebedingung zu verwenden, verwenden Sie die Befehle zum Erstellen oder Aktualisieren einer Pipeline, wie unter [Eine Pipeline, Phasen und Aktionen erstellen](pipelines-create.md) und beschrieben[Eine Pipeline bearbeiten in CodePipeline](pipelines-edit.md).

**Konfiguration der Bedingung und der Regel oder Regeln (CLI)**
+ Öffnen Sie ein Terminal (Linux, macOS oder Unix) oder eine Befehlszeile (Windows) und verwenden Sie die, AWS CLI um den `update-pipeline` Befehl auszuführen, wobei Sie die Fehlerbedingung in der Pipeline-Struktur angeben. Im folgenden Beispiel wird eine Entry-Bedingung für ein Staging-Objekt mit dem Namen konfiguriert: `Deploy` 

  ```
  {
      "name": "Deploy",
      "actions": [
          {
              "name": "Deploy",
              "actionTypeId": {
                  "category": "Deploy",
                  "owner": "AWS",
                  "provider": "S3",
                  "version": "1"
              },
              "runOrder": 1,
              "configuration": {
                  "BucketName": "MyBucket",
                  "Extract": "false",
                  "ObjectKey": "object.xml"
              },
              "outputArtifacts": [],
              "inputArtifacts": [
                  {
                      "name": "SourceArtifact"
                  }
              ],
              "region": "us-east-1",
              "namespace": "DeployVariables"
          }
      ],
     {{ "beforeEntry": {
          "conditions": [
              {
                  "result": "FAIL",
                  "rules": [
                      {
                          "name": "MyAlarmRule",
                          "ruleTypeId": {
                              "category": "Rule",
                              "owner": "AWS",
                              "provider": "CloudWatchAlarm",
                              "version": "1"
                          },
                          "configuration": {
                              "AlarmName": "CWAlarm",
                              "WaitTime": "1"
                          },
                          "inputArtifacts": [],
                          "region": "us-east-1"
                      }
                  ]
              }
          ]
      }}}
  }
  ```

  *Weitere Informationen zur Konfiguration von Erfolgsbedingungen für das Rollback in der Phase finden Sie [SuccessConditions](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_SuccessConditions.html)in der CodePipeline API-Referenz.*

### Zugangsbedingungen (CFN) erstellen
<a name="stage-conditions-entry-cfn"></a>

Verwenden Sie den `beforeEntry` Parameter, CloudFormation um eine Eingabebedingung zu konfigurieren. Bei der Eingabe führt die Phase die Regel aus und führt das Ergebnis aus.

```
beforeEntry:
     Result: FAIL
```
+ Aktualisieren Sie die Vorlage wie im folgenden Codeausschnitt gezeigt. Im folgenden Beispiel wird eine Eingabebedingung mit der folgenden Regel konfiguriert: `MyMonitorRule` 

  ```
  Name: Deploy
  Actions:
  - Name: Deploy
    ActionTypeId:
      Category: Deploy
      Owner: AWS
      Provider: S3
      Version: '1'
    RunOrder: 1
    Configuration:
      BucketName: MyBucket
      Extract: 'false'
      ObjectKey: object.xml
    OutputArtifacts: []
    InputArtifacts:
    - Name: SourceArtifact
    Region: us-east-1
    Namespace: DeployVariables
  BeforeEntry:
    Conditions:
    - Result: FAIL
      Rules:
      - Name: MyMonitorRule
        RuleTypeId:
          Category: Rule
          Owner: AWS
          Provider: CloudWatchAlarm
          Version: '1'
        Configuration:
          AlarmName: CWAlarm
          WaitTime: '1'
        InputArtifacts: []
        Region: us-east-1
  ```

  Weitere Informationen zur Konfiguration der BeforeEntry-Bedingungen finden Sie [AWS::CodePipeline::Pipeline BeforeEntryConditions](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-beforeentryconditions.html)unter `StageDeclaration` im *CloudFormation Benutzerhandbuch*.

## Bedingungen bei Ausfall erstellen
<a name="stage-conditions-onfailure"></a>

Sie können die Bedingungen bei einem Ausfall für eine Phase mithilfe der Konsole oder der CLI konfigurieren. Sie konfigurieren die entsprechenden Regeln und Ergebnisse für jede Bedingung. Für ein Rollback-Ergebnis kann die Pipeline nur dann zu einer vorherigen Ausführung zurückkehren, wenn die vorherige Ausführung in der aktuellen Pipeline-Strukturversion gestartet wurde.

### Bedingungen bei Ausfall erstellen (Konsole)
<a name="stage-conditions-onfailure-console"></a>

Sie können die Bedingungen bei Ausfall für eine Phase zusammen mit den Regeln und Ergebnissen konfigurieren, die die Phase ausführen soll, wenn die Bedingungen erfüllt sind. 

**Konfigurieren Sie die Bedingung „Bei einem Fehler“ (Konsole)**

1. Erfüllen Sie alle Voraussetzungen, z. B. das Erstellen der Ressource und des ARN für eine Regel, für die eine Ressource bereitgestellt wird, z. B. die **LambdaInvoke**Regel.

1. Melden Sie sich bei der an AWS-Managementkonsole und öffnen Sie die CodePipeline Konsole unter [http://console.aws.amazon. com/codesuite/codepipeline/home](https://console.aws.amazon.com/codesuite/codepipeline/home).

   Die Namen und der Status aller Pipelines, die mit Ihrer verknüpft AWS-Konto sind, werden angezeigt. 

1. Wählen Sie im Feld **Name** den Namen der Pipeline aus, die Sie bearbeiten möchten.

1. Wählen Sie auf der Pipelinedetails-Seite **Edit** aus. 

1. Wählen Sie auf der Seite **Bearbeiten** für die Aktion, die Sie bearbeiten möchten, die Option **Phase bearbeiten** aus.

1. Wählen Sie „**Fehlerbedingung hinzufügen**“. Die Karte mit den **Fehlerbedingungen** wird angezeigt, und für diesen Zustand ist die Option **Rollback** verfügbar.

1. Wählen Sie **Regel hinzufügen** aus, und führen Sie dann die folgenden Schritte aus.

   1. Geben Sie im Feld **Regelname** einen Namen für Ihre Regel ein. Geben Sie für dieses Beispiel `MyLambdaRule` ein.

   1. Wählen Sie unter **Regelanbieter** den vorkonfigurierten Regelanbieter aus, den Sie zu Ihrer Bedingung hinzufügen möchten. Wählen Sie für dieses Beispiel aus **AWS LambdaInvoke**, und führen Sie dann die folgenden Schritte aus.

   1. Wählen Sie unter **Region** die Region für Ihre Bedingung aus, oder behalten Sie die Standardeinstellung bei.

   1. Wählen Sie unter **Eingabeartefakte** das Quellartefakt aus.

   1. Wählen Sie unter **Funktionsname** die Lambda-Ressource aus, die für die Regel verwendet werden soll. Sie müssen die Ressource bereits in Ihrem Konto erstellt haben.

   1. (Optional) Geben Sie im Feld **Benutzerparameter** alle Paare ein, die Parameter für zusätzliche Konfigurationen darstellen.

   1. (Optional) Geben Sie **unter Rolle ARN** den Rollen-ARN ein, falls konfiguriert.

   1. (Optional) Geben Sie im Feld **Timeout in Minuten** die Zeit in Minuten ein, die die Regel vor dem Timeout warten soll.

   1. **Wenn Sie mit der Bearbeitung der Phase fertig sind, wählen Sie Fertig.** Wählen Sie auf der Seite zur Bearbeitung der Pipeline die Option **Speichern** aus.

### OnFailure-Bedingungen mit einem Retry-Ergebnis erstellen — Beispiel (Konsole)
<a name="w2aac36c27b7"></a>

Sie können die OnFailure-Bedingungen für eine Phase so konfigurieren, dass die Phase erneut versucht wird, wenn die Eingabebedingung nicht erfüllt ist. Als Teil dieses Ergebnisses konfigurieren Sie den Wiederholungsmodus und geben an, ob die fehlgeschlagenen Aktionen oder die fehlgeschlagene Phase erneut versucht werden soll.

**Konfiguration einer OnFailure-Bedingung mit einem Wiederholungsergebnis (Konsole)**

1. Erfüllen Sie alle Voraussetzungen, z. B. das Erstellen der Ressource und des ARN für eine Regel, für die eine Ressource bereitgestellt wird, z. B. die **AWS CloudWatchAlarm**.

1. Melden Sie sich bei der an AWS-Managementkonsole und öffnen Sie die CodePipeline Konsole unter [http://console.aws.amazon. com/codesuite/codepipeline/home](https://console.aws.amazon.com/codesuite/codepipeline/home).

   Die Namen und der Status aller Pipelines, die mit Ihrer verknüpft AWS-Konto sind, werden angezeigt. 

1. Wählen Sie im Feld **Name** den Namen der Pipeline aus, die Sie bearbeiten möchten.

1. Wählen Sie auf der Pipelinedetails-Seite **Edit** aus. 

1. Wählen Sie auf der Seite **Bearbeiten** für die Aktion, die Sie bearbeiten möchten, die Option **Phase bearbeiten** aus.

1. Wählen Sie unten in der Phase unter **Automatisierte Stufenkonfiguration:** die Option **Automatische Wiederholung bei Stufenausfall aktivieren** aus. Wählen Sie im **Wiederholungsmodus** entweder die **Phase Fehlgeschlagen wiederholen oder Fehlgeschlagene Aktionen** **wiederholen** aus.  
![Konfiguration des Wiederholungsmodus für eine Phase in. CodePipeline](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-retry-mode.png)

1. Wählen Sie aus, ob Sie eine OnFailure-Bedingung hinzufügen möchten, wählen **Sie dann Regel hinzufügen** und geben Sie eine Regel für die Bedingung ein.

   1. Geben Sie im Feld **Regelname** einen Namen für Ihre Regel ein. Geben Sie für dieses Beispiel `MyAlarmRule` ein.

   1. Wählen Sie unter **Regelanbieter** den vorkonfigurierten Regelanbieter aus, den Sie zu Ihrer Bedingung hinzufügen möchten. Wählen Sie für dieses Beispiel aus **CloudWatchAlarm**, und führen Sie dann die folgenden Schritte aus.

   1. Wählen Sie unter **Region** die Region für Ihre Bedingung aus, oder behalten Sie die Standardeinstellung bei.

   1. Wählen Sie **unter Alarmname** die konfigurierte Ressource für die Warnung aus.

   1. Wenn Sie mit der Bearbeitung der Phase fertig sind, wählen Sie **Fertig**. Wählen Sie auf der Seite zur Bearbeitung der Pipeline die Option **Speichern** aus.

1. Sehen Sie sich nach dem Lauf das Ergebnis an.

### Bedingungen bei Ausfall erstellen (CLI)
<a name="stage-conditions-onfailure-cli"></a>

Um die Bedingung Bei Ausfall AWS CLI zu konfigurieren, verwenden Sie die Befehle, um eine Pipeline zu erstellen oder zu aktualisieren, wie unter [Eine Pipeline, Phasen und Aktionen erstellen](pipelines-create.md) und beschrieben[Eine Pipeline bearbeiten in CodePipeline](pipelines-edit.md).

**Konfiguration der Bedingung und der Regel oder Regeln (CLI)**
+ Öffnen Sie ein Terminal (Linux, macOS oder Unix) oder eine Befehlszeile (Windows) und verwenden Sie die, AWS CLI um den `update-pipeline` Befehl auszuführen, wobei Sie die Fehlerbedingung in der Pipeline-Struktur angeben. Im folgenden Beispiel wird die Bedingung On Failure für ein Staging-Objekt mit dem Namen konfiguriert: `Deploy` 

  ```
  {
      "name": "Deploy",
      "actions": [
          {
              "name": "Deploy",
              "actionTypeId": {
                  "category": "Deploy",
                  "owner": "AWS",
                  "provider": "S3",
                  "version": "1"
              },
              "runOrder": 1,
              "configuration": {
                  "BucketName": "MyBucket",
                  "Extract": "false",
                  "ObjectKey": "object.xml"
              },
              "outputArtifacts": [],
              "inputArtifacts": [
                  {
                      "name": "SourceArtifact"
                  }
              ],
              "region": "us-east-1",
              "namespace": "DeployVariables"
          }
      ],
     {{ "onFailure": {
          "conditions": [
              {
                  "result": "ROLLBACK",
                  "rules": [
                      {
                          "name": "MyLambdaRule",
                          "ruleTypeId": {
                              "category": "Rule",
                              "owner": "AWS",
                              "provider": "LambdaInvoke",
                              "version": "1"
                          },
                          "configuration": {
                              "FunctionName": "my-function"
                          },
                          "inputArtifacts": [
                              {
                                  "name": "SourceArtifact"
                              }
                          ],
                          "region": "us-east-1"
                      }
                  ]
              }
          ]
      }}}
  }
  ```

  Weitere Informationen zur Konfiguration von Fehlerbedingungen finden Sie [FailureConditions](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_FailureConditions.html)in der *CodePipeline API-Referenz*.

### Bedingungen bei Ausfall (CFN) erstellen
<a name="stage-conditions-onfailure-cfn"></a>

Verwenden Sie CloudFormation den `OnFailure` Parameter, um die Bedingung On Failure zu konfigurieren. Bei Erfolg führt die Phase die Regel aus und führt das Ergebnis aus.

```
OnFailure:
     Result: ROLLBACK
```
+ Aktualisieren Sie die Vorlage wie im folgenden Codeausschnitt gezeigt. Im folgenden Beispiel wird eine OnFailure Bedingung mit einer Regel namens konfiguriert: `MyMonitorRule` 

  ```
  name: Deploy
  actions:
  - name: Deploy
    actionTypeId:
      category: Deploy
      owner: AWS
      provider: S3
      version: '1'
    runOrder: 1
    configuration:
      BucketName: MyBucket
      Extract: 'false'
      ObjectKey: object.xml
    outputArtifacts: []
    inputArtifacts:
    - name: SourceArtifact
    region: us-east-1
    namespace: DeployVariables
  OnFailure:
    conditions:
    - result: ROLLBACK
      rules:
      - name: MyMonitorRule
        ruleTypeId:
          category: Rule
          owner: AWS
          provider: CloudWatchAlarm
          version: '1'
        configuration:
          AlarmName: AlarmOnHelloWorldInvocation
          AlarmStates: ALARM
          WaitTime: '1'
        inputArtifacts: []
        region: us-east-1
  ```

  Weitere Informationen zur Konfiguration von Fehlerbedingungen finden Sie [OnFailure](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-stagedeclaration.html#cfn-codepipeline-pipeline-stagedeclaration-onfailure)unter `StageDeclaration` im *CloudFormation Benutzerhandbuch*.

## Bedingungen bei Erfolg erstellen
<a name="stage-conditions-onsuccess"></a>

Sie können On Success-Bedingungen für eine Phase mithilfe der Konsole oder CLI konfigurieren. Sie konfigurieren die entsprechenden Regeln und Ergebnisse für jede Bedingung. Für ein Rollback-Ergebnis kann die Pipeline nur dann zu einer vorherigen Ausführung zurückkehren, wenn die vorherige Ausführung in der aktuellen Pipeline-Strukturversion gestartet wurde.

Die Schritte stellen ein Beispiel für eine Bedingung bei Erfolg dar, die eine Fensterregel für die Bereitstellung verwendet.

Weitere Informationen finden Sie unter [[RuleTypeId](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_RuleTypeId.html)Bedingung](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_Condition.html) und [RuleExecution](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_RuleExecution.html)im *CodePipeline API-Leitfaden*.

### Bedingungen bei Erfolg erstellen (Konsole)
<a name="stage-conditions-onsuccess-console"></a>

Sie können Bedingungen bei Erfolg für eine Phase zusammen mit den Regeln und Ergebnissen konfigurieren, die in der Phase ausgeführt werden sollen, wenn die Bedingungen erfüllt sind. 

**Konfigurieren Sie eine Bedingung „Bei Erfolg“ (Konsole)**

1. Erfüllen Sie alle Voraussetzungen, z. B. das Erstellen der Ressource und des ARN für eine Regel, für die eine Ressource bereitgestellt wird, z. B. die AWS LambdaRule.

1. Melden Sie sich bei der an AWS-Managementkonsole und öffnen Sie die CodePipeline Konsole unter [http://console.aws.amazon. com/codesuite/codepipeline/home](https://console.aws.amazon.com/codesuite/codepipeline/home).

   Die Namen und der Status aller Pipelines, die mit Ihrer verknüpft AWS-Konto sind, werden angezeigt. 

1. Wählen Sie im Feld **Name** den Namen der Pipeline aus, die Sie bearbeiten möchten.

1. Wählen Sie auf der Pipelinedetails-Seite **Edit** aus. 

1. Wählen Sie auf der Seite **Bearbeiten** für die Aktion, die Sie bearbeiten möchten, die Option **Phase bearbeiten** aus.

1. Wählen Sie **Erfolgsbedingung hinzufügen** aus. Die Karte mit der **Bedingung „Erfolg auf der Bühne**“ wird angezeigt. Wählen Sie die Optionen **Rollback** oder **Fail**, die als verfügbare Ergebnisse für diesen Bedingungstyp angezeigt werden. 

1. Wählen Sie **Regel hinzufügen** aus, und führen Sie dann die folgenden Schritte aus.

   1. Geben Sie im Feld **Regelname** einen Namen für Ihre Bedingung ein. Geben Sie für dieses Beispiel `MyDeploymentRule` ein.

   1. Wählen Sie unter **Regelanbieter** die vorkonfigurierte Regel aus, die Sie Ihrer Bedingung hinzufügen möchten. Wählen Sie für dieses Beispiel aus **AWS DeploymentWindow**, und führen Sie dann die folgenden Schritte aus.

   1. Wählen Sie unter **Region** die Region für Ihre Bedingung aus, oder behalten Sie die Standardeinstellung bei.

   1. Geben Sie in **Cron** den Cron-Ausdruck für das Bereitstellungsfenster ein. Der Cron-Ausdruck definiert die Tage und Uhrzeiten, an denen die Bereitstellung zulässig sein soll. Referenzinformationen zu Cron-Ausdrücken finden Sie unter Regeln [mithilfe von Cron- und Rate-Ausdrücken planen](https://docs.aws.amazon.com/eventbridge/latest/userguide/eb-scheduled-rule-pattern.html#eb-cron-expressions).

   1. (Optional) Geben Sie **TimeZone**unter die Zeitzone für das Bereitstellungsfenster ein.

1. Sehen Sie sich nach dem Lauf das Ergebnis an.  
![Eine Beispielbedingung in CodePipeline.](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-condition-onsuccess-deplwin-example-message.png)

### Bedingungen bei Erfolg erstellen (CLI)
<a name="stage-conditions-onsuccess-cli"></a>

Um die Bedingung On Success AWS CLI zu konfigurieren, verwenden Sie die Befehle, um eine Pipeline zu erstellen oder zu aktualisieren, wie unter [Eine Pipeline, Phasen und Aktionen erstellen](pipelines-create.md) und beschrieben[Eine Pipeline bearbeiten in CodePipeline](pipelines-edit.md).

**Konfiguration der Bedingung und der Regel oder Regeln (CLI)**
+ Öffnen Sie ein Terminal (Linux, macOS oder Unix) oder eine Befehlszeile (Windows) und verwenden Sie die, AWS CLI um den `update-pipeline` Befehl auszuführen, wobei Sie die Fehlerbedingung in der Pipeline-Struktur angeben. Im folgenden Beispiel wird die Bedingung On Success für einen Staging-Ordner mit dem Namen „On Success“ konfiguriert`Deploy`, in dem die Regel benannt ist: `MyDeploymentRule` 

  ```
  {
      "name": "Deploy",
      "actions": [
          {
              "name": "Deploy",
              "actionTypeId": {
                  "category": "Deploy",
                  "owner": "AWS",
                  "provider": "S3",
                  "version": "1"
              },
              "runOrder": 1,
              "configuration": {
                  "BucketName": "MyBucket",
                  "Extract": "false",
                  "ObjectKey": "object.xml"
              },
              "outputArtifacts": [],
              "inputArtifacts": [
                  {
                      "name": "SourceArtifact"
                  }
              ],
              "region": "us-east-1",
              "namespace": "DeployVariables"
          }
      ],
     {{ "onSuccess": {
         "conditions": [
              {
                  "result": "FAIL",
                  "rules": [
                      {
                          "name": "MyAlarmRule",
                          "ruleTypeId": {
                              "category": "Rule",
                              "owner": "AWS",
                              "provider": "CloudWatchAlarm",
                              "version": "1"
                          },
                          "configuration": {
                              "AlarmName": "CWAlarm",
                              "WaitTime": "1"
                          },
                          "inputArtifacts": [],
                          "region": "us-east-1"
                      }
                  ]
              }
          ]
      }
  }}}
  ```

  Weitere Informationen zur Konfiguration von Erfolgsbedingungen finden Sie [SuccessConditions](https://docs.aws.amazon.com/codepipeline/latest/APIReference/API_SuccessConditions.html)in der *CodePipeline API-Referenz*.

### Erstellen Sie eine Bedingung bei Erfolg (CFN)
<a name="stage-conditions-onsuccess-cfn"></a>

Verwenden Sie CloudFormation den `OnSuccess` Parameter, um eine On Success-Bedingung zu konfigurieren. Bei Erfolg führt die Phase die Regel aus und führt das Ergebnis aus.

```
OnSuccess:
     Result: ROLLBACK
```
+ Aktualisieren Sie die Vorlage wie im folgenden Codeausschnitt gezeigt. Im folgenden Beispiel wird eine OnSuccess Bedingung mit einer Regel namens konfiguriert: `MyDeploymentWindowRule` 

  ```
  name: Deploy
  actions:
  - name: Deploy
    actionTypeId:
      category: Deploy
      owner: AWS
      provider: S3
      version: '1'
    runOrder: 1
    configuration:
      BucketName: MyBucket
      Extract: 'false'
      ObjectKey: object.xml
    outputArtifacts: []
    inputArtifacts:
    - name: SourceArtifact
    region: us-east-1
    namespace: DeployVariables{{
  onSuccess:
     conditions:
    - result: FAIL
      rules:
      - name: MyMonitorRule
        ruleTypeId:
          category: Rule
          owner: AWS
          provider: CloudWatchAlarm
          version: '1'
        configuration:
          AlarmName: CWAlarm
          WaitTime: '1'
        inputArtifacts: []
        region: us-east-1
  }}
  ```

  Weitere Informationen zur Konfiguration von Fehlerbedingungen für das Stage-Rollback finden Sie [OnFailure](https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-stagedeclaration.html#cfn-codepipeline-pipeline-stagedeclaration-onfailure)unter `StageDeclaration` im *CloudFormation Benutzerhandbuch*.

## Löschen von Stufenbedingungen
<a name="stage-conditions-delete"></a>

Sie können Phasenbedingungen löschen, die für Ihre Pipeline konfiguriert wurden.

**Um eine Phasenbedingung zu löschen**

1. Melden Sie sich bei der an AWS-Managementkonsole und öffnen Sie die CodePipeline Konsole unter [http://console.aws.amazon. com/codesuite/codepipeline/home](https://console.aws.amazon.com/codesuite/codepipeline/home).

   Die Namen und der Status aller Pipelines, die mit Ihrer verknüpft AWS-Konto sind, werden angezeigt. 

1. Wählen Sie im Feld **Name** den Namen der Pipeline aus, die Sie bearbeiten möchten.

1. Wählen Sie auf der Pipelinedetails-Seite **Edit** aus. 

1. Wählen Sie auf der Seite **Bearbeiten** für die Bedingung, die Sie bearbeiten möchten, die Option **Phase bearbeiten** aus.

1. Wählen Sie neben der Bedingung, die Sie löschen möchten, die Option **Bedingung löschen** aus.

## Stufenbedingungen überschreiben
<a name="stage-conditions-override"></a>

Sie können Phasenbedingungen überschreiben, die für Ihre Pipeline konfiguriert wurden. Wenn die Phase und die Regel in der Konsole ausgeführt werden, können Sie festlegen, dass die Stufenbedingung außer Kraft gesetzt wird. Dies führt dazu, dass die Phase läuft 

**Um eine Stufenbedingung zu überschreiben**

1. In diesem Beispiel wird die Pipeline-Phase mit einer Bedingung ausgeführt. Die Schaltfläche „**Überschreiben**“ ist aktiviert.  
![Eine Beispielbedingung in CodePipeline.](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-condition-override-depl.png)

1. Wählen Sie neben der Bedingung, die Sie überschreiben möchten, die Option **Überschreiben** aus.  
![Eine Beispielbedingung in CodePipeline.](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-condition-override-depl-overridden.png)

1. Um Details zu überprüfen, wählen Sie **Überprüfen**. Das Detail im folgenden Beispiel zeigt, dass das konfigurierte Ergebnis für die Bedingung „Fehlgeschlagen“ lautet, was überschrieben wurde. Der Regelstatus ist aufgrund der Überschreibung „Verloren“.  
![Ein Beispiel für eine Seite mit Bedingungsdetails, auf der die überschriebene Bedingung in angezeigt wird. CodePipeline](http://docs.aws.amazon.com/de_de/codepipeline/latest/userguide/images/stage-condition-onsuccess-deplwin-example-message-review.png)