🚀 ArgoCD v2.12.1 오프라인 설치 가이드
폐쇄망 환경에서 ArgoCD v2.12.1을 Kubernetes 위에 Helm으로 설치하는 절차를 안내합니다.
0. 오프라인 설치 자산 준비 (인터넷 환경)
폐쇄망에 반입할 Helm 차트와 컨테이너 이미지(.tar)가 charts/ 및 images/ 디렉토리에 없는 경우, 인터넷이 연결된 외부 PC(리눅스)에서 아래 스크립트를 실행하여 자산을 다운로드해야 합니다.
주의: 이 작업은 폐쇄망 내부가 아닌, 외부망에서 사전에 수행되어야 합니다. (Docker 또는 containerd(
ctr),helmCLI 설치 필수)
# 컴포넌트 스크립트 디렉토리로 이동
cd scripts/
# 실행 권한 부여 및 다운로드 스크립트 실행
chmod +x download_assets_offline.sh
sudo ./download_assets_offline.sh
스크립트 실행이 완료되면 charts/ 디렉토리에 .tgz 차트 파일이, images/ 디렉토리에 .tar 이미지 파일들이 생성됩니다. 전체 프로젝트 폴더를 압축하여 폐쇄망 내부로 반입하십시오.
전제 조건
- Kubernetes 클러스터 구성 완료
- Helm v3.14.0 설치 완료
kubectlCLI 사용 가능- Harbor 레지스트리 접근 가능 (
<NODE_IP>:30002) - (도메인 접속 사용 시) Envoy Gateway 설치 완료
- (NAS 사용 시) 모든 노드에 NFS 클라이언트 설치 완료
1단계: 이미지 Harbor 업로드
모든 작업은 컴포넌트 루트 디렉토리에서 실행합니다.
# upload_images_to_harbor_v3-lite.sh 상단 Config 수정
# IMAGE_DIR : ./images (현재 디렉터리의 이미지 폴더 지정)
# HARBOR_REGISTRY: <NODE_IP>:30002
chmod +x images/upload_images_to_harbor_v3-lite.sh
./images/upload_images_to_harbor_v3-lite.sh
2단계: 설치 스크립트 설정
scripts/install.sh 상단 Config 블록을 환경에 맞게 수정합니다.
# ==================== Config ====================
# Harbor Registry
HARBOR_REGISTRY="<NODE_IP>:30002"
HARBOR_PROJECT="library"
# Storage: "none" | "nas" | "hostpath"
STORAGE_TYPE="hostpath"
# hostPath Settings
HOSTPATH_REDIS="/data/argocd/redis"
HOSTPATH_REPO="/data/argocd/repo-cache"
# NAS Settings (STORAGE_TYPE="nas" 시 사용)
NAS_SERVER="192.168.1.50"
NAS_REDIS_PATH="/nas/argocd/redis"
NAS_REPO_PATH="/nas/argocd/repo"
# Networking
NODEPORT="30001"
DOMAIN="argocd.devops.internal"
GATEWAY_NAME="cluster-gateway"
GATEWAY_NAMESPACE="envoy-gateway-system"
# ================================================
3단계: (NAS 사용 시) PV/PVC 설정
NAS(NFS) 스토리지를 사용하는 경우 manifests/nas-pv.yaml의 NFS 서버 주소와 경로를 수정합니다.
4단계: 설치 실행
스크립트 자동 처리 항목:
- Namespace 생성 및 스토리지 설정 적용
- Helm 설치 (Harbor 이미지 경로 기반)
- NodePort 및 HTTPRoute 생성 (
DOMAIN설정 시) - CoreDNS 도메인 자동 등록 (
DOMAIN설정 시)
5단계: 설치 확인
6단계: 초기 접속 및 비밀번호 변경
초기 비밀번호 확인:
kubectl -n argocd get secret argocd-initial-admin-secret \
-o jsonpath="{.data.password}" | base64 -d && echo
| 접속 방식 | 주소 | 비고 |
|---|---|---|
| NodePort | http://<NODE_IP>:30001 |
일반 접속 |
| 도메인 | http://argocd.devops.internal |
DNS/hosts 설정 필요 |
도메인 접속 시 /etc/hosts 파일에 추가:
<GATEWAY_IP> argocd.devops.internal
보안 권고: 최초 로그인 후 비밀번호를 변경하고 초기 Secret을 삭제하십시오.
kubectl delete secret argocd-initial-admin-secret -n argocd