繁体   English   中英

aws cdk graphicsmagick lambda pdf 到 png

[英]aws cdk graphicsmagick lambda pdf to png

我需要 AWS CDK 来部署 lambda 队列,并想使用gm将 PDF 的第一页转换为 PNG。 我对实现没问题,因为它在我的笔记本电脑上运行良好,我只需要帮助添加 graphicsmagick 二进制文件。

我当然得到Error: Stream yields empty buffer ,因为下面的 NodejsFunction 不包含必要的二进制文件。 如何部署安装了 graphicsmagick 的 NodejsFunction?

    const designerHandler = new NodejsFunction(this, "designer-server", {
      functionName: "designer-server",
      memorySize: 512,
      runtime: lambda.Runtime.NODEJS_12_X,
      handler: "handler",
      entry: path.join(__dirname, "./server/src/index.ts"),
      timeout: cdk.Duration.seconds(30),
    });

我试过使用图层但没有成功,现在我正在考虑使用 docker。

    designerHandler.addLayers(
      lambda.LayerVersion.fromLayerVersionArn(
        this,
        "layer-graphicsmagick",
        "arn:aws:lambda:ap-southeast-2:391641713082:layer:graphicsmagick-layer:1"
      )
    );

这是我对gm的用法。

  const pngOf = (pdf: Buffer) => {
    return new Promise(
      (resolve: (value: Buffer) => void, reject: (reason: any) => void) => {
        gm(pdf)
          .density(600, 600)
          .resize(600)
          .toBuffer('PNG', (err, png) => {
            if (err) {
              reject(err);
            }
            resolve(png);
          });
      }
    );
  };

我最终用 DockerImage function 解决了这个问题。

const designerHandler = new lambda.DockerImageFunction(
  this,
  "designer-server",
  {
    functionName: "designer-server",
    memorySize: 512,
    code: lambda.DockerImageCode.fromImageAsset(
      path.join(__dirname, "./server")
    ),
    timeout: cdk.Duration.seconds(30),
  }
);

Dockerfile如下

# transpile typescript into javascript
FROM public.ecr.aws/lambda/nodejs:18 as builder

WORKDIR /usr/app

COPY package*.json ./
RUN npm install

# .dockerignore node_modules/ dist/
COPY . .
# rimraf dist && tsc
RUN npm run build 


FROM public.ecr.aws/lambda/nodejs:18

WORKDIR ${LAMBDA_TASK_ROOT}

RUN yum -y install gcc-c++ make libpng-devel libjpeg-devel libtiff-devel wget tar gzip libpng libjpeg libtiff ghostscript freetype freetype-devel jasper jasper-devel
RUN wget https://sourceforge.net/projects/graphicsmagick/files/graphicsmagick/1.3.38/GraphicsMagick-1.3.38.tar.gz \
        && tar -zxvf GraphicsMagick-1.3.38.tar.gz \
        && rm GraphicsMagick-1.3.38.tar.gz
RUN ./GraphicsMagick-1.3.38/configure --prefix=/var/task/graphicsmagick --enable-shared=no --enable-static=yes
RUN make
RUN make install
RUN tar -zcvf ~/graphicsmagick.tgz /var/task/graphicsmagick/

ENV PATH="${PATH}:/var/task/graphicsmagick/bin"

COPY package*.json ./
RUN npm install

# copy builders javascript to task root
COPY --from=builder /usr/app/dist ./
ENTRYPOINT [ "/lambda-entrypoint.sh" ]
CMD [ "index.handler" ]

在处理程序中使用就很简单了

import gm from 'gm';

这是tsconfig.json万一。

{
  "compilerOptions": {
    "target": "es2020",
    "module": "commonjs",
    "rootDir": "./src",
    "outDir": "./dist",
    "esModuleInterop": true,
    "forceConsistentCasingInFileNames": true,
    "strict": true,
    "baseUrl": "./src",
    "paths": {
      "src/*": ["./*"]
    },
  },
  "include": ["src/**/*"],
  "exclude": ["node_modules"]
}

如果不使用 typescript ,则完全删除构建器并简单地COPY usr/app/src./

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM