Compare commits
25 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| ae5628f370 | |||
| e8e2419537 | |||
| 4ee6027612 | |||
| 389e77e2ae | |||
| 7ce860db96 | |||
| 92f307d33d | |||
| 6e7d2d9f14 | |||
| c91dba475c | |||
| 04d988c584 | |||
| 27abc56a00 | |||
| 333b48ad60 | |||
| 4dee0bfb0a | |||
| 1e91825808 | |||
| c5cb1047ae | |||
| 18f9eed71d | |||
| 02de328bcd | |||
| 31f1a66fed | |||
| 5065145c6f | |||
| 8e0475c8a7 | |||
| 1359a75214 | |||
| 6786547950 | |||
| 17a2caea49 | |||
| 8ff199ca10 | |||
| 62c1f3920b | |||
| 73e3f0a7ac |
59
.drone.yml
59
.drone.yml
@@ -17,7 +17,7 @@ volumes:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
# 1. Fetch latest Git tag
|
# 1. Fetch latest Tags
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
- name: fetch-tags
|
- name: fetch-tags
|
||||||
image: docker:24
|
image: docker:24
|
||||||
@@ -28,34 +28,43 @@ steps:
|
|||||||
- apk add --no-cache git
|
- apk add --no-cache git
|
||||||
- git fetch --tags
|
- git fetch --tags
|
||||||
- |
|
- |
|
||||||
|
# Get latest Git tag and trim newline
|
||||||
LATEST_TAG=$(git describe --tags --abbrev=0 2>/dev/null | tr -d '\n')
|
LATEST_TAG=$(git describe --tags --abbrev=0 2>/dev/null | tr -d '\n')
|
||||||
echo "Latest Git tag: $LATEST_TAG"
|
echo "Latest Git tag fetched: $LATEST_TAG"
|
||||||
|
|
||||||
|
# Save to file for downstream steps
|
||||||
echo "$LATEST_TAG" > /drone/src/LATEST_TAG.txt
|
echo "$LATEST_TAG" > /drone/src/LATEST_TAG.txt
|
||||||
if [ -z "$LATEST_TAG" ]; then
|
|
||||||
echo "❌ No git tags found. Cannot continue."
|
# Read back for verification
|
||||||
|
IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
||||||
|
echo "Image tag read from file: $IMAGE_TAG"
|
||||||
|
|
||||||
|
# Validate
|
||||||
|
if [ -z "$IMAGE_TAG" ]; then
|
||||||
|
echo "❌ No git tags found! Cannot continue."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
# 2. Check if remote image already exists
|
# 2. Check existing Nakama Docker image
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
- name: check-remote-image
|
- name: check-remote-image
|
||||||
image: docker:24
|
image: docker:24
|
||||||
volumes:
|
volumes:
|
||||||
- name: dockersock
|
- name: dockersock
|
||||||
path: /var/run/docker.sock
|
path: /var/run/docker.sock
|
||||||
environment:
|
|
||||||
REGISTRY_HOST:
|
|
||||||
from_secret: REGISTRY_HOST
|
|
||||||
commands:
|
commands:
|
||||||
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
||||||
- echo "Checking if $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG exists..."
|
|
||||||
|
- echo "Checking if lila-games/nakama-server:$IMAGE_TAG exists on remote Docker..."
|
||||||
|
- echo "Existing Docker tags for lila-games/nakama-server:"
|
||||||
|
- docker images --format "{{.Repository}}:{{.Tag}}" | grep "^lila-games/nakama-server" || echo "(none)"
|
||||||
- |
|
- |
|
||||||
if docker pull $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG > /dev/null 2>&1; then
|
if docker image inspect lila-games/nakama-server:$IMAGE_TAG > /dev/null 2>&1; then
|
||||||
echo "✅ Image already exists: $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG"
|
echo "✅ Docker image lila-games/nakama-server:$IMAGE_TAG already exists — skipping build"
|
||||||
exit 78
|
exit 78
|
||||||
else
|
else
|
||||||
echo "⚙️ Image does not exist. Will build."
|
echo "⚙️ Docker image lila-games/nakama-server:$IMAGE_TAG not found — proceeding to build..."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
@@ -68,22 +77,19 @@ steps:
|
|||||||
path: /var/run/docker.sock
|
path: /var/run/docker.sock
|
||||||
commands:
|
commands:
|
||||||
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
||||||
- echo "🔨 Building Nakama image lila-games/nakama-server:$IMAGE_TAG"
|
|
||||||
|
- echo "🔨 Building Nakama image lila-games/nakama-server:latest"
|
||||||
- |
|
- |
|
||||||
docker build \
|
docker build --network=host \
|
||||||
--network=host \
|
|
||||||
-t lila-games/nakama-server:$IMAGE_TAG \
|
-t lila-games/nakama-server:$IMAGE_TAG \
|
||||||
-t lila-games/nakama-server:latest \
|
-t lila-games/nakama-server:latest \
|
||||||
/drone/src
|
/drone/src
|
||||||
|
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
# 4. Push Nakama image to registry
|
# 4. Push Nakama Image
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
- name: push-image
|
- name: push-image
|
||||||
image: docker:24
|
image: docker:24
|
||||||
volumes:
|
|
||||||
- name: dockersock
|
|
||||||
path: /var/run/docker.sock
|
|
||||||
environment:
|
environment:
|
||||||
REGISTRY_HOST:
|
REGISTRY_HOST:
|
||||||
from_secret: REGISTRY_HOST
|
from_secret: REGISTRY_HOST
|
||||||
@@ -91,15 +97,20 @@ steps:
|
|||||||
from_secret: REGISTRY_USER
|
from_secret: REGISTRY_USER
|
||||||
REGISTRY_PASS:
|
REGISTRY_PASS:
|
||||||
from_secret: REGISTRY_PASS
|
from_secret: REGISTRY_PASS
|
||||||
|
volumes:
|
||||||
|
- name: dockersock
|
||||||
|
path: /var/run/docker.sock
|
||||||
commands:
|
commands:
|
||||||
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt | tr -d '\n')
|
||||||
- echo "🔑 Logging into registry..."
|
|
||||||
|
- echo "🔑 Logging into registry $REGISTRY_HOST ..."
|
||||||
- echo "$REGISTRY_PASS" | docker login $REGISTRY_HOST -u "$REGISTRY_USER" --password-stdin
|
- echo "$REGISTRY_PASS" | docker login $REGISTRY_HOST -u "$REGISTRY_USER" --password-stdin
|
||||||
- echo "🏷️ Tagging images..."
|
- echo "🏷️ Tagging images with registry prefix..."
|
||||||
- docker tag lila-games/nakama-server:$IMAGE_TAG $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG
|
- docker tag lila-games/nakama-server:$IMAGE_TAG $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG
|
||||||
- docker tag lila-games/nakama-server:$IMAGE_TAG $REGISTRY_HOST/lila-games/nakama-server:latest
|
- docker tag lila-games/nakama-server:$IMAGE_TAG $REGISTRY_HOST/lila-games/nakama-server:latest
|
||||||
- echo "📤 Pushing images..."
|
- echo "📤 Pushing lila-games/nakama-server:$IMAGE_TAG ..."
|
||||||
- docker push $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG
|
- docker push $REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG
|
||||||
|
- echo "📤 Pushing lila-games/nakama-server:latest ..."
|
||||||
- docker push $REGISTRY_HOST/lila-games/nakama-server:latest
|
- docker push $REGISTRY_HOST/lila-games/nakama-server:latest
|
||||||
|
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
@@ -142,9 +153,7 @@ steps:
|
|||||||
--add-host private-pi:192.168.1.111 \
|
--add-host private-pi:192.168.1.111 \
|
||||||
-e DB_ADDR="$DB_ADDR" \
|
-e DB_ADDR="$DB_ADDR" \
|
||||||
-e SERVER_KEY="$SERVER_KEY" \
|
-e SERVER_KEY="$SERVER_KEY" \
|
||||||
-v /mnt/omnissiah-vault/data/nakama/modules:/nakama/data/modules \
|
lila-games/nakama-server:latest
|
||||||
-v /mnt/omnissiah-vault/data/nakama/storage:/nakama/data \
|
|
||||||
$REGISTRY_HOST/lila-games/nakama-server:$IMAGE_TAG
|
|
||||||
|
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
# Pipeline trigger
|
# Pipeline trigger
|
||||||
|
|||||||
23
Dockerfile
23
Dockerfile
@@ -1,21 +1,19 @@
|
|||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
# 1. Build the Nakama plugin (ARM64)
|
# 1. Build the Nakama plugin
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
FROM golang:1.22-alpine AS plugin_builder
|
FROM --platform=linux/arm64 golang:1.21.6 AS plugin_builder
|
||||||
|
|
||||||
# Install dependencies needed for CGO plugin build
|
RUN apt-get update && apt-get install -y \
|
||||||
RUN apk add --no-cache git build-base
|
build-essential \
|
||||||
|
git
|
||||||
|
|
||||||
WORKDIR /workspace
|
WORKDIR /workspace
|
||||||
|
|
||||||
# Download module deps first (better caching)
|
|
||||||
COPY go.mod go.sum ./
|
COPY go.mod go.sum ./
|
||||||
RUN go mod download
|
RUN go mod download
|
||||||
|
|
||||||
# Copy source code
|
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
# Build plugin
|
|
||||||
RUN mkdir -p build && \
|
RUN mkdir -p build && \
|
||||||
CGO_ENABLED=1 go build \
|
CGO_ENABLED=1 go build \
|
||||||
--trimpath \
|
--trimpath \
|
||||||
@@ -25,16 +23,13 @@ RUN mkdir -p build && \
|
|||||||
|
|
||||||
|
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
# 2. Build final Nakama image (ARM64)
|
# 2. Build final Nakama image
|
||||||
# -----------------------------------------------------
|
# -----------------------------------------------------
|
||||||
FROM --platform=linux/arm64 heroiclabs/nakama:3.21.0 AS nakama
|
FROM heroiclabs/nakama:3.21.0-arm
|
||||||
|
|
||||||
# Copy plugin from builder stage
|
# Copy plugin from builder stage
|
||||||
COPY --from=plugin_builder /workspace/build/main.so /nakama/data/modules/main.so
|
COPY --from=plugin_builder /workspace/build/main.so /nakama/data/modules/main.so
|
||||||
|
#COPY --from=plugin_builder local.yml /nakama/data/config.yml
|
||||||
|
|
||||||
# Default Nakama startup (runs migrations + server)
|
# Default Nakama startup (runs migrations + server)
|
||||||
ENTRYPOINT [
|
ENTRYPOINT exec /bin/sh -ecx "/nakama/nakama migrate up --database.address \"$DB_ADDR\" && exec /nakama/nakama --database.address \"$DB_ADDR\" --socket.server_key=\"$SERVER_KEY\""
|
||||||
"/bin/sh", "-ecx", "\
|
|
||||||
/nakama/nakama migrate up --database.address \"$DB_ADDR\" && \
|
|
||||||
exec /nakama/nakama --database.address \"$DB_ADDR\" --socket.server_key=\"$SERVER_KEY\""
|
|
||||||
]
|
|
||||||
|
|||||||
Reference in New Issue
Block a user