Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improved Argo CD Integration #752

Open
EronWright opened this issue Nov 19, 2024 · 2 comments
Open

Improved Argo CD Integration #752

EronWright opened this issue Nov 19, 2024 · 2 comments
Labels
kind/epic Large new features or investments

Comments

@EronWright
Copy link
Contributor

EronWright commented Nov 19, 2024

While Argo CD doesn't have 'native' support for Pulumi (as opposed to Helm), it should be possible to use Argo to manage Stack objects and thus to delegate to PKO.

Some areas to investigate are:

  1. Stack lifecycle - Argo CD should be able to create and destroy stack objects, with correct ordering of the related objects (KSA, CRB). For example, deleting an object should work gracefully, even when destroyOnFinalize is true.
  2. Resource tracking - resources deployed by Pulumi should appear in the Argo resource view. There's two "topologies" to consider - the physical topology of the Workspace, the Updates - and the logical topology of the managed resources.
  3. Application Sets and multi-cluster deployments. Is it possible to use Pulumi to provision a cluster and register it, and then use an ApplicationSet to apply an application (also using Pulumi) to that cluster?
  4. Argo CD prunes objects that it doesn't recognize, and warns of drift. How to make it understand externally-managed objects?
  5. When the Stack is selected in the UI, is it possible to enrich the UI e.g. with a link to the Pulumi Console.
  6. The health and readiness of the Stack object should be known to Argo CD, e.g. so that the sync operation doesn't appear to end prematurely while the Stack is still syncing.
  7. When the user clicks "Sync", force a resync of the Pulumi stack (e.g. using the pulumi.com/reconciliation-request annotation).
  8. More Kubernetes "events" from PKO to show progress.
  9. Provide lua-based "actions" such as forcing a re-sync.
@EronWright EronWright added the kind/epic Large new features or investments label Nov 19, 2024
@pulumi-bot pulumi-bot added the needs-triage Needs attention from the triage team label Nov 19, 2024
@EronWright
Copy link
Contributor Author

EronWright commented Nov 20, 2024

Some links:

Some findings:

  1. ArgoCD uses foreground deletion by default, and this causes the Workspace to be eagerly deleted during Stack deletion. When destroyOnFinalize is set, a replacement workspace must be provisioned. By using background deletion, the Workspace is left to be garbaged collected. A possible improvement would be to have the stack controller proactively delete the workspace during finalization.
  2. To explicitly trigger a re-sync of the Pulumi program, consider contributing a lua script with a "resync" action, that would set the pulumi.com/reconcilitation-request annotation. To implicitly trigger a re-sync, consider using a hook.
  3. It is possible to disable reconciliation of an Application using skip-reconcile (see ArgoCD Application Pull Controller
    that replicates status). In concept, a Pulumi program could create and update the status of an Application object.
  4. It isn't clear whether automatic label/annotation propagation would work well, e.g. fix: Do not copy all labels from ArgoCD CR to resources we create argoproj-labs/argocd-operator#414

@mikhailshilkov mikhailshilkov removed the needs-triage Needs attention from the triage team label Nov 25, 2024
@project0
Copy link

project0 commented Jan 23, 2025

There is another quirk with ArgoCD i have solved and might be beneficial to know for others. When an application with a stack gets deleted by argocd it will delete all associated resources as well.

Argocd seems to detect by owner reference which objects belongs together, that results resources get being tracked by argo even tough the manager is actually the pulumi operator. This is the case for Workspaces etc..

Image

This situations will unfortunately cause the workspace pod being interrupted by argocd 😬, see also relevant issue #795.

However, i was tried solving this problem by blacklisting the pulumi resources within a associated project. It did not really help. Its gone from UI, but the pod still gets interrupted on deletion.

apiVersion: argoproj.io/v1alpha1
kind: AppProject
metadata:
  name: {{ template "fullname" $ }}
  namespace: argocd
  annotations:
    argocd.argoproj.io/sync-wave: "-20"
spec:
  sourceRepos:
    - '*'
   # prevents argo from managing/tracking resources owned by pulumi operator
  namespaceResourceBlacklist:
    - group: 'auto.pulumi.com'
      kind: Workspace

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kind/epic Large new features or investments
Projects
None yet
Development

No branches or pull requests

4 participants