mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
docs(troubleshooting): add docker alpine example (#1836)
Fixes #1835, fixes #379
This commit is contained in:
parent
59f6d42610
commit
49d3799e32
@ -81,6 +81,7 @@ xorg-x11-fonts-misc
|
|||||||
- Check out discussions:
|
- Check out discussions:
|
||||||
- [#290](https://github.com/GoogleChrome/puppeteer/issues/290) - Debian troubleshooting
|
- [#290](https://github.com/GoogleChrome/puppeteer/issues/290) - Debian troubleshooting
|
||||||
- [#391](https://github.com/GoogleChrome/puppeteer/issues/391) - CentOS troubleshooting
|
- [#391](https://github.com/GoogleChrome/puppeteer/issues/391) - CentOS troubleshooting
|
||||||
|
- [#379]() - Alpine troubleshooting
|
||||||
|
|
||||||
## Chrome Headless fails due to sandbox issues
|
## Chrome Headless fails due to sandbox issues
|
||||||
|
|
||||||
@ -93,12 +94,12 @@ const browser = await puppeteer.launch({args: ['--no-sandbox', '--disable-setuid
|
|||||||
|
|
||||||
## Running Puppeteer in Docker
|
## Running Puppeteer in Docker
|
||||||
|
|
||||||
Using headless Chrome Linux to run Puppeteer in Docker container can be tricky.
|
Getting headless Chrome up and running in Docker can be tricky.
|
||||||
The bundled version Chromium that Puppeteer installs is missing the necessary
|
The bundled Chromium that Puppeteer installs is missing the necessary
|
||||||
shared library dependencies.
|
shared library dependencies.
|
||||||
|
|
||||||
To fix this, you'll need to install the latest version of Chrome dev in your
|
To fix, you'll need to install the missing dependencies and the
|
||||||
Dockerfile:
|
latest Chromium package in your Dockerfile:
|
||||||
|
|
||||||
```
|
```
|
||||||
FROM node:8-slim
|
FROM node:8-slim
|
||||||
@ -119,6 +120,10 @@ RUN apt-get update && apt-get install -y wget --no-install-recommends \
|
|||||||
&& apt-get purge --auto-remove -y curl \
|
&& apt-get purge --auto-remove -y curl \
|
||||||
&& rm -rf /src/*.deb
|
&& rm -rf /src/*.deb
|
||||||
|
|
||||||
|
# It's a good idea to use dumb-init to help prevent zombie chrome processes.
|
||||||
|
ADD https://github.com/Yelp/dumb-init/releases/download/v1.2.0/dumb-init_1.2.0_amd64 /usr/local/bin/dumb-init
|
||||||
|
RUN chmod +x /usr/local/bin/dumb-init
|
||||||
|
|
||||||
# Uncomment to skip the chromium download when installing puppeteer. If you do,
|
# Uncomment to skip the chromium download when installing puppeteer. If you do,
|
||||||
# you'll need to launch puppeteer with:
|
# you'll need to launch puppeteer with:
|
||||||
# browser.launch({executablePath: 'google-chrome-unstable'})
|
# browser.launch({executablePath: 'google-chrome-unstable'})
|
||||||
@ -127,15 +132,16 @@ RUN apt-get update && apt-get install -y wget --no-install-recommends \
|
|||||||
# Install puppeteer so it's available in the container.
|
# Install puppeteer so it's available in the container.
|
||||||
RUN yarn add puppeteer
|
RUN yarn add puppeteer
|
||||||
|
|
||||||
# Add pptr user.
|
# Add user so we don't need --no-sandbox.
|
||||||
RUN groupadd -r pptruser && useradd -r -g pptruser -G audio,video pptruser \
|
RUN groupadd -r pptruser && useradd -r -g pptruser -G audio,video pptruser \
|
||||||
&& mkdir -p /home/pptruser/Downloads \
|
&& mkdir -p /home/pptruser/Downloads \
|
||||||
&& chown -R pptruser:pptruser /home/pptruser \
|
&& chown -R pptruser:pptruser /home/pptruser \
|
||||||
&& chown -R pptruser:pptruser /node_modules
|
&& chown -R pptruser:pptruser /node_modules
|
||||||
|
|
||||||
# Run user as non privileged.
|
# Run everything after as non-privileged user.
|
||||||
USER pptruser
|
USER pptruser
|
||||||
|
|
||||||
|
ENTRYPOINT ["dumb-init", "--"]
|
||||||
CMD ["google-chrome-unstable"]
|
CMD ["google-chrome-unstable"]
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -156,6 +162,51 @@ Run the container by passing `node -e "<yourscript.js content as a string>` as t
|
|||||||
There's a full example at https://github.com/ebidel/try-puppeteer that shows
|
There's a full example at https://github.com/ebidel/try-puppeteer that shows
|
||||||
how to run this Dockerfile from a webserver running on App Engine Flex (Node).
|
how to run this Dockerfile from a webserver running on App Engine Flex (Node).
|
||||||
|
|
||||||
|
### Running on Alpine
|
||||||
|
|
||||||
|
The [newest Chromium package](https://pkgs.alpinelinux.org/package/edge/community/x86_64/chromium) supported on Alpine is 63, which was corresponds to [Puppeteer v0.11.0](https://github.com/GoogleChrome/puppeteer/releases/tag/v0.11.0).
|
||||||
|
|
||||||
|
Example Dockerfile:
|
||||||
|
|
||||||
|
```
|
||||||
|
FROM node:9-alpine
|
||||||
|
|
||||||
|
# Installs latest Chromium (63) package.
|
||||||
|
RUN apk update && apk upgrade && \
|
||||||
|
echo @edge http://nl.alpinelinux.org/alpine/edge/community >> /etc/apk/repositories && \
|
||||||
|
echo @edge http://nl.alpinelinux.org/alpine/edge/main >> /etc/apk/repositories && \
|
||||||
|
apk add --no-cache \
|
||||||
|
chromium@edge \
|
||||||
|
nss@edge
|
||||||
|
|
||||||
|
...
|
||||||
|
|
||||||
|
# Tell Puppeteer to skip installing Chrome. We'll be using the installed package.
|
||||||
|
ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD true
|
||||||
|
|
||||||
|
# Puppeteer v0.11.0 works with Chromium 63.
|
||||||
|
RUN yarn add puppeteer@0.11.0
|
||||||
|
|
||||||
|
# Add user so we don't need --no-sandbox.
|
||||||
|
RUN addgroup -S pptruser && adduser -S -g pptruser pptruser \
|
||||||
|
&& mkdir -p /home/pptruser/Downloads \
|
||||||
|
&& chown -R pptruser:pptruser /home/pptruser \
|
||||||
|
&& chown -R pptruser:pptruser /app
|
||||||
|
|
||||||
|
# Run everything after as non-privileged user.
|
||||||
|
USER pptruser
|
||||||
|
|
||||||
|
...
|
||||||
|
```
|
||||||
|
|
||||||
|
And when launching Chrome, be sure to use the `chromium-browser` executable:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const browser = await puppeteer.launch({
|
||||||
|
executablePath: '/usr/bin/chromium-browser'
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
#### Tips
|
#### Tips
|
||||||
|
|
||||||
By default, Docker runs a container with a `/dev/shm` shared memory space 64MB.
|
By default, Docker runs a container with a `/dev/shm` shared memory space 64MB.
|
||||||
|
Loading…
Reference in New Issue
Block a user