Я пытаюсь экспортировать изображение, созданное с помощью WebGL на сервере Linux без GPU. Для этого я использую безголовый Chrome, однако экспортированное изображение является черным (пример экспортированного изображения, снятие скриншота страницы показывает его простое полотно, которое является черным). Я надеялся на какую-то помощь в выяснении, почему это происходит.
Чтобы экспортировать изображение, я визуализую изображение в холст, экспортирую данные через canvas.toDataURL('image/jpeg')
, а затем отправляю данные на сервер. Я использую Pixi.js для рендеринга, если я использую canvas renderer, тогда все работает на сервере; Это рендеринг WebGL не работает. Стоит отметить, что рендеринг WebGL отлично работает в Chrome 63 на Macbook.
Для управления Chrome я использую Puppeteer. Все, что я делаю, это открыть страницу, ждать секунды, а затем снова закрыть ее:
puppeteer
.launch({
args: [
'--no-sandbox',
'--disable-setuid-sandbox',
],
})
.then(browser => {
return browser.newPage().then(page => {
return page
.goto(url)
.then(() => page.waitFor(1000))
.then(() => browser.close())
.catch(err => console.error('Failed', err));
});
})
Это аргументы, которые кукловод передает в Chrome:
[
'--disable-background-networking',
'--disable-background-timer-throttling',
'--disable-client-side-phishing-detection',
'--disable-default-apps',
'--disable-extensions',
'--disable-hang-monitor',
'--disable-popup-blocking',
'--disable-prompt-on-repost',
'--disable-sync',
'--disable-translate',
'--metrics-recording-only',
'--no-first-run',
'--remote-debugging-port=0',
'--safebrowsing-disable-auto-update',
'--enable-automation',
'--password-store=basic',
'--use-mock-keychain',
'--user-data-dir=/tmp/puppeteer_dev_profile-GhEAXZ',
'--headless',
'--disable-gpu',
'--hide-scrollbars',
'--mute-audio',
'--no-sandbox',
'--disable-setuid-sandbox'
]
автор swiftshader сказал, что в июне можно сделать рендеринг без заголовка WebGL и кажется подтвержденный этой проблемой Chromium, поэтому я думаю, что я что-то упустил. У кого-нибудь есть идеи, что я делаю неправильно?
Несколько вещей, которые я пробовал:
- Не проходит через --disable-gpu
-
--use-gl=swiftshader-webgl
,--use-gl=swiftshader
,--use-gl=osmesa
- Взятие полного скриншота экрана, чтобы увидеть, просто ли его холст. Весь экран просто черный.
Версия
- Chrome: linux-515411
- puppeteer: 0.13.0
- node: 8.2.1
- Linux: CentOS 7
Это то, что мне нужно было установить на моем сервере, чтобы запустить хром (Источник)
yum install cups-libs dbus-glib libXrandr libXcursor libXinerama cairo cairo-gobject pango ffmpeg
rpm -ivh --nodeps http://mirror.centos.org/centos/7/os/x86_64/Packages/atk-2.22.0-3.el7.x86_64.rpm
rpm -ivh --nodeps http://mirror.centos.org/centos/7/os/x86_64/Packages/at-spi2-atk-2.22.0-2.el7.x86_64.rpm
rpm -ivh --nodeps http://mirror.centos.org/centos/7/os/x86_64/Packages/at-spi2-core-2.22.0-1.el7.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/20/Fedora/x86_64/os/Packages/g/GConf2-3.2.6-7.fc20.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/20/Fedora/x86_64/os/Packages/l/libXScrnSaver-1.2.2-6.fc20.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/20/Fedora/x86_64/os/Packages/l/libxkbcommon-0.3.1-1.fc20.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/20/Fedora/x86_64/os/Packages/l/libwayland-client-1.2.0-3.fc20.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/20/Fedora/x86_64/os/Packages/l/libwayland-cursor-1.2.0-3.fc20.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/20/Fedora/x86_64/os/Packages/g/gtk3-3.10.4-1.fc20.x86_64.rpm
rpm -ivh --nodeps http://dl.fedoraproject.org/pub/archive/fedora/linux/releases/16/Fedora/x86_64/os/Packages/gdk-pixbuf2-2.24.0-1.fc16.x86_64.rpm