Update .gitlab-ci.yml file

This commit is contained in:
kris
2025-11-09 09:23:32 +00:00
parent 942b19375e
commit 32f202d814
+27 -6
View File
@@ -3,12 +3,25 @@ stages:
- deploy - deploy
variables: variables:
# 🔧 Docker BuildKit lebih cepat
DOCKER_BUILDKIT: "1" DOCKER_BUILDKIT: "1"
COMPOSE_DOCKER_CLI_BUILD: "1" COMPOSE_DOCKER_CLI_BUILD: "1"
DOCKER_DRIVER: overlay2 DOCKER_DRIVER: overlay2
# 🧠 Tag image berdasarkan commit
IMAGE_NAME: "$CI_REGISTRY_IMAGE/web-lti:development_${CI_COMMIT_SHORT_SHA}" IMAGE_NAME: "$CI_REGISTRY_IMAGE/web-lti:development_${CI_COMMIT_SHORT_SHA}"
# 📦 Cache npm antar pipeline
NPM_CACHE_DIR: "$CI_PROJECT_DIR/.npm" NPM_CACHE_DIR: "$CI_PROJECT_DIR/.npm"
# 🌐 Environment default untuk Next.js
NODE_ENV: "production"
HUSKY_SKIP_INSTALL: "1"
# ⚙️ Inject ENV dari GitLab CI Variables ke Dockerfile
NEXT_PUBLIC_API_BASE_URL: "${NEXT_PUBLIC_API_BASE_URL}"
NEXT_PUBLIC_LTI_API_START_URL: "${NEXT_PUBLIC_LTI_API_START_URL}"
cache: cache:
key: npm-cache key: npm-cache
paths: paths:
@@ -24,14 +37,22 @@ build-image:
- docker:dind - docker:dind
before_script: before_script:
- echo "Logging in to GitLab Container Registry..." - echo "🔐 Logging in to GitLab Container Registry..."
- echo "$CI_REGISTRY_PASSWORD" | docker login -u "$CI_REGISTRY_USER" --password-stdin "$CI_REGISTRY" - echo "$CI_REGISTRY_PASSWORD" | docker login -u "$CI_REGISTRY_USER" --password-stdin "$CI_REGISTRY"
script: script:
- echo "Building optimized Docker image..." - echo "🚧 Building optimized Docker image..."
- docker build --build-arg BUILDKIT_INLINE_CACHE=1 --cache-from "$CI_REGISTRY_IMAGE/web-lti:latest" -t "$IMAGE_NAME" . - >
docker build
--build-arg NEXT_PUBLIC_API_BASE_URL="$NEXT_PUBLIC_API_BASE_URL"
--build-arg NEXT_PUBLIC_LTI_API_START_URL="$NEXT_PUBLIC_LTI_API_START_URL"
--build-arg NODE_ENV="$NODE_ENV"
--build-arg HUSKY_SKIP_INSTALL="$HUSKY_SKIP_INSTALL"
--build-arg BUILDKIT_INLINE_CACHE=1
--cache-from "$CI_REGISTRY_IMAGE/web-lti:latest"
-t "$IMAGE_NAME" .
- docker push "$IMAGE_NAME" - docker push "$IMAGE_NAME"
- echo "Cleaning old images..." - echo "🧹 Cleaning old images..."
- docker image prune -af --filter "until=72h" - docker image prune -af --filter "until=72h"
rules: rules:
@@ -45,7 +66,7 @@ deploy-dev:
image: alpine:3.20 image: alpine:3.20
before_script: before_script:
- echo "Installing dependencies..." - echo "📦 Installing dependencies..."
- apk add --no-cache openssh curl - apk add --no-cache openssh curl
- mkdir -p ~/.ssh - mkdir -p ~/.ssh
- echo "$SSH_PRIVATE_KEY" > ~/.ssh/id_rsa - echo "$SSH_PRIVATE_KEY" > ~/.ssh/id_rsa
@@ -55,7 +76,7 @@ deploy-dev:
- ssh-keyscan -H "$SERVER_IP" >> ~/.ssh/known_hosts - ssh-keyscan -H "$SERVER_IP" >> ~/.ssh/known_hosts
script: script:
- echo "Deploying image to $SERVER_USER@$SERVER_IP" - echo "🚀 Deploying image to $SERVER_USER@$SERVER_IP"
- > - >
ssh -o StrictHostKeyChecking=no "$SERVER_USER@$SERVER_IP" " ssh -o StrictHostKeyChecking=no "$SERVER_USER@$SERVER_IP" "
docker pull $CI_REGISTRY_IMAGE/web-lti:development_${CI_COMMIT_SHORT_SHA} && docker pull $CI_REGISTRY_IMAGE/web-lti:development_${CI_COMMIT_SHORT_SHA} &&