docs/user-guide/sync_windows.md
Sync windows are configurable windows of time where syncs will either be blocked or allowed. These are defined
by a kind, which can be either allow or deny, a schedule in cron format and a duration along with one or
more of either applications, namespaces and clusters. If more than one option is specified, by default, the enabled options will
be OR-ed. If you want to AND the options, you can tick the Use AND operator option.
Wildcards are supported.
The relationship between Sync Windows and Application resources is many-to-many. This means that an Application resource may be affected by multiple Sync Windows, and that a single Sync Window definition may apply to multiple Application resources.
The relationship between Sync Window and Application is established as part of the definition of Sync Window. Sync Window definition includes a section defining the Application resources to which it applies. There are three mechanisms for selecting the Application resources to which a Sync Window applies:
Application.spec.destination.name and .server fieldsApplication.spec.destination.namespace field.All three mechanisms allow usage of wildcards. The mechanisms are not mutually exclusive, and all three of them can be used in single Sync Window definition.
When multiple selection mechanisms are used, they are effectively ORed, meaning that if any of the selector selects the Application,
then the Application is affected by the Sync Window.
These windows affect the running of both manual and automated syncs but allow an override for manual syncs which is useful if you are only interested in preventing automated syncs or if you need to temporarily override a window to perform a sync.
The windows work in the following way:
allow windows matching an application then syncs will only be allowed when there is an active allow window.deny windows matching an application then all syncs will be denied when the deny windows are active.allow and an active matching deny then syncs will be denied as deny windows override allow windows.The UI and the CLI will both display the state of the sync windows. The UI has a panel which will display different colours depending
on the state. The colours are as follows. Red: sync denied, Orange: manual allowed and Green: sync allowed.
To display the sync state using the CLI:
argocd app get APP
Which will return the sync state and any matching windows.
Name: guestbook
Project: default
Server: in-cluster
Namespace: default
URL: http://localhost:8080/applications/guestbook
Repo: https://github.com/argoproj/argocd-example-apps.git
Target:
Path: guestbook
SyncWindow: Sync Denied
Assigned Windows: deny:0 2 * * *:1h,allow:0 2 3 3 3:1h
Sync Policy: Automated
Sync Status: Synced to (5c2d89b)
Health Status: Healthy
Windows can be created using the CLI:
argocd proj windows add PROJECT \
--kind allow \
--schedule "0 22 * * *" \
--duration 1h \
--applications "*"
Alternatively, they can be created directly in the AppProject manifest:
apiVersion: argoproj.io/v1alpha1
kind: AppProject
metadata:
name: default
spec:
syncWindows:
- kind: allow
schedule: '10 1 * * *'
duration: 1h
applications:
- '*-prod'
manualSync: true
- kind: deny
schedule: '0 22 * * *'
timeZone: "Europe/Amsterdam"
duration: 1h
namespaces:
- default
- kind: allow
schedule: '0 23 * * *'
duration: 1h
clusters:
- in-cluster
- cluster1
In order to perform a sync when syncs are being prevented by a window, you can configure the window to allow manual syncs
using the CLI, UI or directly in the AppProject manifest:
argocd proj windows enable-manual-sync PROJECT ID
To disable
argocd proj windows disable-manual-sync PROJECT ID
Windows can be listed using the CLI or viewed in the UI:
argocd proj windows list PROJECT
ID STATUS KIND SCHEDULE DURATION APPLICATIONS NAMESPACES CLUSTERS MANUALSYNC
0 Active allow * * * * * 1h - - prod1 Disabled
1 Inactive deny * * * * 1 3h - default - Disabled
2 Inactive allow 1 2 * * * 1h prod-* - - Enabled
3 Active deny * * * * * 1h - default - Disabled
All fields of a window can be updated using either the CLI or UI. The applications, namespaces and clusters fields
require the update to contain all of the required values. For example if updating the namespaces field and it already
contains default and kube-system then the new value would have to include those in the list.
argocd proj windows update PROJECT ID --namespaces default,kube-system,prod1