mirror of
https://github.com/openfrontio/OpenFrontIO.git
synced 2026-06-21 14:20:45 +00:00
191 lines
6.2 KiB
Bash
191 lines
6.2 KiB
Bash
#!/bin/bash
|
|
# Comprehensive setup script for Hetzner server with Docker, user setup, Node Exporter, and OpenTelemetry
|
|
# Exit on error
|
|
set -e
|
|
|
|
echo "====================================================="
|
|
echo "🚀 STARTING SERVER SETUP"
|
|
echo "====================================================="
|
|
|
|
# Verify required environment variables
|
|
if [ -z "$OTEL_ENDPOINT" ] || [ -z "$OTEL_USERNAME" ] || [ -z "$OTEL_PASSWORD" ]; then
|
|
echo "❌ ERROR: Required environment variables are not set!"
|
|
echo "Please set OTEL_ENDPOINT, OTEL_USERNAME, and OTEL_PASSWORD"
|
|
exit 1
|
|
fi
|
|
|
|
echo "🔄 Updating system..."
|
|
apt update && apt upgrade -y
|
|
|
|
# Check if Docker is already installed
|
|
if command -v docker &> /dev/null; then
|
|
echo "Docker is already installed"
|
|
else
|
|
echo "🐳 Installing Docker..."
|
|
# Install Docker using official script
|
|
curl -fsSL https://get.docker.com -o get-docker.sh
|
|
sh get-docker.sh
|
|
systemctl enable --now docker
|
|
echo "Docker installed successfully"
|
|
fi
|
|
|
|
echo "👤 Setting up openfront user..."
|
|
# Create openfront user if it doesn't exist
|
|
if id "openfront" &>/dev/null; then
|
|
echo "User openfront already exists"
|
|
else
|
|
useradd -m -s /bin/bash openfront
|
|
echo "User openfront created"
|
|
fi
|
|
|
|
# Check if openfront is already in docker group
|
|
if groups openfront | grep -q '\bdocker\b'; then
|
|
echo "User openfront is already in the docker group"
|
|
else
|
|
# Add openfront to docker group
|
|
usermod -aG docker openfront
|
|
echo "Added openfront to docker group"
|
|
fi
|
|
|
|
# Create .ssh directory for openfront if it doesn't exist
|
|
if [ ! -d "/home/openfront/.ssh" ]; then
|
|
mkdir -p /home/openfront/.ssh
|
|
chmod 700 /home/openfront/.ssh
|
|
echo "Created .ssh directory for openfront"
|
|
fi
|
|
|
|
# Copy SSH keys from root if they exist and haven't been copied yet
|
|
if [ -f /root/.ssh/authorized_keys ] && [ ! -f /home/openfront/.ssh/authorized_keys ]; then
|
|
cp /root/.ssh/authorized_keys /home/openfront/.ssh/
|
|
chmod 600 /home/openfront/.ssh/authorized_keys
|
|
echo "SSH keys copied from root to openfront"
|
|
fi
|
|
|
|
# Configure UDP buffer sizes for Cloudflare Tunnel
|
|
# https://github.com/quic-go/quic-go/wiki/UDP-Buffer-Sizes
|
|
echo "🔧 Configuring UDP buffer sizes..."
|
|
# Check if settings already exist in sysctl.conf
|
|
if grep -q "net.core.rmem_max" /etc/sysctl.conf && grep -q "net.core.wmem_max" /etc/sysctl.conf; then
|
|
echo "UDP buffer size settings already configured"
|
|
else
|
|
# Add UDP buffer size settings to sysctl.conf
|
|
echo "# UDP buffer size settings for improved QUIC performance" >> /etc/sysctl.conf
|
|
echo "net.core.rmem_max=7500000" >> /etc/sysctl.conf
|
|
echo "net.core.wmem_max=7500000" >> /etc/sysctl.conf
|
|
|
|
# Apply the settings immediately
|
|
sysctl -p
|
|
echo "UDP buffer sizes configured and applied"
|
|
fi
|
|
|
|
# Set proper ownership for openfront's home directory
|
|
chown -R openfront:openfront /home/openfront
|
|
echo "Set proper ownership for openfront's home directory"
|
|
|
|
# Create directory for OpenTelemetry configuration
|
|
echo "📊 Setting up Node Exporter and OpenTelemetry Collector..."
|
|
OTEL_CONFIG_DIR="/home/openfront/otel"
|
|
|
|
if [ ! -d "$OTEL_CONFIG_DIR" ]; then
|
|
mkdir -p "$OTEL_CONFIG_DIR"
|
|
echo "Created OpenTelemetry configuration directory"
|
|
fi
|
|
|
|
# Generate Base64 auth string
|
|
BASE64_AUTH=$(echo -n "${OTEL_USERNAME}:${OTEL_PASSWORD}" | base64)
|
|
|
|
# Create OpenTelemetry Collector configuration
|
|
cat > "$OTEL_CONFIG_DIR/otel-collector-config.yaml" << EOF
|
|
receivers:
|
|
prometheus:
|
|
config:
|
|
scrape_configs:
|
|
- job_name: 'node'
|
|
scrape_interval: 10s
|
|
static_configs:
|
|
- targets: ['localhost:9100'] # Node Exporter endpoint
|
|
relabel_configs:
|
|
- source_labels: [__address__]
|
|
regex: '.*'
|
|
target_label: openfront.host
|
|
replacement: "\${HOSTNAME}"
|
|
|
|
processors:
|
|
batch:
|
|
# Batch metrics before sending
|
|
timeout: 10s
|
|
send_batch_size: 1000
|
|
|
|
exporters:
|
|
otlphttp:
|
|
endpoint: "${OTEL_ENDPOINT}"
|
|
headers:
|
|
Authorization: "Basic ${BASE64_AUTH}"
|
|
tls:
|
|
insecure: true # Set to false in production with proper certs
|
|
|
|
service:
|
|
pipelines:
|
|
metrics:
|
|
receivers: [prometheus]
|
|
processors: [batch]
|
|
exporters: [otlphttp]
|
|
EOF
|
|
|
|
# Set ownership of all files
|
|
chmod 600 "$OTEL_CONFIG_DIR/otel-collector-config.yaml"
|
|
chown -R openfront:openfront "$OTEL_CONFIG_DIR"
|
|
|
|
# Run Node Exporter
|
|
echo "🚀 Starting Node Exporter..."
|
|
docker pull prom/node-exporter:latest
|
|
docker rm -f node-exporter 2>/dev/null || true
|
|
docker run -d \
|
|
--name=node-exporter \
|
|
--restart=unless-stopped \
|
|
--net="host" \
|
|
--pid="host" \
|
|
-v "/:/host:ro,rslave" \
|
|
prom/node-exporter:latest \
|
|
--path.rootfs=/host
|
|
|
|
# Run OpenTelemetry Collector
|
|
echo "🚀 Starting OpenTelemetry Collector..."
|
|
docker pull otel/opentelemetry-collector-contrib:latest
|
|
docker rm -f otel-collector 2>/dev/null || true
|
|
# Run OpenTelemetry Collector with appropriate permissions
|
|
# Run OpenTelemetry Collector
|
|
echo "🚀 Starting OpenTelemetry Collector..."
|
|
docker pull otel/opentelemetry-collector-contrib:latest
|
|
docker rm -f otel-collector 2>/dev/null || true
|
|
|
|
docker run -d \
|
|
--name=otel-collector \
|
|
--restart=unless-stopped \
|
|
--network=host \
|
|
--user=0 \
|
|
-v "$OTEL_CONFIG_DIR/otel-collector-config.yaml:/etc/otelcol-contrib/config.yaml:ro" \
|
|
-e OTEL_ENDPOINT="${OTEL_ENDPOINT}" \
|
|
otel/opentelemetry-collector-contrib:latest
|
|
|
|
# Check if containers are running
|
|
if docker ps | grep -q node-exporter && docker ps | grep -q otel-collector; then
|
|
echo "✅ Node Exporter and OpenTelemetry Collector started successfully!"
|
|
else
|
|
echo "❌ Failed to start containers. Check logs with: docker logs node-exporter or docker logs otel-collector"
|
|
exit 1
|
|
fi
|
|
|
|
echo "====================================================="
|
|
echo "🎉 SETUP COMPLETE!"
|
|
echo "====================================================="
|
|
echo "The openfront user has been set up and has Docker permissions."
|
|
echo "UDP buffer sizes have been configured for optimal QUIC/WebSocket performance."
|
|
echo "Node Exporter is collecting system metrics."
|
|
echo "OpenTelemetry Collector is forwarding metrics to your endpoint."
|
|
echo ""
|
|
echo "📝 Configuration:"
|
|
echo " - Config Directory: $OTEL_CONFIG_DIR"
|
|
echo " - OpenTelemetry Endpoint: $OTEL_ENDPOINT"
|
|
echo " - Username: $OTEL_USERNAME"
|
|
echo "=====================================================" |