-
Notifications
You must be signed in to change notification settings - Fork 129
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
Support for argocd-apps #226
Comments
This would be great so we could point argocd to a bootstrap repo. The idea is that EKS blueprints manages the "core" helm charts, like external-dns, which should be in all clusters and are rarely changed. ArgoCD points to a bootstrap repo which points to a helm repo(s), and the helm repo manages "application" helm charts, like custom webservers, internal tooling, and most of our charts in general. These charts are changed often. |
I would argue that it would be nicer to have the option to see and manage these core charts and components in the ArgoCD UI rather than Terraform. Even if they rarely change it is easier to see what’s going on and how they are configured if everything is in Argo. Just my 2 cents. |
I completely agree. If you choose to go the route of a GitOps operator, once the controller is deployed, all of the cluster resource provisioning should then be handled through that controller and not through Terraform |
Let's have both, that way we are backwards compatible with v4 and people have the flexibility of choosing their preferred approach. Would you accept a PR for the above feature? It sounds like Logan is willing to contribute if so. |
I don't quite follow - we did not have support for Argo Apps in EKS Blueprints v4. And, per semver, major version changes do not guarantee backwards compatibility. |
Maybe we're talking about two different things? The feature I'm talking about was in v4: https://github.com/aws-ia/terraform-aws-eks-blueprints/blob/8a06a6e7006e4bed5630bd49c7434d76c59e0b5e/modules/kubernetes-addons/variables.tf#L852
True. Backwards compatibility is up to the maintainer's discretion. |
I believe the v4 |
@bryantbiggs I agree with what has been discussed, cluster resource provisioning should be handled through Argo. What I am looking for that the initial bootstrap of ArgoCD. The main reason for raising this was a potential solution to solve the removal of If the above link can solve this problem. This issue can be closed 🤝 Maybe the best path for this is documentation to show the pattern in v5 for bootstrapping Argo as there was for v4. This is what originally led me to raise this issue as I was trying to get an EKS cluster with Argo and an app of apps in one plan and apply cycle. If this approach is not great please let me know. |
The gitops-bridge-dev project is great, but what's the rational of going that length to do something which a CD pipeline can do. Happy to hear any input. |
I guess you could make this argument for any library/module. You want an interface that abstracts away complexity. The interface existed in v4 and is not there in v5 but has been solved in other ways via the gitops-bridge
It would be a fine approach but now you need to maintain your own abstraction to pass data if needed from Terraform to your downstream steps in the CD pipeline. I think this is what @bryantbiggs was discussing in #114 if you now want separate stages you lose the graph capabilities of Terraform and also the ability to easily pass values generated in Terraform (IDs, ARNs, etc.) without your own abstractions. Anyway, this looks to be solved by #209 so closing this issue. An example of how to bootstrap Argo with an app of apps has been posted. Thanks all 🙌 |
This would be very helpful and would reduce confusion for folks (like myself). |
In the same pipeline the step that provision the cluster with ArgoCD deployed can easily pass-on data to next step. If needed output of each step can be saved for future use. How by doing so would result to "losing graph capabilities of Terraform"? After all, this is just about bootstrap the cluster during its creation with addons and business applications. After the bootstrap, suppose further deployment to the cluster should be handle using ArgoCD/Rollout and not terraform anymore. Note there could be a side effect that when the cluster needs to be destroy, you will need to first destroy gitops-bridge resources. |
regarding passing on data values from terrafom to Argo CD deployments, we used a different strategy. resource "github_repository_file" "karpenter_tf" {
repository = data.github_repository.deployments.name
file = "base/${var.argo_cd_cluster_name_repository}/karpenter/terraform-values.yaml"
overwrite_on_create = true
content = <<EOT
## THIS FILE IS GENERATED BY TERRAFORM. DON'T MODIFY. CHANGES WILL BE OVERWRITTEN
x-anchors:
clustername: &clustername ${var.cluster_name}
availabilityZones: &availabilityZones ${join(",", data.aws_availability_zones.good_zone_ids.names)}
awsRegion: &awsRegion ${var.aws_region}
clusterEndpoint: &clusterEndpoint ${try(local.addon_context.aws_eks_cluster_endpoint, null)}
instanceProfile: &instanceProfile ${try(module.karpenter[0].aws_iam_instance_profile_karpenter_name, null)}
interruptionQueueName: &interruptionQueueName ${try(module.karpenter[0].eks_blueprints_kubernetes_addons_karpenter_sqs_interruptionQueueName, null)}
securityGroupSelector: &securityGroupSelector ${join(",", data.aws_security_groups.eks_node_security_groups.ids)}
subnetsInternal: &subnetsInternal ${join(",", local.private_subnets_with_room)}
karpenter:
controller:
env:
- name: AWS_REGION
value: *awsRegion
provisioner:
enable: true
availabilityZones: *availabilityZones
clustername: *clustername
instanceProfile: *instanceProfile
securityGroupSelector: *securityGroupSelector
subnetSelector: *subnetsInternal
settings:
aws:
clusterEndpoint: *clusterEndpoint
clusterName: *clustername
defaultInstanceProfile:
interruptionQueueName: *interruptionQueueName
EOT
} In the ApplicationSet: [...]
spec:
project: default
source:
repoURL: "https://github.com/XXX/deployments.git"
path: "{{ .path.path }}"
targetRevision: HEAD
helm:
ignoreMissingValueFiles: true
passCredentials: true
valueFiles:
- "/common/values.{{ .path.basename }}.yaml"
- "./terraform-values.yaml"
- "./values.yaml"
[...] |
So in order to bootstrap ArgoCD, in addition to this module we will also need to use Relevant: gitops-bridge-dev/gitops-bridge-argocd-control-plane-template#1 |
Finally got it working, I'm now on v5 🎉 . it took a long time because I ran into all sorts of various bugs and configuration issues. terraform-aws-modules/terraform-aws-eks#2525 was particularly troublesome. Specifying I used https://www.github.com/gitops-bridge-dev/gitops-bridge-argocd-bootstrap-terraform, passing in a yaml of an |
Please describe your question here
Currently, in the addons section of the docs for ArgoCD there are resources for deploying ArgoCD;
workflows
,events
, androllouts
. However, there is no sectionargocd-apps
.In past iterations of
terraform-aws-eks-blueprints-addons
there was the ability to configure ArgoCD application and projects. Is there an intention to exposeargocd-apps
through this module?Provide a link to the example/module related to the question
Main helm charts for argocd-apps - https://github.com/argoproj/argo-helm/tree/main/charts/argocd-apps
If there is an intention please just reach out to me and I am happy to implement it.
The text was updated successfully, but these errors were encountered: