sojorn/admin/setup_server.sh

105 lines
2.5 KiB
Bash

#!/bin/bash
set -e
echo "=== Cleaning up all node processes on port 3001 ==="
# Stop and fully remove any existing service
systemctl stop sojorn-admin 2>/dev/null || true
systemctl disable sojorn-admin 2>/dev/null || true
# Kill ALL node processes related to the admin panel
pkill -9 -f "next start --port 3001" 2>/dev/null || true
pkill -9 -f "dist/server/entry.mjs" 2>/dev/null || true
sleep 2
# Double-kill anything left on port 3001
fuser -k 3001/tcp 2>/dev/null || true
sleep 2
# Triple check
STILL_RUNNING=$(fuser 3001/tcp 2>/dev/null || true)
if [ -n "$STILL_RUNNING" ]; then
echo "Force killing PIDs: $STILL_RUNNING"
kill -9 $STILL_RUNNING 2>/dev/null || true
sleep 2
fi
echo "Port 3001 status:"
ss -tlnp | grep 3001 || echo "PORT IS FREE"
echo ""
echo "=== Writing systemd service ==="
cat > /etc/systemd/system/sojorn-admin.service <<'SVCEOF'
[Unit]
Description=Sojorn Admin Panel
After=network.target
[Service]
Type=simple
User=patrick
Group=patrick
WorkingDirectory=/opt/sojorn/admin
ExecStart=/usr/bin/node /opt/sojorn/admin/node_modules/next/dist/bin/next start --port 3001
Restart=on-failure
RestartSec=30
StartLimitIntervalSec=120
StartLimitBurst=3
Environment=NODE_ENV=production
Environment=NEXT_PUBLIC_API_URL=https://api.sojorn.net
[Install]
WantedBy=multi-user.target
SVCEOF
systemctl daemon-reload
systemctl enable sojorn-admin
systemctl start sojorn-admin
echo "Waiting 5s for startup..."
sleep 5
echo ""
echo "=== Service status ==="
systemctl status sojorn-admin --no-pager
echo ""
echo "=== Port check ==="
ss -tlnp | grep 3001
echo ""
echo "=== Setting up Nginx ==="
cat > /etc/nginx/sites-available/sojorn-admin <<'NGXEOF'
server {
listen 80;
server_name admin.sojorn.net;
location / {
proxy_pass http://127.0.0.1:3001;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_cache_bypass $http_upgrade;
}
}
NGXEOF
if [ ! -L /etc/nginx/sites-enabled/sojorn-admin ]; then
ln -s /etc/nginx/sites-available/sojorn-admin /etc/nginx/sites-enabled/
fi
nginx -t && systemctl reload nginx
echo "Nginx configured and reloaded"
echo ""
echo "=== Checking Go API service ==="
systemctl status sojorn-api --no-pager || true
echo ""
echo "=== DONE ==="