Application Specification

The following describes all the available fields of an Application:

  1. apiVersion: argoproj.io/v1alpha1
  2. kind: Application
  3. metadata:
  4. name: guestbook
  5. # You'll usually want to add your resources to the argocd namespace.
  6. namespace: argocd
  7. # Add this finalizer ONLY if you want these to cascade delete.
  8. finalizers:
  9. # The default behaviour is foreground cascading deletion
  10. - resources-finalizer.argocd.argoproj.io
  11. # Alternatively, you can use background cascading deletion
  12. # - resources-finalizer.argocd.argoproj.io/background
  13. # Add labels to your application object.
  14. labels:
  15. name: guestbook
  16. spec:
  17. # The project the application belongs to.
  18. project: default
  19. # Source of the application manifests
  20. source:
  21. repoURL: https://github.com/argoproj/argocd-example-apps.git # Can point to either a Helm chart repo or a git repo.
  22. targetRevision: HEAD # For Helm, this refers to the chart version.
  23. path: guestbook # This has no meaning for Helm charts pulled directly from a Helm repo instead of git.
  24. # helm specific config
  25. chart: chart-name # Set this when pulling directly from a Helm repo. DO NOT set for git-hosted Helm charts.
  26. helm:
  27. passCredentials: false # If true then adds --pass-credentials to Helm commands to pass credentials to all domains
  28. # Extra parameters to set (same as setting through values.yaml, but these take precedence)
  29. parameters:
  30. - name: "nginx-ingress.controller.service.annotations.external-dns\\.alpha\\.kubernetes\\.io/hostname"
  31. value: mydomain.example.com
  32. - name: "ingress.annotations.kubernetes\\.io/tls-acme"
  33. value: "true"
  34. forceString: true # ensures that value is treated as a string
  35. # Use the contents of files as parameters (uses Helm's --set-file)
  36. fileParameters:
  37. - name: config
  38. path: files/config.json
  39. # Release name override (defaults to application name)
  40. releaseName: guestbook
  41. # Helm values files for overriding values in the helm chart
  42. # The path is relative to the spec.source.path directory defined above
  43. valueFiles:
  44. - values-prod.yaml
  45. # Ignore locally missing valueFiles when installing Helm chart. Defaults to false
  46. ignoreMissingValueFiles: false
  47. # Values file as block file. Prefer to use valuesObject if possible (see below)
  48. values: |
  49. ingress:
  50. enabled: true
  51. path: /
  52. hosts:
  53. - mydomain.example.com
  54. annotations:
  55. kubernetes.io/ingress.class: nginx
  56. kubernetes.io/tls-acme: "true"
  57. labels: {}
  58. tls:
  59. - secretName: mydomain-tls
  60. hosts:
  61. - mydomain.example.com
  62. # Values file as block file. This takes precedence over values
  63. valuesObject:
  64. ingress:
  65. enabled: true
  66. path: /
  67. hosts:
  68. - mydomain.example.com
  69. annotations:
  70. kubernetes.io/ingress.class: nginx
  71. kubernetes.io/tls-acme: "true"
  72. labels: {}
  73. tls:
  74. - secretName: mydomain-tls
  75. hosts:
  76. - mydomain.example.com
  77. # Skip custom resource definition installation if chart contains custom resource definitions. Defaults to false
  78. skipCrds: false
  79. # Optional Helm version to template with. If omitted it will fall back to look at the 'apiVersion' in Chart.yaml
  80. # and decide which Helm binary to use automatically. This field can be either 'v2' or 'v3'.
  81. version: v2
  82. # You can specify the Kubernetes API version to pass to Helm when templating manifests. By default, Argo CD uses
  83. # the Kubernetes version of the target cluster. The value must be semver formatted. Do not prefix with `v`.
  84. kubeVersion: 1.30.0
  85. # You can specify the Kubernetes resource API versions to pass to Helm when templating manifests. By default, Argo
  86. # CD uses the API versions of the target cluster. The format is [group/]version/kind.
  87. apiVersions:
  88. - traefik.io/v1alpha1/TLSOption
  89. - v1/Service
  90. # Optional namespace to template with. If left empty, defaults to the app's destination namespace.
  91. namespace: custom-namespace
  92. # kustomize specific config
  93. kustomize:
  94. # Optional kustomize version. Note: version must be configured in argocd-cm ConfigMap
  95. version: v3.5.4
  96. # Supported kustomize transformers. https://kubectl.docs.kubernetes.io/references/kustomize/kustomization/
  97. namePrefix: prod-
  98. nameSuffix: -some-suffix
  99. commonLabels:
  100. foo: bar
  101. commonAnnotations:
  102. beep: boop-${ARGOCD_APP_REVISION}
  103. # Toggle which enables/disables env variables substitution in commonAnnotations
  104. commonAnnotationsEnvsubst: true
  105. forceCommonLabels: false
  106. forceCommonAnnotations: false
  107. images:
  108. - gcr.io/heptio-images/ks-guestbook-demo:0.2
  109. - my-app=gcr.io/my-repo/my-app:0.1
  110. namespace: custom-namespace
  111. replicas:
  112. - name: kustomize-guestbook-ui
  113. count: 4
  114. components:
  115. - ../component # relative to the kustomization.yaml (`source.path`).
  116. patches:
  117. - target:
  118. kind: Deployment
  119. name: guestbook-ui
  120. patch: |-
  121. - op: add # Add new element to manifest
  122. path: /spec/template/spec/nodeSelector/
  123. value:
  124. env: "pro"
  125. # You can specify the Kubernetes API version to pass to Helm when templating manifests. By default, Argo CD uses
  126. # the Kubernetes version of the target cluster. The value must be semver formatted. Do not prefix with `v`.
  127. kubeVersion: 1.30.0
  128. # You can specify the Kubernetes resource API versions to pass to Helm when templating manifests. By default, Argo
  129. # CD uses the API versions of the target cluster. The format is [group/]version/kind.
  130. apiVersions:
  131. - traefik.io/v1alpha1/TLSOption
  132. - v1/Service
  133. # directory
  134. directory:
  135. recurse: true
  136. jsonnet:
  137. # A list of Jsonnet External Variables
  138. extVars:
  139. - name: foo
  140. value: bar
  141. # You can use "code" to determine if the value is either string (false, the default) or Jsonnet code (if code is true).
  142. - code: true
  143. name: baz
  144. value: "true"
  145. # A list of Jsonnet Top-level Arguments
  146. tlas:
  147. - code: false
  148. name: foo
  149. value: bar
  150. # Exclude contains a glob pattern to match paths against that should be explicitly excluded from being used during
  151. # manifest generation. This takes precedence over the `include` field.
  152. # To match multiple patterns, wrap the patterns in {} and separate them with commas. For example: '{config.yaml,env-use2/*}'
  153. exclude: 'config.yaml'
  154. # Include contains a glob pattern to match paths against that should be explicitly included during manifest
  155. # generation. If this field is set, only matching manifests will be included.
  156. # To match multiple patterns, wrap the patterns in {} and separate them with commas. For example: '{*.yml,*.yaml}'
  157. include: '*.yaml'
  158. # plugin specific config
  159. plugin:
  160. # If the plugin is defined as a sidecar and name is not passed, the plugin will be automatically matched with the
  161. # Application according to the plugin's discovery rules.
  162. name: mypluginname
  163. # environment variables passed to the plugin
  164. env:
  165. - name: FOO
  166. value: bar
  167. # Plugin parameters are new in v2.5.
  168. parameters:
  169. - name: string-param
  170. string: example-string
  171. - name: array-param
  172. array: [item1, item2]
  173. - name: map-param
  174. map:
  175. param-name: param-value
  176. # Sources field specifies the list of sources for the application
  177. sources:
  178. - repoURL: https://github.com/argoproj/argocd-example-apps.git # Can point to either a Helm chart repo or a git repo.
  179. targetRevision: HEAD # For Helm, this refers to the chart version.
  180. path: guestbook # This has no meaning for Helm charts pulled directly from a Helm repo instead of git.
  181. ref: my-repo # For Helm, acts as a reference to this source for fetching values files from this source. Has no meaning when under `source` field
  182. # Destination cluster and namespace to deploy the application
  183. destination:
  184. # cluster API URL
  185. server: https://kubernetes.default.svc
  186. # or cluster name
  187. # name: in-cluster
  188. # The namespace will only be set for namespace-scoped resources that have not set a value for .metadata.namespace
  189. namespace: guestbook
  190. # Extra information to show in the Argo CD Application details tab
  191. info:
  192. - name: 'Example:'
  193. value: 'https://example.com'
  194. # Sync policy
  195. syncPolicy:
  196. automated: # automated sync by default retries failed attempts 5 times with following delays between attempts ( 5s, 10s, 20s, 40s, 80s ); retry controlled using `retry` field.
  197. prune: true # Specifies if resources should be pruned during auto-syncing ( false by default ).
  198. selfHeal: true # Specifies if partial app sync should be executed when resources are changed only in target Kubernetes cluster and no git change detected ( false by default ).
  199. allowEmpty: false # Allows deleting all application resources during automatic syncing ( false by default ).
  200. syncOptions: # Sync options which modifies sync behavior
  201. - Validate=false # disables resource validation (equivalent to 'kubectl apply --validate=false') ( true by default ).
  202. - CreateNamespace=true # Namespace Auto-Creation ensures that namespace specified as the application destination exists in the destination cluster.
  203. - PrunePropagationPolicy=foreground # Supported policies are background, foreground and orphan.
  204. - PruneLast=true # Allow the ability for resource pruning to happen as a final, implicit wave of a sync operation
  205. - RespectIgnoreDifferences=true # When syncing changes, respect fields ignored by the ignoreDifferences configuration
  206. - ApplyOutOfSyncOnly=true # Only sync out-of-sync resources, rather than applying every object in the application
  207. managedNamespaceMetadata: # Sets the metadata for the application namespace. Only valid if CreateNamespace=true (see above), otherwise it's a no-op.
  208. labels: # The labels to set on the application namespace
  209. any: label
  210. you: like
  211. annotations: # The annotations to set on the application namespace
  212. the: same
  213. applies: for
  214. annotations: on-the-namespace
  215. # The retry feature is available since v1.7
  216. retry:
  217. limit: 5 # number of failed sync attempt retries; unlimited number of attempts if less than 0
  218. backoff:
  219. duration: 5s # the amount to back off. Default unit is seconds, but could also be a duration (e.g. "2m", "1h")
  220. factor: 2 # a factor to multiply the base duration after each failed retry
  221. maxDuration: 3m # the maximum amount of time allowed for the backoff strategy
  222. # Will ignore differences between live and desired states during the diff. Note that these configurations are not
  223. # used during the sync process unless the `RespectIgnoreDifferences=true` sync option is enabled.
  224. ignoreDifferences:
  225. # for the specified json pointers
  226. - group: apps
  227. kind: Deployment
  228. jsonPointers:
  229. - /spec/replicas
  230. - kind: ConfigMap
  231. jqPathExpressions:
  232. - '.data["config.yaml"].auth'
  233. # for the specified managedFields managers
  234. - group: "*"
  235. kind: "*"
  236. managedFieldsManagers:
  237. - kube-controller-manager
  238. # Name and namespace are optional. If specified, they must match exactly, these are not glob patterns.
  239. name: my-deployment
  240. namespace: my-namespace
  241. # RevisionHistoryLimit limits the number of items kept in the application's revision history, which is used for
  242. # informational purposes as well as for rollbacks to previous versions. This should only be changed in exceptional
  243. # circumstances. Setting to zero will store no history. This will reduce storage used. Increasing will increase the
  244. # space used to store the history, so we do not recommend increasing it.
  245. revisionHistoryLimit: 10