Retour au Blog
Déploiement

Configuration serveur headless pour BotBrowser sur Ubuntu

Guide complet pour configurer BotBrowser sur un serveur Ubuntu headless pour l'automatisation en production.

Configuration requise du serveur

  • OS : Ubuntu 20.04 ou 22.04 LTS
  • RAM : 4 Go minimum (8 Go+ pour instances multiples)
  • CPU : 2+ coeurs
  • Disque : 10 Go+ d'espace libre

Etape 1 : Installer les dependances

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

Etape 2 : Configurer l'affichage virtuel

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

Pour une configuration persistante, creez un service 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

Etape 3 : Installer 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

Etape 4 : Executer avec 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();
})();

Executez avec : DISPLAY=:10.0 node script.js

Conseils de production

Gestion des processus. Utilisez PM2 ou systemd :

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

Instances multiples. Chaque instance necessite son propre --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

Depannage

"Cannot open display" : Assurez-vous que Xvfb est en cours d'execution et que DISPLAY=:10.0 est defini.

Segfault au demarrage : Executez ldd /opt/botbrowser/chrome | grep "not found" pour trouver les bibliotheques manquantes.

Utilisation memoire elevee : Definissez --js-flags="--max-old-space-size=512" pour limiter le heap JS.

Processus zombies : Appelez toujours browser.close() et gerez SIGTERM.

#headless#ubuntu#server#deployment#linux