That is the problem with our jobs and tech in general. Things change fast and I am likely going to say in the near future "this is horrible, don't use it" for most of the things I'm claiming are great today.
@emonymph6911 CI/CD are processes, not tools. You can codify those processes using one, or two, or more tools. That being said, I do not see dapr as being one of the tools involved in CI/CD processes.
In that case, I think you'll like the video I'll (probably) publish next Thursday. It's about combining Argo Workflows with Events (and CD, and Rollouts, and SealedSecrets). Workflows really shines only when it is combined with Events, and gets even more boost with other Argo projects.
Awesome, great introduction and regarding your question: yes, I admit it, I want to use the whole argo stack, so lemme just click your next video! PS: Subscribed!
The instructions with both the commands I executed before and during the video are in a Gist and the link to the Gist is in the description. It includes everything I did to set it up (install it). As for the security context... I used Minikube for the demo so I did not do anything with the context. Most of the time, that's not directly related to a specific app but applicable in general and, sometimes, specific to the k8s platform you chose.
I worked at Codefresh for a shortwhile and chose to move elsewhere. I guess that tells you what I think without me saying what I think about Codefresh. As for running GitOps at scale... It depends on what the scale is and how you set it up. If you have one ArgoCD or Flux instance in every cluster, you should not have issues with scale (assuming that control plane nodes are not underprovisioned). If you have a single instance of ArgoCD or Flux that manages hundreds of clusters, than you will indeed face issues. That's usually the situation where companies (running at that scale) are looking at enterprise solutions like Akuity.
Looks like aws step functions to me. You can also do cmd overrides etc, run job in parallel or serial, and schedule runs via cwatch. Anyways really nice work Viktor, thank you for your effort.
I already did that in th-cam.com/video/XNXJtxkUKeY/w-d-xo.html. However, it has been a while since i published it so I will add it to my TODO list to do an updated version.
Hi Viktor, thank you for the video! I managed to run your example. A question i have is what if the git repo is a private repo? where do i set up the credentials in order to access the git repo? Thanks for the help.
@@DevOpsToolkit , thanks for the reply. I think the link you provided is for Argo CD. Using argo workflows to build image referencing a private git repo doesn't seem to work as the the argo workflow UI doesn't have this tab.
If you need to access a private git repo, you need to define git artifact and provide the secret with the username and password. You can find an example in github.com/argoproj/argo-workflows/blob/master/examples/input-artifact-git.yaml
I do not use python myself. However, that should not matter since Argo workflows allow you to use any container image for any of the steps. If the image you're using is based on python, you should be able to execute any python command inside your workflow.
Great content in the argo playlist , one suggestion if you could please add the link of your github repository you use in your demos in the description it would be helpful.
Argo CD video was one of the first ones I created and it was done in a "weird" way. I adapted the material from my book without creating a Gist that people can follow. I think that all the videos after that one do have a Gist. For example, if you take a look at the description of this video, you'll see the "Gist with the commands" link with all the commands, including `git clone` of the repos I used.
Hi Victor, thanks for video.If I understand this workflow is not like Camunda or Spring Activity?This is for orchastration of micro services?Can you build kind of workflow like Camunda workflow and read from MQ?
Unfortunately, I haven't used either of those so I cannot compare them or say whether they are similar. Argo workflows is a pipeline tool just like Jenkins, GitHub actions, tekton, GitLab ci, etc. As such, it is not limited to microservices but can be used to automate any type of pipeline.
One more thing... Pull repo using Kaniko only if you are not already pulling it for other reasons. More often than not, you will already have the repo cloned for testing or other reasons.
@@DevOpsToolkit - Hi. It would only be one or two hours to help architect an ARGO workflow/CD solution to allow for propagating changes to different environments. Thank You. Please let me know how I can reach your or if you want me to leave my contact information. I greatly appreciate your guidance. Thank You
@@DevOpsToolkit thanks!! I had a look at it.... But was a bit difficult to comprehend... I am looking for something replica to docker run -v sourcepath: destinationpath container-name.... If you can further explain it that would be great... Thanks in advance
@@ashutoshtiwari6947 I don't have an example at hand. I'll do my best to create one over the weekend. In the meantime... You need to define a Kubernetes volume (it could be almost any time) in, more or less, the same way you would do it for any k8s resource. From there on, it's all about telling workflows to use that volume.
@@DevOpsToolkit Cool... really looking forward to your next video wherein we can use volumes used via docker run.. or docker artifacts as an alternative to it.
@@ashutoshtiwari6947 To clarify... When I do such a video (can't promise the date), it will not involve Docker. I do not think that anyone should use Docker inside Kubernetes. There are much better (and safer) alternatives. For building images that could be, for example, Kaniko. As for running containers, that's completely irrelevant since the decision is made by the Kubernetes distro you're using (and is almost certainly not Docker). On top of that, volumes are typically used for temporary storage so that you can pass artifacts from one step to another, not from one pipeline to another. When a permanent storage is needed, it would be a container image or artiface registry like ECR, ACR, Docker Hub, Artifactory, etc.
I prefer k3d. It's the fastest and the least resource-intensive local Kubernetes cluster. KinD is a good alternative. You can find videos about both in this channel :)
I think it's one of the things TH-cam does without explaining how. When I look at that video, there are no captions, but when I look at, for example, at th-cam.com/video/LGNEG-t96eE/w-d-xo.html, there is the CC button to enable captions. I'm not sure how and why TH-cam choose one but not the other. Maybe it's doing it automatically in all the new videos?
Victor, what would be the best way to run integration tests during the build phase of CICD? My dev team need few databases to test an app like mariadb, posgress etc. So far we did it by keeping docker-compose in each app repository. Before the tests start we run 'docker-compose up' that provides mocks of all the services needed. How that could work with argo workflows?
Argo Workflows, just as any other pipeline solution, allows you to execute any command as a step. Since all the steps are executed in containers, you need to specify an image that contains the tools you need. Now, Docker is gone from Kubernetes clusters so you should either connect to Docker running in a VM (you can use environment variables for that) or spin up the DB inside a Kubernetes cluster. I suggest doing the latter. You can, for example, use MariaDB Helm chart. If that DB is temporary, create a new Namespace, spin up MariaDB (or whichever other DB you might need) inside that Namespace, run the tests, and delete that Namespace when you're done. You can also use virtual clusters with, let's say, vCluster if you'd like to have better isolation from the rest of the workloads in that cluster. Also, virtual clusters help with cleanup. If you deploy something that uses cluster-wide resources (e.g., CRDs), deleting the Namespace will not delete everything, but, if that is inside vCluster, you can delete the whole (virtual) cluster.
Hey Viktor, I've followed your video and deployed workflows and implemented a Traefik ingressRoute apiVersion: traefik.containo.us/v1alpha1 kind: IngressRoute metadata: name: argo-workflow-https spec: entryPoints: - websecure routes: - match: Host(`workflow.xxxx.co.uk`) && PathPrefix(`/`) kind: Rule services: - name: argo-server port: 2746 tls: certResolver: le-staging domains: - main: workflow.xxxx.co.uk but all I get is bad gateway. Any ideas of what could be the problem or how to troubleshoot.
@@DevOpsToolkit .... a bit late to the party ... but I would really like to see a comparison between Argo Workflows and Tekton. Imho Tekton pipelines can be quite flexible but also verbose/tedious to write (aside from a hello-world usecase :), and I am wondering if Argo accomplishes that in a neater way? Also debugging of pipeline runs/workflows/jenkinsfiles/... can be a huge issue and is usually not a built-in feature.
To be more precise, that was the first release in the current GitHub repo and it was v2.0.0 in November 2017. I did not follow Argo workflows at that time so I'm not sure when was the release release made before it moved to the current repo nor I know how it looked at that time. In any case, I am not sure who copied whom and how Argo evolved back then but it is definitely older than tekton.
“What it looks like,” or “how it looks,” but never “how it looks like.” “What” is a placeholder for a thing. You need “like” when you say “what” so we know you are comparing to the thing that “what” is standing in for. “It looks like what?” or “What does it look like?” “It looks like this.” “What” stands in for “this.” “How” is a placeholder for a description (e.g. good, quickly, slowly, etc.). because there is nothing to compare to, “like” doesn’t make sense. “It looks how?” or “How does it look?” “It looks good.” “How” stands in for “good.”
Don’t get me wrong. Your English is very good. I would even say it’s much better than average for someone from what I’m guessing is Eastern Europe. This is a very common mistake, even among native speakers, and I was just being a bit picky because I was in a bad mood.
Thanks for this series, starting to believe that you've already demystified any modern solution I've come across. Keep it up!
That is the problem with our jobs and tech in general. Things change fast and I am likely going to say in the near future "this is horrible, don't use it" for most of the things I'm claiming are great today.
@@DevOpsToolkit Absolutely, community adoption really makes or breaks that support - so thanks for being part of that. Awesome content for sure.
@@DevOpsToolkit is dapr, argo and jenkins all ci/cd? i don't really understand if dapr is ci/cd.
@emonymph6911 CI/CD are processes, not tools. You can codify those processes using one, or two, or more tools.
That being said, I do not see dapr as being one of the tools involved in CI/CD processes.
@@DevOpsToolkit what should we use for CI/CD in 2024? ^.^ (for devsecops tests on pushed code)
Yes a video about combining these all things together will definitely help people.
It's (probably) coming up next week :)
Awesome. Didn't know anything about Argo since this video and now I'm almost an expert haha
Glad I could help!
Yes! Thanks Viktor I've been wrestling with the workflows side of argo for months 💵💵💵💵💵
In that case, I think you'll like the video I'll (probably) publish next Thursday. It's about combining Argo Workflows with Events (and CD, and Rollouts, and SealedSecrets). Workflows really shines only when it is combined with Events, and gets even more boost with other Argo projects.
Thank you, very good video. My vote is Yes make the video combine argo tools.
You got it! It's probably coming up next Thursday.
Love this channel ❤❤ for real !!
Man this is so awesome!! Thank you so much!
Awesome, great introduction and regarding your question: yes, I admit it, I want to use the whole argo stack, so lemme just click your next video! PS: Subscribed!
Thank you for this! Please make a video comparing Argo Workflows with Jenkins.
Adding it to my to-do list... 🙂
Thank you so much, this is awesome
I couldn't find the video where you installed workflow and setup any security context as its failing for the same.
The instructions with both the commands I executed before and during the video are in a Gist and the link to the Gist is in the description. It includes everything I did to set it up (install it).
As for the security context... I used Minikube for the demo so I did not do anything with the context. Most of the time, that's not directly related to a specific app but applicable in general and, sometimes, specific to the k8s platform you chose.
Really nice series, very helpful.
What is your view on the codefresh Enterprise ArgoCD? Or, issues running GitOps at scale?
I worked at Codefresh for a shortwhile and chose to move elsewhere. I guess that tells you what I think without me saying what I think about Codefresh.
As for running GitOps at scale... It depends on what the scale is and how you set it up. If you have one ArgoCD or Flux instance in every cluster, you should not have issues with scale (assuming that control plane nodes are not underprovisioned). If you have a single instance of ArgoCD or Flux that manages hundreds of clusters, than you will indeed face issues. That's usually the situation where companies (running at that scale) are looking at enterprise solutions like Akuity.
Looks like aws step functions to me. You can also do cmd overrides etc, run job in parallel or serial, and schedule runs via cwatch. Anyways really nice work Viktor, thank you for your effort.
Hey Victor, thanks! Please make a video of the combination of all Argo tools, as not obvious to beginners!
Found it th-cam.com/video/XNXJtxkUKeY/w-d-xo.html !! 🙏
I already did that in th-cam.com/video/XNXJtxkUKeY/w-d-xo.html. However, it has been a while since i published it so I will add it to my TODO list to do an updated version.
Hi Viktor, thank you for the video! I managed to run your example. A question i have is what if the git repo is a private repo? where do i set up the credentials in order to access the git repo? Thanks for the help.
Something like argo-cd.readthedocs.io/en/stable/user-guide/private-repositories/ should do
@@DevOpsToolkit , thanks for the reply. I think the link you provided is for Argo CD. Using argo workflows to build image referencing a private git repo doesn't seem to work as the the argo workflow UI doesn't have this tab.
If you need to access a private git repo, you need to define git artifact and provide the secret with the username and password. You can find an example in github.com/argoproj/argo-workflows/blob/master/examples/input-artifact-git.yaml
great video!
How can I run python scripts in an Argo workflow? Could you provide any implementation details to achieve this task?
I do not use python myself. However, that should not matter since Argo workflows allow you to use any container image for any of the steps. If the image you're using is based on python, you should be able to execute any python command inside your workflow.
Well done like always Viktor. Can you provide us the installation of argoworkflow with serviceaccount and with the right privilege?
Adding it to my TODO list...
please make the combined full flaged aroproc CI CD
Do you mean something like th-cam.com/video/XNXJtxkUKeY/w-d-xo.html or you have something else in mind?
Great content in the argo playlist , one suggestion if you could please add the link of your github repository you use in your demos in the description it would be helpful.
Argo CD video was one of the first ones I created and it was done in a "weird" way. I adapted the material from my book without creating a Gist that people can follow. I think that all the videos after that one do have a Gist. For example, if you take a look at the description of this video, you'll see the "Gist with the commands" link with all the commands, including `git clone` of the repos I used.
Hi Victor, thanks for video.If I understand this workflow is not like Camunda or Spring Activity?This is for orchastration of micro services?Can you build kind of workflow like Camunda workflow and read from MQ?
Unfortunately, I haven't used either of those so I cannot compare them or say whether they are similar.
Argo workflows is a pipeline tool just like Jenkins, GitHub actions, tekton, GitLab ci, etc. As such, it is not limited to microservices but can be used to automate any type of pipeline.
@@DevOpsToolkit so it is not meant for data flow workflows?
The initial use case was for data pipelines but, since then, it evolved into pipelines of any kind.
So can it be used to run data flow like IIB data flow?
th-cam.com/video/gEIOAUZLJuo/w-d-xo.html
Something like this?
how to pull private git repo in this case? like how to add github secrets in kaniko?
You need to store auth info as secrets and then mount those secrets inside containers that need them.
One more thing... Pull repo using Kaniko only if you are not already pulling it for other reasons. More often than not, you will already have the repo cloned for testing or other reasons.
Are you available for consultation?
I am not available for any type of activity that requires dedication. I can spare an hour or two if that can help.
@@DevOpsToolkit - Hi. It would only be one or two hours to help architect an ARGO workflow/CD solution to allow for propagating changes to different environments. Thank You. Please let me know how I can reach your or if you want me to leave my contact information. I greatly appreciate your guidance. Thank You
@@johndesposito Feel free to pick a time that works for you from calendly.com/vfarcic/meet.
@@DevOpsToolkit Will do .. thank you
How can i create volume to have a folder path shared across containers . i.e. all using argo workflow??
You can found a couple of examples in argoproj.github.io/argo-workflows/examples/#volumes with more detailed info in the spec section of the docs.
@@DevOpsToolkit thanks!! I had a look at it.... But was a bit difficult to comprehend... I am looking for something replica to docker run -v sourcepath: destinationpath container-name.... If you can further explain it that would be great... Thanks in advance
@@ashutoshtiwari6947 I don't have an example at hand. I'll do my best to create one over the weekend. In the meantime... You need to define a Kubernetes volume (it could be almost any time) in, more or less, the same way you would do it for any k8s resource. From there on, it's all about telling workflows to use that volume.
@@DevOpsToolkit Cool... really looking forward to your next video wherein we can use volumes used via docker run.. or docker artifacts as an alternative to it.
@@ashutoshtiwari6947 To clarify... When I do such a video (can't promise the date), it will not involve Docker. I do not think that anyone should use Docker inside Kubernetes. There are much better (and safer) alternatives. For building images that could be, for example, Kaniko. As for running containers, that's completely irrelevant since the decision is made by the Kubernetes distro you're using (and is almost certainly not Docker).
On top of that, volumes are typically used for temporary storage so that you can pass artifacts from one step to another, not from one pipeline to another. When a permanent storage is needed, it would be a container image or artiface registry like ECR, ACR, Docker Hub, Artifactory, etc.
What is your recommended way of installing a cluster locally on a mac for testing things like this?
I prefer k3d. It's the fastest and the least resource-intensive local Kubernetes cluster. KinD is a good alternative. You can find videos about both in this channel :)
Please enable captions for us folks who can’t hear.
I think it's one of the things TH-cam does without explaining how. When I look at that video, there are no captions, but when I look at, for example, at th-cam.com/video/LGNEG-t96eE/w-d-xo.html, there is the CC button to enable captions. I'm not sure how and why TH-cam choose one but not the other. Maybe it's doing it automatically in all the new videos?
Victor, what would be the best way to run integration tests during the build phase of CICD? My dev team need few databases to test an app like mariadb, posgress etc. So far we did it by keeping docker-compose in each app repository. Before the tests start we run 'docker-compose up' that provides mocks of all the services needed. How that could work with argo workflows?
Argo Workflows, just as any other pipeline solution, allows you to execute any command as a step. Since all the steps are executed in containers, you need to specify an image that contains the tools you need.
Now, Docker is gone from Kubernetes clusters so you should either connect to Docker running in a VM (you can use environment variables for that) or spin up the DB inside a Kubernetes cluster. I suggest doing the latter. You can, for example, use MariaDB Helm chart. If that DB is temporary, create a new Namespace, spin up MariaDB (or whichever other DB you might need) inside that Namespace, run the tests, and delete that Namespace when you're done. You can also use virtual clusters with, let's say, vCluster if you'd like to have better isolation from the rest of the workloads in that cluster. Also, virtual clusters help with cleanup. If you deploy something that uses cluster-wide resources (e.g., CRDs), deleting the Namespace will not delete everything, but, if that is inside vCluster, you can delete the whole (virtual) cluster.
Hey Viktor, I've followed your video and deployed workflows and implemented a Traefik ingressRoute
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
name: argo-workflow-https
spec:
entryPoints:
- websecure
routes:
- match: Host(`workflow.xxxx.co.uk`) && PathPrefix(`/`)
kind: Rule
services:
- name: argo-server
port: 2746
tls:
certResolver: le-staging
domains:
- main: workflow.xxxx.co.uk
but all I get is bad gateway. Any ideas of what could be the problem or how to troubleshoot.
Hey Viktor, I managed to get it working buy adding the following
- server
- --secure=false
and letting Traefik do the certificates
That Marla poster ...
Oh yeah. My favorite.
@@DevOpsToolkit BTW, going through everything argo you published ... it's awesome and being of great help ...
Thanks a lot ! where can i find source code ?
There is a gist in the description of the video.
How does this compare to tekton pipelines?
I haven't been using tekton for some 6 months now so I need to get up-to-speed with what they are doing lately before answering that question :(
@@DevOpsToolkit .... a bit late to the party ... but I would really like to see a comparison between Argo Workflows and Tekton. Imho Tekton pipelines can be quite flexible but also verbose/tedious to write (aside from a hello-world usecase :), and I am wondering if Argo accomplishes that in a neater way? Also debugging of pipeline runs/workflows/jenkinsfiles/... can be a huge issue and is usually not a built-in feature.
It is Tekton principle taken over.
Actually, the first release of Argo workflows was published a year and a half before the first release of Tekton.
To be more precise, that was the first release in the current GitHub repo and it was v2.0.0 in November 2017. I did not follow Argo workflows at that time so I'm not sure when was the release release made before it moved to the current repo nor I know how it looked at that time. In any case, I am not sure who copied whom and how Argo evolved back then but it is definitely older than tekton.
“What it looks like,” or “how it looks,” but never “how it looks like.”
“What” is a placeholder for a thing. You need “like” when you say “what” so we know you are comparing to the thing that “what” is standing in for.
“It looks like what?” or “What does it look like?”
“It looks like this.”
“What” stands in for “this.”
“How” is a placeholder for a description (e.g. good, quickly, slowly, etc.). because there is nothing to compare to, “like” doesn’t make sense.
“It looks how?” or “How does it look?”
“It looks good.”
“How” stands in for “good.”
Thank you for that clarification. My English is self-tought and there are too many things i still struggle with.
Don’t get me wrong. Your English is very good. I would even say it’s much better than average for someone from what I’m guessing is Eastern Europe. This is a very common mistake, even among native speakers, and I was just being a bit picky because I was in a bad mood.