Setting Up ArgoCD on Kubernetes: A Quick Guide

ArgoCD is a popular GitOps continuous delivery tool that simplifies Kubernetes application deployments. In this article, I’ll guide you through the basic steps to install ArgoCD using Helm, configure access for both external and internal environments, and ensure your KUBECONFIG is set correctly.


Step 1: Ensure KUBECONFIG is Properly Configured

Before starting, make sure your KUBECONFIG environment variable points to the correct Kubernetes cluster configuration file. This file allows kubectl and other tools to interact with your cluster.

Save and reload your shell configuration:

source ~/.bashrc

Append the following line:

export KUBECONFIG=/path/to/your/kubeconfig.yaml

If not set, add the correct path to your ~/.bashrc file (for Bash users):

nano ~/.bashrc

Check if KUBECONFIG is set:

echo $KUBECONFIG

This ensures your tools can correctly access your Kubernetes cluster.


Step 2: Install ArgoCD Using Helm

Helm simplifies the deployment of Kubernetes applications by packaging them into reusable charts. To install ArgoCD:

    • -n argocd: Specifies the namespace argocd where ArgoCD will be installed.
    • --create-namespace: Creates the namespace if it doesn’t exist.

Verify the installation:

kubectl get all -n argocd

Add the ArgoCD Helm repository:

helm repo add argo https://argoproj.github.io/argo-helm
helm repo update

Install ArgoCD:

helm install argocd argo/argo-cd -n argocd --create-namespace

This command lists all ArgoCD-related resources, ensuring the installation is complete.


Step 3: Configure Access to ArgoCD

ArgoCD’s default installation provides internal access. You can expose the ArgoCD UI for external or internal use by modifying the service type.

Option 1: Using Ingress (External Access)

  1. Apply a DNS record to point argocd.example.com to your ingress controller.
  2. Test access by visiting https://argocd.example.com.

Update the service configuration to use an ingress controller (e.g., Traefik or NGINX). For example:

annotations:
  kubernetes.io/ingress.class: "nginx"
spec:
  rules:
  - host: argocd.example.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: argocd-server
            port:
              number: 80

Edit the argocd-server service to configure ingress:

kubectl edit svc argocd-server -n argocd

Option 2: Using NodePort (External or Internal Access)

If you don’t have an ingress controller or need simpler access, change the service type to NodePort:

Access ArgoCD via:

http://<node-ip>:<node-port>

Retrieve the NodePort and access ArgoCD:

kubectl get svc argocd-server -n argocd

Look for the NodePort value under the PORT(S) column (e.g., 30000-32767).

Update the service type to NodePort:

spec:
  type: NodePort

Edit the service type:

kubectl edit svc argocd-server -n argocd

以上資訊ChatGPT整理

Read more

如何安裝 KubeSphere 以及管理 Workspace 和新增 Label

前言 在 Kubernetes 的世界中,KubeSphere 是一個功能強大的開源容器平台,它不僅讓 Kubernetes 的管理更簡單,還集成了多集群管理、DevOps、微服務治理等功能。本篇文章將教您如何使用 Helm 快速安裝 KubeSphere,並如何通過管理 Workspace 和新增 Label 來實現資源的高效管理。 一、使用 Helm 安裝 KubeSphere 1. 為什麼選擇 Helm 安裝? Helm 是 Kubernetes 中廣泛使用的包管理工具,使用 Helm 安裝 KubeSphere 有以下優點: * 自動化:簡化安裝過程,減少手動配置。 * 靈活性:可以根據需求自定義安裝的模組。 * 版本控制:支持管理和回滾安裝的不同版本。 2. 安裝前準備 在開始安裝之前,請確保以下條件:

By Tim Chiagn

我的經驗

1. 網絡與安全 (Networking & Security) * Fortigate: 防火牆來管理網路環境 * Traefik: 用於 K8s 的 2. 虛擬化與存儲 (Virtualization & Storage) * Esxi: 買了一台server 使用 Esxi 管理 vm * TrueNAS: 還沒有買 NAS 使用這個加減用一下 3. DevOps 與持續交付 (DevOps & CI/CD) * ArgoCD: GitOps 工具,用於 Kubernetes 的應用交付和管理,支持自動化部署和同步。 * KubeSphere:提供完整的 CI/CD 工作流管理、應用部署和 DevOps 整合功能,是 Kubernetes

By Tim Chiagn