Volver al Blog
Despliegue

Configuracion de servidor headless para BotBrowser en Ubuntu

Guia completa para configurar BotBrowser en un servidor Ubuntu headless para automatizacion en produccion.

Requisitos del servidor

  • SO: Ubuntu 20.04 o 22.04 LTS
  • RAM: 4GB minimo (8GB+ para multiples instancias)
  • CPU: 2+ nucleos
  • Disco: 10GB+ de espacio libre

Paso 1: Instalar dependencias

sudo apt-get update
sudo apt-get install -y \
  wget ca-certificates fonts-liberation \
  libasound2 libatk-bridge2.0-0 libatk1.0-0 \
  libcups2 libdbus-1-3 libdrm2 libgbm1 \
  libgtk-3-0 libnspr4 libnss3 \
  libxcomposite1 libxdamage1 libxrandr2 \
  xdg-utils xvfb

Paso 2: Configurar display virtual

Xvfb :10 -screen 0 1920x1080x24 &
export DISPLAY=:10.0

Para configuracion persistente, crea un servicio systemd:

# /etc/systemd/system/xvfb.service
[Unit]
Description=X Virtual Frame Buffer
After=network.target

[Service]
ExecStart=/usr/bin/Xvfb :10 -screen 0 1920x1080x24
Restart=always

[Install]
WantedBy=multi-user.target

Paso 3: Instalar BotBrowser

wget https://github.com/botswin/BotBrowser/releases/download/latest/botbrowser-linux.tar.gz
tar -xzf botbrowser-linux.tar.gz -C /opt/botbrowser/
chmod +x /opt/botbrowser/chrome
DISPLAY=:10.0 /opt/botbrowser/chrome --version

Paso 4: Ejecutar con Playwright

npm install playwright-core
const { chromium } = require('playwright-core');

(async () => {
  const browser = await chromium.launch({
    executablePath: '/opt/botbrowser/chrome',
    args: [
      '--disable-setuid-sandbox',
      '--bot-profile=/opt/profiles/profile.enc',
    ],
    headless: true,
    defaultViewport: null,
  });

  const page = await (await browser.newContext()).newPage();
  await page.goto('https://example.com');
  console.log('Title:', await page.title());
  await browser.close();
})();

Ejecutar con: DISPLAY=:10.0 node script.js

Consejos de produccion

Gestion de procesos. Usa PM2 o systemd:

npm install -g pm2
DISPLAY=:10.0 pm2 start script.js --name botbrowser-worker

Multiples instancias. Cada instancia necesita su propio --user-data-dir:

for i in $(seq 1 5); do
  DISPLAY=:10.0 /opt/botbrowser/chrome \
    --bot-profile="/opt/profiles/profile-${i}.enc" \
    --user-data-dir="/tmp/bb-session-${i}" &
done

Solucion de problemas

"Cannot open display": Asegurate de que Xvfb esta ejecutandose y DISPLAY=:10.0 esta establecido.

Segfault al iniciar: Ejecuta ldd /opt/botbrowser/chrome | grep "not found" para encontrar bibliotecas faltantes.

Alto uso de memoria: Establece --js-flags="--max-old-space-size=512" para limitar el heap JS.

Procesos zombie: Siempre llama a browser.close() y gestiona SIGTERM.

#headless#ubuntu#server#deployment#linux