mirror of
https://github.com/openfrontio/OpenFrontIO.git
synced 2026-06-21 15:51:42 +00:00
03f7bade7f
## Description: Update deployment: 1. automatically create and configure CF tunnels and point it to subdomain.domain 2. Send loki logs to remote endpoint 3. create metric-exporter.sh to push prom metrics to remote endpoint 4. update and refactor deployment & env variables ## Please complete the following: - [x] I have added screenshots for all UI updates - [x] I confirm I have thoroughly tested these changes and take full responsibility for any bugs introduced - [x] I understand that submitting code with bugs that could have been caught through manual testing blocks releases and new features for all contributors ## Please put your Discord username so you can be contacted if a bug or regression is found: <DISCORD USERNAME> --------- Co-authored-by: Evan Pellegrini <evan@Evans-Air.attlocal.net> Co-authored-by: evan <openfrontio@gmail.com>
105 lines
3.6 KiB
Bash
Executable File
105 lines
3.6 KiB
Bash
Executable File
#!/bin/bash
|
|
# update.sh - Script to update Docker container on Hetzner server
|
|
# Called by deploy.sh after uploading Docker image to Docker Hub
|
|
|
|
# Load environment variables if .env exists
|
|
if [ -f /home/openfront/.env ]; then
|
|
echo "Loading environment variables from .env file..."
|
|
export $(grep -v '^#' /home/openfront/.env | xargs)
|
|
fi
|
|
|
|
echo "======================================================"
|
|
echo "🔄 UPDATING SERVER: ${HOST} ENVIRONMENT"
|
|
echo "======================================================"
|
|
|
|
|
|
# Container and image configuration
|
|
CONTAINER_NAME="openfront-${ENV}-${SUBDOMAIN}"
|
|
|
|
docker login -u $DOCKER_USERNAME -p $DOCKER_TOKEN
|
|
|
|
# Install Loki Docker plugin if not already installed
|
|
if ! docker plugin ls | grep -q "loki"; then
|
|
echo "Installing Loki Docker plugin..."
|
|
docker plugin install grafana/loki-docker-driver:latest --alias loki --grant-all-permissions
|
|
if [ $? -ne 0 ]; then
|
|
echo "Failed to install Loki Docker plugin. Continuing anyway..."
|
|
else
|
|
echo "Loki Docker plugin installed successfully."
|
|
fi
|
|
else
|
|
echo "Loki Docker plugin already installed."
|
|
fi
|
|
|
|
echo "Pulling ${DOCKER_IMAGE} from Docker Hub..."
|
|
docker pull $DOCKER_IMAGE
|
|
|
|
echo "Checking for existing container..."
|
|
# Check for running container
|
|
RUNNING_CONTAINER=$(docker ps | grep ${CONTAINER_NAME} | awk '{print $1}')
|
|
if [ -n "$RUNNING_CONTAINER" ]; then
|
|
echo "Stopping running container $RUNNING_CONTAINER..."
|
|
docker stop $RUNNING_CONTAINER
|
|
echo "Waiting for container to fully stop and release resources..."
|
|
sleep 5 # Add a 5-second delay
|
|
docker rm $RUNNING_CONTAINER
|
|
echo "Container $RUNNING_CONTAINER stopped and removed."
|
|
fi
|
|
|
|
# Also check for stopped containers with the same name
|
|
STOPPED_CONTAINER=$(docker ps -a | grep ${CONTAINER_NAME} | awk '{print $1}')
|
|
if [ -n "$STOPPED_CONTAINER" ]; then
|
|
echo "Removing stopped container $STOPPED_CONTAINER..."
|
|
docker rm $STOPPED_CONTAINER
|
|
echo "Container $STOPPED_CONTAINER removed."
|
|
fi
|
|
|
|
# Check if port 80 is still in use
|
|
echo "Checking if port 80 is still in use..."
|
|
if command -v lsof >/dev/null 2>&1; then
|
|
PORT_CHECK=$(lsof -i :80 | grep LISTEN)
|
|
elif command -v netstat >/dev/null 2>&1; then
|
|
PORT_CHECK=$(netstat -tuln | grep ":80 ")
|
|
else
|
|
PORT_CHECK=""
|
|
echo "Warning: Cannot check if port is in use (neither lsof nor netstat found)"
|
|
fi
|
|
|
|
if [ -n "$PORT_CHECK" ]; then
|
|
echo "Warning: Port 80 is still in use by another process:"
|
|
echo "$PORT_CHECK"
|
|
echo "Attempting to proceed anyway..."
|
|
fi
|
|
|
|
echo "Starting new container for ${HOST} environment..."
|
|
docker run -d \
|
|
--restart=always \
|
|
$VOLUME_MOUNTS \
|
|
--log-driver=loki \
|
|
--log-opt loki-url="https://${MON_USERNAME}:${MON_PASSWORD}@mon.openfront.io/loki/loki/api/v1/push" \
|
|
--log-opt loki-batch-size="400" \
|
|
--log-opt loki-external-labels="job=docker,environment=${ENV},host=${HOST},subdomain=${SUBDOMAIN}" \
|
|
--env-file /home/openfront/.env \
|
|
--name ${CONTAINER_NAME} \
|
|
$DOCKER_IMAGE
|
|
|
|
if [ $? -eq 0 ]; then
|
|
echo "Update complete! New ${CONTAINER_NAME} container is running."
|
|
|
|
# Final cleanup after successful deployment
|
|
echo "Performing final cleanup of unused Docker resources..."
|
|
echo "Removing unused images (not tagged and not referenced)..."
|
|
docker image prune -f
|
|
docker container prune -f
|
|
echo "Cleanup complete."
|
|
else
|
|
echo "Failed to start container"
|
|
exit 1
|
|
fi
|
|
|
|
echo "======================================================"
|
|
echo "✅ SERVER UPDATE COMPLETED SUCCESSFULLY"
|
|
echo "Container name: ${CONTAINER_NAME}"
|
|
echo "Image: ${FULL_IMAGE_NAME}"
|
|
echo "Logs: Configured to send to Loki on port 3100"
|
|
echo "======================================================" |