Puppeteer в функциях firebase не смог запустить хром

Я пытаюсь запустить puppeteer в функции firebase. Как я понимаю это https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md#running-puppeteer-on-google-cloud-functions должно работать добавление

 "engines": {
    "node": "8"
  },

в пакете.json. Я получаю положительные отзывы, он использует развертывание firebase

 functions: updating Node.js 8 function helloWorld(us-central1)...

К сожалению, это обналичивает с

Error: Error: Failed to launch chrome!
[0408/080847.149912:ERROR:zygote_host_impl_linux.cc(89)] Running as root without --no-sandbox is not supported. See https://crbug.com/638180.


TROUBLESHOOTING: https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md

    at startPuppeteer.then.then.then.catch.error (/srv/index.js:42:15)
    at <anonymous>
    at process._tickDomainCallback (internal/process/next_tick.js:229:7)

Протестировал тот же код на локальном, который работал.

Это код облачных функций, который не работает.

const functions = require('firebase-functions');

const puppeteer = require('puppeteer');
let browser = ""
let page = ""

const startPuppeteer = async () => {
    browser = await puppeteer.launch();
    page = await browser.newPage()
}

const usePageInPuppeteer = async (url) => {
    await page.goto(url);
    return await page.title()
}

const closePuppeteer = async () => {
    return await browser.close();
}

const runtimeOpts = {
    timeoutSeconds: 500,
    memory: '2GB'
  }

exports.helloWorld = functions
.runWith(runtimeOpts)
.https.onRequest((request, response) => {

    //response.send()
    startPuppeteer()
    .then(() => {
        return usePageInPuppeteer('https://www.google.com')
    })
    .then(returnUse => {
        console.info(returnUse)
        return response.send(returnUse)
    })
    .then(() => {
        return closePuppeteer()
    })
    .catch(error => {
        throw new Error(error)
    });

});


Что местный тест, который работает

const puppeteer = require('puppeteer');

let browser = ""
let page = ""

const startPuppeteer = async () => {
    browser = await puppeteer.launch();
    page = await browser.newPage()
}

const usePageInPuppeteer = async (url) => {
    await page.goto(url);
    return await page.title()
}

const closePuppeteer = async () => {
    return await browser.close();
}


startPuppeteer()
.then(() => {
    return usePageInPuppeteer('https://www.google.com')
})
.then(returnUse => {
    console.info(returnUse)
    return closePuppeteer()
})
.catch(error => {
    throw new Error(error)
});

Running as root without --no-sandbox is not supported. Судя по этому сообщению, вам не хватает флага --no-sandbox для запуска вашего расширения.
Igor Ilic 08.04.2019 10:29
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
1
2 909
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий
const startPuppeteer = async () => {
    browser = await puppeteer.launch({args: ['--no-sandbox', '--disable-setuid-sandbox']});
    page = await browser.newPage()
}

прекрасно работает. Спасибо https://stackoverflow.com/users/2911633/igor-ilic за подсказку

вам нужно запустить хром в режиме песочницы. Запуск chrome от имени пользователя root напрямую не поддерживается, вы можете передать аргумент --no-sandbox, чтобы запустить его от имени пользователя root. Окончательный код будет выглядеть так

browser = await puppeteer.launch({args: ['--no-sandbox']});

Другие вопросы по теме