Compare commits
13 Commits
0.0.3
...
a803759384
| Author | SHA1 | Date | |
|---|---|---|---|
| a803759384 | |||
| 1f65582e77 | |||
| 54cabc5f7f | |||
| 8760d61b22 | |||
| 1a2c725f6b | |||
| b346f02282 | |||
| 78271baba1 | |||
| 871b497ffa | |||
| 41e254f732 | |||
| 7ebdfede12 | |||
| bb7a2fd08e | |||
| 4058796b50 | |||
| 54d72b4d66 |
87
.drone.yml
87
.drone.yml
@@ -3,51 +3,88 @@ kind: pipeline
|
|||||||
type: docker
|
type: docker
|
||||||
name: default
|
name: default
|
||||||
|
|
||||||
steps:
|
# ARM64 platform (for your Pi runner)
|
||||||
# Step 1: Install dependencies & build Node.js app
|
platform:
|
||||||
- name: install-and-build
|
os: linux
|
||||||
image: node:20-alpine
|
arch: arm64
|
||||||
commands:
|
|
||||||
- echo "Installing dependencies..."
|
|
||||||
- npm ci
|
|
||||||
- echo "Building app..."
|
|
||||||
- npm run build
|
|
||||||
|
|
||||||
# Step 2: Build Docker image with dynamic Git tag
|
workspace:
|
||||||
|
path: /drone/src
|
||||||
|
|
||||||
|
steps:
|
||||||
|
# Step 1a: Git fetch tags locally
|
||||||
|
- name: fetch-tags
|
||||||
|
image: docker:24
|
||||||
|
environment:
|
||||||
|
DOCKER_HOST: unix:///var/run/docker.sock # local Docker, if needed
|
||||||
|
commands:
|
||||||
|
- apk add --no-cache git
|
||||||
|
- git fetch --tags
|
||||||
|
- |
|
||||||
|
LATEST_TAG=$(git describe --tags --abbrev=0)
|
||||||
|
echo "Latest Git tag fetched: $LATEST_TAG"
|
||||||
|
# Save to file to share with next step
|
||||||
|
echo $LATEST_TAG > /drone/src/LATEST_TAG.txt
|
||||||
|
|
||||||
|
# Step 1b: Check if image exists on remote LAN Docker
|
||||||
|
- name: check-remote-image
|
||||||
|
image: docker:24
|
||||||
|
environment:
|
||||||
|
DOCKER_HOST: tcp://192.168.1.111:2376 # remote Docker
|
||||||
|
commands:
|
||||||
|
- IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt)
|
||||||
|
- echo "Checking if apps/homepage:$IMAGE_TAG exists on remote Docker..."
|
||||||
|
- |
|
||||||
|
if docker image inspect apps/homepage:$IMAGE_TAG > /dev/null 2>&1; then
|
||||||
|
echo "✅ Docker image apps/homepage:$IMAGE_TAG already exists — skipping build";
|
||||||
|
exit 78; # stop pipeline gracefully
|
||||||
|
else
|
||||||
|
echo "⚙️ Docker image apps/homepage:$IMAGE_TAG not found — proceeding to build...";
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Step 2: Build Docker image (dynamic tag)
|
||||||
- name: build-image
|
- name: build-image
|
||||||
image: docker:24
|
image: docker:24
|
||||||
environment:
|
environment:
|
||||||
DOCKER_HOST: unix:///var/run/docker.sock
|
DOCKER_HOST: tcp://192.168.1.111:2376
|
||||||
commands:
|
commands:
|
||||||
- IMAGE_TAG=${DRONE_TAG:-latest}
|
- |
|
||||||
- echo "Building Docker image apps/homepage:$IMAGE_TAG ..."
|
IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt)
|
||||||
- docker build -t apps/homepage:$IMAGE_TAG .
|
if [ -z "$IMAGE_TAG" ]; then
|
||||||
|
echo "❌ No tag found in LATEST_TAG.txt — cannot build."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "🔨 Building Docker image apps/homepage:$IMAGE_TAG ..."
|
||||||
|
docker build --network=host -t apps/homepage:$IMAGE_TAG -t apps/homepage:latest
|
||||||
|
|
||||||
# Step 3: Stop old container if exists
|
# Step 3: Stop old container (if exists)
|
||||||
- name: stop-old
|
- name: stop-old
|
||||||
image: docker:24
|
image: docker:24
|
||||||
environment:
|
environment:
|
||||||
DOCKER_HOST: unix:///var/run/docker.sock
|
DOCKER_HOST: tcp://192.168.1.111:2376
|
||||||
commands:
|
commands:
|
||||||
- IMAGE_TAG=${DRONE_TAG:-latest}
|
- |
|
||||||
- echo "Stopping old container..."
|
echo "🛑 Stopping old container..."
|
||||||
- docker rm -f homepage || true
|
docker rm -f homepage || true
|
||||||
|
|
||||||
# Step 4: Run container with dynamic tag
|
# Step 4: Run container
|
||||||
- name: run-container
|
- name: run-container
|
||||||
image: docker:24
|
image: docker:24
|
||||||
environment:
|
environment:
|
||||||
DOCKER_HOST: unix:///var/run/docker.sock
|
DOCKER_HOST: tcp://192.168.1.111:2376
|
||||||
commands:
|
commands:
|
||||||
- IMAGE_TAG=${DRONE_TAG:-latest}
|
- |
|
||||||
- echo "Starting container apps/homepage:$IMAGE_TAG ..."
|
IMAGE_TAG=$(cat /drone/src/LATEST_TAG.txt)
|
||||||
- docker run -d \
|
echo "🚀 Starting container apps/homepage:$IMAGE_TAG ..."
|
||||||
|
docker run -d \
|
||||||
--name homepage \
|
--name homepage \
|
||||||
-p 3001:3000 \
|
-p 3001:3000 \
|
||||||
-e NODE_ENV=production \
|
-e NODE_ENV=production \
|
||||||
apps/homepage:$IMAGE_TAG
|
apps/homepage:$IMAGE_TAG
|
||||||
|
|
||||||
# Trigger pipeline on Git tags
|
# Trigger rules
|
||||||
trigger:
|
trigger:
|
||||||
event:
|
event:
|
||||||
|
- push
|
||||||
- tag
|
- tag
|
||||||
|
- custom
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ services:
|
|||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
# network: host
|
# network: host
|
||||||
container_name: homepage
|
container_name: homepage
|
||||||
image: apps/homepage:0.0.3
|
image: apps/homepage:0.0.5
|
||||||
ports:
|
ports:
|
||||||
- "3001:3000" # map host port 3000 to container
|
- "3001:3000" # map host port 3000 to container
|
||||||
environment:
|
environment:
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"name": "material-ui-react-router-ts",
|
"name": "homepage",
|
||||||
"private": true,
|
"private": true,
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|||||||
Reference in New Issue
Block a user