mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
feat: add canary builds for testing purposes
This commit is contained in:
parent
04a2ca49f3
commit
63b5fdaa71
5
.dockerignore
Normal file
5
.dockerignore
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
node_modules
|
||||||
|
.git
|
||||||
|
.gitignore
|
||||||
|
*.md
|
||||||
|
dist
|
@ -1,7 +1,18 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
VERSION=$(node -p "require('./package.json').version")
|
# Determine the type of build based on the first script argument
|
||||||
|
BUILD_TYPE=${1:-production}
|
||||||
|
|
||||||
docker build --platform linux/amd64 --pull --rm -f 'Dockerfile' -t "dokploy/dokploy:${VERSION}" .
|
if [ "$BUILD_TYPE" == "canary" ]; then
|
||||||
|
TAG="canary"
|
||||||
|
else
|
||||||
|
VERSION=$(node -p "require('./package.json').version")
|
||||||
|
TAG="$VERSION"
|
||||||
|
fi
|
||||||
|
|
||||||
docker tag "dokploy/dokploy:${VERSION}" "dokploy/dokploy:latest"
|
docker build --platform linux/amd64 --pull --rm -f 'Dockerfile' -t "dokploy/dokploy:${TAG}" .
|
||||||
|
|
||||||
|
if [ "$BUILD_TYPE" != "canary" ]; then
|
||||||
|
# Tag the production build as latest
|
||||||
|
docker tag "dokploy/dokploy:${TAG}" "dokploy/dokploy:latest"
|
||||||
|
fi
|
||||||
|
90
docker/canary.sh
Normal file
90
docker/canary.sh
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ "$(id -u)" != "0" ]; then
|
||||||
|
echo "This script must be run as root" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# check if is Mac OS
|
||||||
|
if [ "$(uname)" = "Darwin" ]; then
|
||||||
|
echo "This script must be run on Linux" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# check if is running inside a container
|
||||||
|
if [ -f /.dockerenv ]; then
|
||||||
|
echo "This script must be run on Linux" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# check if something is running on port 80
|
||||||
|
if ss -tulnp | grep ':80 ' >/dev/null; then
|
||||||
|
echo "Error: something is already running on port 80" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# check if something is running on port 443
|
||||||
|
if ss -tulnp | grep ':443 ' >/dev/null; then
|
||||||
|
echo "Error: something is already running on port 443" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
command_exists() {
|
||||||
|
command -v "$@" > /dev/null 2>&1
|
||||||
|
}
|
||||||
|
|
||||||
|
if command_exists docker; then
|
||||||
|
echo "Docker already installed"
|
||||||
|
else
|
||||||
|
curl -sSL https://get.docker.com | sh
|
||||||
|
fi
|
||||||
|
|
||||||
|
docker swarm leave --force 2>/dev/null
|
||||||
|
docker swarm init --advertise-addr 127.0.0.1 --listen-addr 0.0.0.0;
|
||||||
|
|
||||||
|
echo "Swarm initialized"
|
||||||
|
|
||||||
|
docker network rm -f dokploy-network 2>/dev/null
|
||||||
|
docker network create --driver overlay --attachable dokploy-network
|
||||||
|
|
||||||
|
echo "Network created"
|
||||||
|
|
||||||
|
mkdir -p /etc/dokploy
|
||||||
|
|
||||||
|
chmod -R 777 /etc/dokploy
|
||||||
|
|
||||||
|
docker pull dokploy/dokploy:canary
|
||||||
|
|
||||||
|
# Installation
|
||||||
|
docker service create \
|
||||||
|
--name dokploy \
|
||||||
|
--replicas 1 \
|
||||||
|
--network dokploy-network \
|
||||||
|
--mount type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock \
|
||||||
|
--mount type=bind,source=/etc/dokploy,target=/etc/dokploy \
|
||||||
|
--publish published=3000,target=3000,mode=host \
|
||||||
|
--update-parallelism 1 \
|
||||||
|
--update-order stop-first \
|
||||||
|
-e RELEASE_TAG=canary \
|
||||||
|
dokploy/dokploy:canary
|
||||||
|
|
||||||
|
|
||||||
|
public_ip=$(hostname -I | awk '{print $1}')
|
||||||
|
|
||||||
|
GREEN="\033[0;32m"
|
||||||
|
YELLOW="\033[1;33m"
|
||||||
|
BLUE="\033[0;34m"
|
||||||
|
NC="\033[0m" # No Color
|
||||||
|
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
printf "${GREEN}Congratulations, Dokploy is installed!${NC}\n"
|
||||||
|
printf "${BLUE}Wait 15 seconds for the server to start${NC}\n"
|
||||||
|
printf "${YELLOW}Please go to http://${public_ip}:3000${NC}\n\n"
|
||||||
|
echo ""
|
@ -1,6 +1,15 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
VERSION=$(node -p "require('./package.json').version")
|
# Determine the type of build based on the first script argument
|
||||||
|
BUILD_TYPE=${1:-production}
|
||||||
|
|
||||||
docker push "dokploy/dokploy:${VERSION}"
|
if [ "$BUILD_TYPE" == "canary" ]; then
|
||||||
docker push "dokploy/dokploy:latest"
|
TAG="canary"
|
||||||
|
echo PUSHING CANARY
|
||||||
|
docker push "dokploy/dokploy:${TAG}"
|
||||||
|
else
|
||||||
|
echo "PUSHING PRODUCTION"
|
||||||
|
VERSION=$(node -p "require('./package.json').version")
|
||||||
|
docker push "dokploy/dokploy:${VERSION}"
|
||||||
|
docker push "dokploy/dokploy:latest"
|
||||||
|
fi
|
||||||
|
@ -23,6 +23,8 @@
|
|||||||
"db:clean": "dotenv tsx ./server/db/reset.ts",
|
"db:clean": "dotenv tsx ./server/db/reset.ts",
|
||||||
"docker:build": "./docker/build.sh",
|
"docker:build": "./docker/build.sh",
|
||||||
"docker:push": "./docker/push.sh",
|
"docker:push": "./docker/push.sh",
|
||||||
|
"docker:build:canary": "./docker/build.sh canary",
|
||||||
|
"docker:push:canary": "./docker/push.sh canary",
|
||||||
"version": "echo $(node -p \"require('./package.json').version\")"
|
"version": "echo $(node -p \"require('./package.json').version\")"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
@ -130,6 +132,6 @@
|
|||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": "^18.18.0",
|
"node": "^18.18.0",
|
||||||
"pnpm": "^8.15.4"
|
"pnpm": ">=8.15.4"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@ const updateIsAvailable = async () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export const getDokployImage = () => {
|
export const getDokployImage = () => {
|
||||||
return "dokploy/dokploy:latest";
|
return `dokploy/dokploy:${process.env.RELEASE_TAG || "latest"}`;
|
||||||
};
|
};
|
||||||
|
|
||||||
export const pullLatestRelease = async () => {
|
export const pullLatestRelease = async () => {
|
||||||
|
Loading…
Reference in New Issue
Block a user