data:image/s3,"s3://crabby-images/305b5/305b55880fa43844d772858c3a2b59e209c90d0f" alt=""
In this blog, we will explore the features, benefits, and use cases of Argo Workflows, which can accelerate and streamline your application deployments, data pipelines, machine learning workflows, and more.
Table of Contents
What is Argo Workflows?
Argo Workflows is an open-source container-native workflow engine for orchestrating parallel jobs on Kubernetes. It is deployed as Kubernetes Custom Resource Definition (CRD). The users can define Argo Workflows using YAML manifests, making it easy to create, manage, and visualize workflows. It supports a range of features, including DAG (Directed Acyclic Graph) workflows, container-based tasks, workflow templates, and extensibility through hooks and plugins.
A simple Hello World example manifest:
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
generateName: hello-world-
labels:
workflows.argoproj.io/archive-strategy: "false"
annotations:
workflows.argoproj.io/description: |
This is a simple hello world example.
spec:
entrypoint: whalesay
templates:
- name: whalesay
container:
image: docker/whalesay:latest
command: [cowsay]
args: ["hello world"]
Deploying Argo Workflows on a microk8s cluster
We will create ‘argo’ namespace and install the required CRDs.
kubectl create namespace argo
kubectl apply -n argo -f https://github.com/argoproj/argo-workflows/releases/download/v3.4.8/install.yaml
Let’s check what is deployed in the ‘argo’ namespace:
data:image/s3,"s3://crabby-images/75d25/75d256734ee884dcf6b5b3640be757c051f23425" alt="Argo Workflows Server"
As the cluster is deployed on a remote VM, I’ll also expose the deployment ‘argo-server’ on Node Port so that it can be accessed remotely:
Use the existing argo-server Cluster IP Service to generate a template for the new service and edit it accordingly.
kubectl get svc argo-server -n argo -oyaml > argo-server-np.yaml
data:image/s3,"s3://crabby-images/1b185/1b18542d7b5f0d5686c11f77d53e5981d519b35d" alt="Argo Workflows Server"
Let’s apply this manifest to create the Node Port service: argo-server-np
data:image/s3,"s3://crabby-images/07dad/07dade67cfbcd142cf59c3532b3196f608929297" alt="Argo Workflows Server"
Argo Workflows UI
Let’s try to access the Argo Server Web UI using the newly created Node Port Service:
https://ipaddress:30085
I’m using 30085 port to access Web UI, you have to use the node port mentioned in the manifest above.
data:image/s3,"s3://crabby-images/06340/063403f5acadc2a137a2e281bec76fb73fb74f31" alt="Argo Workflows Login Screen"
Argo Web Interface
How to create a token to log in to Argo Web UI?
We will create a service account, cluster role, and cluster role binding for this.
microk8s kubectl create clusterrole argowork --verb=list,update --resource=workflows.argoproj.io
microk8s kubectl create sa argowork -n argo
microk8s kubectl create clusterrolebinding argowork --clusterrole=argowork --serviceaccount=argo:argowork
data:image/s3,"s3://crabby-images/48ce1/48ce1dec0e604ce937cb6358986bf1b80b4ce01f" alt="Argo Workflows Token"
Token creation:
microk8s kubectl apply -f - <<EOF
apiVersion: v1
kind: Secret
metadata:
name: argowork.service-account-token
namespace: argo
annotations:
kubernetes.io/service-account.name: argowork
type: kubernetes.io/service-account-token
EOF
Retrieve the token value:
ARGO_TOKEN="Bearer $(microk8s kubectl get secret argowork.service-account-token -n argo -o=jsonpath='{.data.token}' | base64 --decode)"
Print the token value:
echo $ARGO_TOKEN
Now copy the token value and paste into the Web UI login field:
data:image/s3,"s3://crabby-images/b28e1/b28e151117959e849fc648975ad6e7a617b371b5" alt="Argo Workflows Login"
Click on the LOGIN button:
data:image/s3,"s3://crabby-images/16197/16197a83086294fd31b311ccde0ff04556b6a8ae" alt="Argo Workflows Login"
data:image/s3,"s3://crabby-images/573b8/573b872415b40a9e6517e4aa1dd7cec70a1405c2" alt=""
This is the landing page of the Argo Workflows Web UI.
data:image/s3,"s3://crabby-images/0e4d0/0e4d0f59e32f5ae9b25c89d54851610ebebc7b39" alt="Argo Workflows Web UI"
How to install the Argo CLI binary?
# Download the binary
curl -sLO https://github.com/argoproj/argo-workflows/releases/download/v3.4.8/argo-linux-amd64.gz
# Unzip
gunzip argo-linux-amd64.gz
# Make binary executable
chmod +x argo-linux-amd64
# Move binary to path
mv ./argo-linux-amd64 /usr/local/bin/argo
# Test installation
argo version
data:image/s3,"s3://crabby-images/db228/db228c9c3a2a8fd35c7800a539823b544f1422cf" alt="Argo Workflows CLI"
argo cli version
Make sure Kubeconfig file is present in standard location or set the KUBECONFIG environment variable:
cd .kube/
microk8s config > config
Let’s submit our Hello Argo sample workflow:
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
generateName: hello-world-
labels:
workflows.argoproj.io/archive-strategy: "false"
annotations:
workflows.argoproj.io/description: |
This is a simple hello argo example.
spec:
entrypoint: whalesay
templates:
- name: whalesay
container:
image: docker/whalesay:latest
command: [cowsay]
args: ["hello argo"]
hello-argo.yaml
Workflow has started:
data:image/s3,"s3://crabby-images/84824/84824b0b1cab9084177ee2fa3b5e3324adcfdd19" alt="Argo Workflows Started"
Workflow is complete now:
data:image/s3,"s3://crabby-images/08d21/08d2161b84859df449a586c398b5ac9b72e5d3cc" alt="Argo Workflows Completed"
Let’s check logs of the workflow we submitted using argo cli:
argo logs hello-world-xh57h -n argo
data:image/s3,"s3://crabby-images/e62ad/e62ad6f7d268139cfc97e2e7224f0ef0ded957fd" alt="Argo Workflows Logs"
Status of the completed workflow on the Argo Web UI:
data:image/s3,"s3://crabby-images/db025/db025dcd9ef7b6757e8031cad9a2f07b7a33b43e" alt="Argo Workflows Status"
To get more details of the workflow just click on the workflow name:
data:image/s3,"s3://crabby-images/4bb31/4bb31bd7545442043644e7e20f5f905f5d2c1ece" alt="Argo Workflows Status"
Argo Workflow Examples
The example folder in the Argo Workflows git repository is a great place to see a wide variety of example manifest files to learn various concepts.
Argo Workflows Use cases
Some of the use cases where Argo Workflows is a great fit:
- Continuous Integration and Delivery (CI/CD) Pipelines: Automating the build, test, and deployment processes of applications.
- Data Processing and ETL Pipelines: Orchestrating data workflows for data ingestion, transformation, and analytics.
- Machine Learning Workflows: Managing end-to-end machine learning pipelines, including model training and inference.
- Event-Driven Workflows: Reacting to events and triggering workflows based on system events or external triggers.
- Infrastructure Provisioning and Management: Automating the provisioning and lifecycle management of infrastructure resources.
Conclusion
Argo Workflows provides a great piece of kit the Kubernetes users to automate and orchestrate their complex tasks and workflows, providing enhanced productivity, scalability, and reliability. By taking advantage of Argo Workflows, you can unlock the full potential of your Kubernetes cluster and streamline your application deployments, data processing pipelines, machine learning workflows, and more.
Please read our blog on Argo Workflows vs Kubernetes Job for more details on Argo.