docker内阿尔卑斯山上的节点画布

时间:2019-07-18 06:23:57

标签: docker alpine node-canvas

我正在尝试在docker的Alpine上安装节点画布(https://github.com/Automattic/node-canvas)。

这些是我的Dockerfile(的一部分):

# Use node/alpine image for final build
FROM keymetrics/pm2:latest-alpine as app

# install dependencies for canvas
RUN apk --no-cache --virtual .build-deps add \
        python \
        make \
        g++ \
        gcc \
    && apk --no-cache --virtual .canvas-build-deps add \
        build-base \
        cairo-dev \
        jpeg-dev \
        pango-dev \
        giflib-dev \
        pixman-dev \
        pangomm-dev \
        libjpeg-turbo-dev \
        freetype-dev \
    && apk --no-cache add \
        pixman \
        cairo \
        pango \
        giflib
RUN apk add --update  --repository http://dl-3.alpinelinux.org/alpine/edge/testing libmount ttf-dejavu ttf-droid ttf-freefont ttf-liberation ttf-ubuntu-font-family fontconfig

# Install dependencies
RUN npm install --prod
RUN npm rebuild canvas --build-from-source

当我尝试启动Docker容器时出现以下错误:

Error: Error relocating /var/www/app/node_modules/canvas/build/Release/canvas.node: FcConfigGetCurrent: symbol not found


    at Object.Module._extensions..node (internal/modules/cjs/loader.js:775:18)


    at Module.load (internal/modules/cjs/loader.js:626:32)


    at tryModuleLoad (internal/modules/cjs/loader.js:566:12)


    at Function.Module._load (internal/modules/cjs/loader.js:558:3)


    at Module.require (internal/modules/cjs/loader.js:663:17)


    at require (internal/modules/cjs/helpers.js:20:18)


    at Object.<anonymous> (/var/www/app/node_modules/canvas/lib/bindings.js:3:18)


    at Module._compile (internal/modules/cjs/loader.js:734:30)


    at Object.Module._extensions..js (internal/modules/cjs/loader.js:745:10)


    at Module.load (internal/modules/cjs/loader.js:626:32)


    at tryModuleLoad (internal/modules/cjs/loader.js:566:12)


    at Function.Module._load (internal/modules/cjs/loader.js:558:3)


    at Module.require (internal/modules/cjs/loader.js:663:17)


    at require (internal/modules/cjs/helpers.js:20:18)


    at Object.<anonymous> (/var/www/app/node_modules/canvas/lib/canvas.js:9:18)


    at Module._compile (internal/modules/cjs/loader.js:734:30)

我猜想这与Alpine使用musl而不是glibc有关,但是我认为从源npm rebuild canvas --build-from-source重建画布就足够了。

我已经尝试了https://github.com/Automattic/node-canvas/issues的大多数建议,但没有一个对我有用。

有什么建议吗?

5 个答案:

答案 0 :(得分:3)

好的,这是一个答案-一种在官方 node:10.16.0-alpine Docker镜像下安装 node-canvas v2.5 的方法。您可能知道,您发布的错误“错误重定位... canvas.node”表示您的构建失败。这是因为canvas使用 glibc ,而alpine使用 musl 。 Canvas需要链接到 glibc ,因此您需要将其添加到图像中。 Sasha Gerrand提供了alpine-pkg-glibc作为其中一种方法。按照他的安装说明,这是在docker文件中的外观:

    #  geo_core layer
    #  build on a node image, in turn built on alpine linux, Docker's official linux pulled from hub.docker.com
    FROM node:10.16.0-alpine

    #  add libraries; sudo so non-root user added downstream can get sudo
    RUN apk add --no-cache \
        sudo \
        curl \
        build-base \
        g++ \
        libpng \
        libpng-dev \
        jpeg-dev \
        pango-dev \
        cairo-dev \
        giflib-dev \
        python \
        ;

    #  add glibc and install canvas
    RUN apk --no-cache add ca-certificates wget  && \
        wget -q -O /etc/apk/keys/sgerrand.rsa.pub https://alpine-pkgs.sgerrand.com/sgerrand.rsa.pub && \
        wget https://github.com/sgerrand/alpine-pkg-glibc/releases/download/2.29-r0/glibc-2.29-r0.apk && \
        apk add glibc-2.29-r0.apk && \
        npm install canvas@2.5.0
        ;

答案 1 :(得分:3)

我在使用alpine和nodev8.9.4的docker base上安装canvas@2.6.0时遇到了相同的错误。我可以通过升级到 nodev10.15.0 alpinev3.10 来解决此问题。它无需安装alpine-pkg-glibc软件包即可工作。当然,您仍然必须安装以下软件包:

apk add --no-cache \
    python \
    g++ \
    build-base \
    cairo-dev \
    jpeg-dev \
    pango-dev \
    musl-dev \
    giflib-dev \
    pixman-dev \
    pangomm-dev \
    libjpeg-turbo-dev \
    freetype-dev \
    && npm install canvas@2.6.0

答案 2 :(得分:1)

FROM node:12-alpine

WORKDIR /app

RUN apk add --update --no-cache \
    make \
    g++ \
    jpeg-dev \
    cairo-dev \
    giflib-dev \
    pango-dev \
    libtool \
    autoconf \
    automake

COPY package.json ./

RUN npm install

COPY . .

这对我有用。额外的包是对钠原生的依赖。

答案 3 :(得分:0)

这不是答案-抱歉-但是您可能需要一种解决方法,直到此问题得到解决。我已临时备份到 node:8.1.0-alpine 图片。在此图像下,我可以 npm安装canvas@1.6.7 。它引发了很多警告,但我得到了可以部署的工作映像。现在,我希望有人能找到解决此问题的真正方法,并且我们可以使canvas 2.5在node:10.16.0-alpine下运行。希望对您有所帮助。

答案 4 :(得分:0)

“重建”对我也不起作用。但是,您可以尝试进行此修改(请忽略其他库的其他软件包)

FROM node:8.16.0-alpine
....

RUN apk --update --no-cache --virtual build-dependencies add \
    python python-dev py-pip \ 
    build-base make g++ pkgconfig autoconf automake bash \ 
    imagemagick cairo-dev jpeg-dev pango-dev giflib-dev pixman-dev pangomm-dev libjpeg-turbo-dev freetype-dev \ 
    libc6-compat \  
  && apk --no-cache add \
    pixman cairo pango giflib libjpeg \
....
# Remove the canvas in package.json
RUN npm install canvas@2.0.0-alpha.12 --build-from-source
RUN npm install --prod