ArgoCD Tutorial for Beginners: GitOps CD for Kubernetes #1

Поделиться
HTML-код
  • Опубликовано: 19 окт 2024

Комментарии • 117

  • @AntonPutra
    @AntonPutra  Год назад +7

    🔴 - To support my channel, I’d like to offer Mentorship/On-the-Job Support/Consulting - me@antonputra.com
    👉 How to Set Up ArgoCD for Production?: ruclips.net/video/_G_RY5trQao/видео.html
    👉 [Playlist] Argo CD Tutorials: ruclips.net/p/PLiMWaCMwGJXkktZoHhmL6sbg7ELNjv9Xw

  • @DevOpsEd
    @DevOpsEd Год назад +15

    I can't really express in words how helpful your tutorials are. Your EKS-Terraform tutorial had saved me a client in my early Fiverr days and this one too is a life-saver. Thanks very much Anton.

    • @AntonPutra
      @AntonPutra  Год назад

      Thanks Raza!

    • @DevOpsEd
      @DevOpsEd Год назад

      @@AntonPutra By the way Anton, which yaml formatting extension are you using here for VSCode? Thanks.

    • @AntonPutra
      @AntonPutra  Год назад +2

      ​@@DevOpsEd
      - Name: YAML
      Id: redhat.vscode-yaml
      Description: YAML Language Support by Red Hat, with built-in Kubernetes syntax support
      Version: 1.12.2
      Publisher: Red Hat
      VS Marketplace Link: marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml

  • @prashlovessamosa
    @prashlovessamosa Год назад +5

    Hey Anton thank you please make more tutorials like these
    Long videos like theses gives us lot of information. Thank you.

    • @AntonPutra
      @AntonPutra  Год назад +1

      Thanks for the feedback. Yes from now on only long format!

  • @bnssoftware3292
    @bnssoftware3292 11 месяцев назад

    Can't believe you don't have more subscribers. You are the go-to guy for me now. Thank you.

  • @yassinekhouaja1257
    @yassinekhouaja1257 Год назад +3

    Thank you, Anton.
    Your tutorials are very informative, and I would appreciate it if you could create more videos like these in the future.
    The length of these videos allows us to gain a lot of valuable knowledge.
    Once again, thank you.

    • @AntonPutra
      @AntonPutra  Год назад +1

      THanks one more is coming soon

    • @yassinekhouaja1257
      @yassinekhouaja1257 Год назад

      @@AntonPutra Great to hear that
      I'm looking forward to seeing your next video.
      Could you suggest any helpful resources for someone who is new to GitOps and DevOps ?

    • @AntonPutra
      @AntonPutra  Год назад

      @@yassinekhouaja1257 kubernetes.io/ for sure

  • @twizzoe
    @twizzoe Год назад +1

    Hi Anton, your contents are GOLD, thanks for the effort you put into these quality videos

  • @djKenpLan09
    @djKenpLan09 6 месяцев назад +1

    Great video! Most creators assume some basic details that you just covered as part as your step-by-step procedure. Thanks for sharing knowledge man!

  • @azerbaijan50
    @azerbaijan50 Год назад +1

    It is basically just perfect! Thank you for your contribution, Anton!

  • @Temp1archik
    @Temp1archik Год назад +1

    Perfect timing. I need it for my new project

  • @OsascogamingBrSP
    @OsascogamingBrSP Год назад +2

    Thank you so much again Anton! It was a very helpful video. I'm sure I learned more than some courses!

  • @agun21st
    @agun21st Год назад +1

    I was looking for this tutorial Sir. Thank you ❤

  • @George-mk7lp
    @George-mk7lp Год назад +2

    I always put like then watching your videos

  • @chasim1982
    @chasim1982 Год назад +1

    Great Tutorial ❤ love it, You are awesome 👌 teacher, thanks a lot.

  • @romanbatrak3763
    @romanbatrak3763 Год назад +1

    Very informative videos ☝🏼👍🏼

  • @coleshores
    @coleshores Год назад

    I am a huge fan of using terraform to deploy with helm as well. It's very nice to have a single module to deploy every applicable resource in a declarative way. It's nice to see someone else using this pattern as well.

    • @AntonPutra
      @AntonPutra  Год назад +2

      It's great for deployments but terraform is not great for managing and keeping the state sync with the source code...

    • @coleshores
      @coleshores Год назад

      @@AntonPutra Im using Terraform to layer down the foundations for continuous deployment. I am using it to deploy kube(proxmox + kubespray in a single tf module), layer down metallb to carve out a small ip space block and configure NFS. Along with little one offs like my Minecraft server and ArgoCD it's self.
      I plan on using ArgoCD in my homelab to become more familiar with GitOps. Your tutorial has been very helpful so far.

  • @ramashish123
    @ramashish123 2 месяца назад +1

    You are a Gem. Excellent detailed explanation.

  • @nishadali940
    @nishadali940 Год назад +1

    Thanks for the tutorial.

  • @aayush5474
    @aayush5474 Год назад +1

    Great tutorial

  • @madrag
    @madrag Год назад +1

    Seem great, how to deal with context deadline exceeded error from terraform? In Git there are lots of "solutions" can't tell what will work

    • @AntonPutra
      @AntonPutra  Год назад

      It depends, if you get context deadline while creating a resource, you can override default and increase the timeline. If you get deadline while destroying infra try to rerun, if it fails most likelly there is a dependency and terraform cannot delete the object. It happens a lot when destroy, you can enable debug log or just remove components manually fro the UI.

  • @pikachu3686
    @pikachu3686 6 месяцев назад +1

    can we use this approach in production i want to deploy this on EKS.

    • @AntonPutra
      @AntonPutra  6 месяцев назад

      Sure, I would say you must use the GitOps approach in production, and ArgoCD and FluxCD are the most widely used tools for that job.

  • @StoyanYordanov-m8w
    @StoyanYordanov-m8w Год назад +1

    Hi, your tutorials helped me land a great job and made me a lot better in Aws, Kubernetes, Terraform and everything else you show on your channel ! Great stuff !! I currently use argo to deploy some apps, but my containers go into loopback, do you have any idea how to troubleshoot them ?

    • @AntonPutra
      @AntonPutra  Год назад

      Thanks! Crashloop? Check logs before it crashes with kubectl logs -p pod. Or check if it crashes with OOM memory. Kubectl describe pod

  • @keratishvili
    @keratishvili Год назад +1

    Hey Anton great video, would love to see maybe fluxCD V2 comparison

  • @Temp1archik
    @Temp1archik Год назад +1

    Hopefully you will add section how to use it via terraform or via the same argocd approach - for the argocd itself. They (argocd) have something called Autopilot for bootstrapping argocd in the kubernetes cluster.
    And moreover - to have that possible video with the AWS EKS cluster. I already built one using you EKS Cluster creation video using terraform (but without cluster autoscaling part).
    And possibly with the information how to expose argocd via ingress, but without using custom domains. I can not find proper guide, how to quickly expose your Kubernetes application (like argoCd) outside, without having your own domain. Or maybe with domain - it is even more important. We all can purchase private domain in case we need it =)
    by the way - great content as always.

    • @AntonPutra
      @AntonPutra  Год назад

      Thanks for the feedback! private domain would require vpn, which i don't want to setup for this tutorial

    • @donwilsonobido4196
      @donwilsonobido4196 Год назад

      We think the same. I'm thinking how to deploy argo cd on EKS using terraform and how to access it securely.

  • @webspooky
    @webspooky Год назад +1

    Bedankt

    • @AntonPutra
      @AntonPutra  Год назад

      Thanks for the support @webspooky!

  • @YeetYeetYe
    @YeetYeetYe Год назад +2

    Fantastic video! Can you make a video about your background, how you came into tech and why you wanted to be in DevOps? Thank you for everything that you do.

    • @AntonPutra
      @AntonPutra  Год назад +2

      Thanks! Maybe in the future

  • @thapakazi_
    @thapakazi_ Год назад +1

    Thanks for the video!.
    How do you handle the notification for the deployment failures, let say for a migration job that happens at beginning of every deployments ?

    • @AntonPutra
      @AntonPutra  Год назад

      Good question. I'm about to create a video about it. In short, you can use Prometheus metrics, which you can obtain from here argo-cd.readthedocs.io/en/stable/operator-manual/metrics/

  • @Davidlavieri
    @Davidlavieri Год назад +1

    This looks good, in surface is amazing at local, but it scares me on production to manage these things in HA, does it have storage to manage, caches? can you make a video about general best practices when moving things production

    • @AntonPutra
      @AntonPutra  Год назад

      I've been running ArgoCD and Flux in prod for 4 years now. It's very straightforward. The only thing you need to pay attention to is garbage collection (when you delete a YAML from Git, the agent removes it from the cluster). If you're just getting started, I would suggest disabling it.

  • @AntonPutra
    @AntonPutra  Год назад +1

    Get Full-Length High-Quality DevOps Tutorials for Free - Subscribe Now! - ruclips.net/user/AntonPutra

    • @InsideFact1
      @InsideFact1 Год назад

      Mlops and machine learning engineer are different?

  • @xylyx_
    @xylyx_ Год назад +1

    Please make a video on Istio ambient mesh which runs without sidecars with the help of eBPF.

  • @rebelavie7772
    @rebelavie7772 Год назад +1

    Hey.. Anton... Do you have some experience using jsonnet? ( data templating language) in kubernetes... If yes Can do a video about it..? I heard it could be a good alternativ to kustomize or helm

  • @DanPlamadeala-l5n
    @DanPlamadeala-l5n 2 месяца назад +1

    Hey Anton, thank you for this great tutorial series. At 28:20 you mention that at the end of this tutorial you will go over the approach used for AWS. I cannot seem to find that part. Would you mind pointing me in the right direction?

    • @AntonPutra
      @AntonPutra  2 месяца назад +1

      Welcome! It's not ready yet, but I plan to refresh these services and include production deployment to AWS, Azure, and GCP soon...

  • @ricardopcunha
    @ricardopcunha Год назад +1

    Valeu!

  • @nomionz4150
    @nomionz4150 Год назад

    Hello, Anton. First of all, thank you for the amazing guides you provide. One thing I'm interested in in this video is how you stored a private ssh key in k8s cluster. Is it a common practice to store the key in Secret? I read a k8s doc and it says it's not secure. I would prefer to use some sort of key-vault. I understand that this is only a guide, and I just want to ask if this is a good practice.

    • @AntonPutra
      @AntonPutra  Год назад

      Thanks, there are so many different integrations harshi corp vault, aws secrets manager etc. The easiest way is to use sealed secrets - ruclips.net/video/ShGHCpUMdOg/видео.html

  • @matc8085
    @matc8085 5 месяцев назад

    how to connect to private repo was just what I needed

    • @AntonPutra
      @AntonPutra  5 месяцев назад

      i hope you found the answer

  • @jovision30
    @jovision30 7 месяцев назад

    Thank you so much for your efforts ✌

  • @kasvith
    @kasvith Год назад

    Do you recommend adding everything inside an argocd app like databases(statefulsets) ? or should we create them separately and just deply our app image with argocd?

    • @AntonPutra
      @AntonPutra  Год назад

      First of all, I would never recommend deploying databases in Kubernetes. However, for other stateful applications, such as Kafka or RabbitMQ, you should add them as ArgoCD apps and use the app-of-apps pattern.

  • @viswaviswa8616
    @viswaviswa8616 Год назад +1

    Hi Anton, thanks for the more effort, just having doubt about argo cd login, do you have video for okat integration for Argocd?

    • @AntonPutra
      @AntonPutra  Год назад

      Thanks, no I can't really cover all integrations in the video, however i've done it many times

    • @viswaviswa8616
      @viswaviswa8616 Год назад

      @@AntonPutra you mean you have already covered the topics using Argo cd or someother video in your RUclips channel?

    • @AntonPutra
      @AntonPutra  Год назад

      @@viswaviswa8616 No, I mean, I've been doing a lot of Okta integration at my work. A few months ago, I was trying to get an Okta account that I could use for a tutorial, but they refused to give it to me, and it's quite expensive for me to buy for personal/educational use. So, I can't do Okta integrations yet.

    • @viswaviswa8616
      @viswaviswa8616 Год назад

      @@AntonPutra true it's expensive, thanks for your help

  • @havefun599
    @havefun599 7 месяцев назад

    Very helpfull video, Thank you

  • @pi3ni0
    @pi3ni0 4 месяца назад

    Hey, I only watched the intro part, but why constant polling/syncing is better than just running `kubectl apply` code in GitHub Actions Code when a PR is merged? If the answer is somewhere later in the video, just let me know.

    • @AntonPutra
      @AntonPutra  4 месяца назад

      Generally, this approach, "GitOps" discourages any manual changes made in the cluster, and you can treat Git as a single source of truth. It's not something new, it was described long ago in the Google SRE book.

  • @chasim1982
    @chasim1982 Год назад

    Can you please make video on Argocd application set, why we need it? Thanks

  • @rusyn2512
    @rusyn2512 Год назад

    @AntonPutra thanks for extremely useful manual! Could you please help me - I've got an error: ComparisonError groupVersion shouldn't be empty, after using kubectl apply command? It looks like wrong version of Helm charts.

    • @rusyn2512
      @rusyn2512 Год назад +1

      Thanks, already fixed, delete and apply again helped)

  • @MinhNguyen-tf7bq
    @MinhNguyen-tf7bq Год назад

    Why are there two different versions of Argo CD throughout your video, mostly 3.35.4 and 2.6.6 at 09:24?

    • @AntonPutra
      @AntonPutra  Год назад

      To be honest, I don't remember, but I would suggest using the latest Helm chart and ArgoCD version. Here's an example: they have a new way to configure the "insecure" parameter via settings.
      Link - github.com/antonputra/tutorials/blob/main/lessons/179/terraform/1-argocd.tf

  • @powersurge5576
    @powersurge5576 Год назад

    How do you guys go about failed ArgoCD application syncs and you need to rollback. What automation logic do you put in?
    With HELM atomic deployments it is fool proof and release would get rolled back. With ArgoCD we reckon to put stages in the pipelines that will be checking the sync status and trigger last known good release deployment if prolonged failures observed.

    • @AntonPutra
      @AntonPutra  Год назад +1

      We use Flux v2 in production, which in my opinion is more mature, especially in terms of auto-deployment and committing back to Git. For failures, there is a Prometheus metric and alert.

    • @powersurge5576
      @powersurge5576 Год назад

      ​@@AntonPutratx!
      A slightly on a tangent question.
      What toolkit/approch you'd recommend to combine CSP resources provisioning that would be a part/dependency of the deployed Kubernetes microservice app, where Devs don't have to stitch/reference all resources manually. This would only be used for standardised app deployments. This would have to work with Flux deployment model.
      At the moment I'm thinking of two options.
      1. Use custom Helm Library Charts (which is a good practice anyway) that will deploy an app and create manifests for e.g. Azure Service Operator, which will manage Azure resources.
      Since we host many apps on a single subscription, I've heard there are scalability issues with service operators as they can hit rate limiting pretty quickly, or if supported configure a dedicated account per tenant operator.
      2. At one of the pipeline stages either through Helm Library Chart templating or some other method generate Terraform resources and plan/review/approve/apply. Following with the triggered app sync/deploy.
      I'd think we'll have some write-back tags on commits to identify last successful running app release numbers and commits. This will allow for auto sync on e.g. kubernetes cluster redeploy/app recovery, whereby we don't have to run a pipeline for deployments.
      Or would you keep CSP resource provisioning independent of the app?

  • @papryk1159
    @papryk1159 Год назад +1

    how do you learn all these things? any tips to share?

  • @George-mk7lp
    @George-mk7lp Год назад

    do you have any tutorial with github actions ci/cd ?

    • @AntonPutra
      @AntonPutra  Год назад

      Yes I have few videos
      ruclips.net/video/lD0t-UgKfEo/видео.html
      ruclips.net/video/jwdG6D-AB1k/видео.html
      ruclips.net/video/6dLHcnlPi_U/видео.html
      ruclips.net/video/Hv5UcBYseus/видео.html

  • @bakhtiyargarashov805
    @bakhtiyargarashov805 Год назад

    Off-topic: seems you are still using Lastpass even after their security incidents.

    • @AntonPutra
      @AntonPutra  Год назад +1

      Planing to switch to self hosted Bitwarden soon

  • @shamstabrez2986
    @shamstabrez2986 Год назад

    plz upload videos in fast pace so that we could learn more in a minimum time

  • @premierde
    @premierde Год назад

    Would be nice to see how to access argocd ui via istio gw & vs.

    • @AntonPutra
      @AntonPutra  Год назад

      Well you just need to setup a regular ingress, I have a bunch of examples like that - ruclips.net/video/9sLHoEyRq8w/видео.html

    • @premierde
      @premierde Год назад

      @@AntonPutra Thankyou. Yea I have now Argocd with istiogw & vs up & running.

  • @thrinadhvenkata2315
    @thrinadhvenkata2315 Год назад

    How to remove duplicate logs in argocd

    • @AntonPutra
      @AntonPutra  Год назад

      Not sure about duplicate logs but you can definitely adjust verbosity

    • @thrinadhvenkata2315
      @thrinadhvenkata2315 Год назад

      @@AntonPutra need to remove unnecessary logs in my spring boot application

    • @AntonPutra
      @AntonPutra  Год назад +1

      @@thrinadhvenkata2315 well it's outside of the argocd scope. You need to do it on the application level, maybe you have 2 loggers, one writes to the console and another one to file..

  • @karthiksundaram544
    @karthiksundaram544 Месяц назад

    Can u explain how to create pipelines 😂

  • @pseudozackxn
    @pseudozackxn 4 месяца назад

    Create a tutorial with argocd ingress please

    • @AntonPutra
      @AntonPutra  4 месяца назад +1

      you mean how to create ingress for argocd?

    • @pseudozackxn
      @pseudozackxn 4 месяца назад

      @@AntonPutra yes i have a eks cluster i have deployed argocd on it service is working fine with port-forward but it is not working with ingress i am using ingress-nginx controller everything is deployed using terraform modules and argocd as helm release even ingress i created from values.yaml only still not able to get the webui of argocd with my host name
      I wanted to access my argocd web ui on /argocd
      But unable to get it

    • @pseudozackxn
      @pseudozackxn 4 месяца назад

      @@AntonPutra yes

    • @AntonPutra
      @AntonPutra  4 месяца назад

      @@pseudozackxn i have plenty of other tutorials that focus on ingress, for example nginx ingress - ruclips.net/video/xwiRjimKW9c/видео.html
      you just need to create ingress object and target argocd service or just use helm chart and you can configure ingress by supplying few variables

    • @pseudozackxn
      @pseudozackxn 3 месяца назад

      @@AntonPutra yes i have done that there was some issur from comfigmap side i was trying to access the application on some path and for that some extra configuration was required in config maps so that is why it was frustrating the documentation is also not very clear for argocd

  • @AdamPoniatowski
    @AdamPoniatowski Год назад +1

    9:48 ... and proceeds to never explain how to do that

    • @AntonPutra
      @AntonPutra  Год назад

      Yeah i know, sorry =) I have bunch of example with ingresses pls take a look - github.com/antonputra/tutorials/tree/main/lessons/082
      it's really easy if you go through this tutorial

  • @satyakighosh4226
    @satyakighosh4226 3 месяца назад

    ArgoCD tutorial not for beginners I guess