TypeError: Невозможно прочитать свойство 'width' неопределенной библиотеки gm - PullRequest
0 голосов
/ 26 октября 2019

Ранее я перешел по этой ссылке , чтобы успешно создавать эскизы изображений с помощью AWS Lambda. Версия узла была 8.10 .

Теперь, поскольку AWS будет устаревать для любого приложения с этой версией узла, я должен обновить версию узла до 10.x .

Мы связываемся с вами, поскольку мы определили, что ваша учетная запись AWS в настоящее время имеет одну или несколько функций Lambda с использованием Node.js 8.10, который достигнет своего EOL в конце 2019 года.

Что происходит?

Сообщество Node решило прекратить поддержку Node.js 8.x 31 декабря 2019 года 1 . С этой даты Node.js 8.x прекратит получать исправления ошибок, обновления безопасности и / или улучшения производительности. Чтобы гарантировать, что ваши новые и существующие функции работают в поддерживаемом и безопасном времени выполнения, языковые среды выполнения, достигшие своего EOL, не поддерживаются в AWS 2 .

Для Node.js 8.x существуетбудет 2 этапа процесса устаревания среды выполнения:

  1. Отключить создание функции - начиная с 6 января 2020 года клиенты больше не смогут создавать функции с использованием Node.js 8.10

  2. Отключить обновление функций - начиная с 3 февраля 2020 года клиенты больше не смогут обновлять функции с помощью Node.js 8.10

По истечении этого периода обе функциисоздание и обновления будут отключены навсегда. Однако существующие функции Node 8.x по-прежнему будут доступны для обработки событий вызова.

Что мне нужно сделать?

Мы рекомендуем обновить все функции Node.js 8.10 доболее новая доступная версия среды выполнения, Node.js 10.x [3]. Вы должны проверить свои функции на совместимость с языковой версией Node.js 10.x, прежде чем вносить изменения в производственные функции.

Что если у меня возникнут проблемы / Что если мне понадобится помощь?

ПожалуйстаСвяжитесь с нами через службу поддержки AWS [4] или форумы разработчиков AWS [5], если у вас возникнут какие-либо вопросы или проблемы.

Итак, я обновил версию своего узла до 10.17.0 и снова разверните пакет в AWS Lambda. Теперь, если какое-либо изображение было загружено на S3, и aws lambda пытается преобразовать изображение в миниатюру, оно показывает ошибку ниже:

enter image description here

Этополный код:

// dependencies
var async = require('async');
var AWS = require('aws-sdk');
var gm = require('gm')
            .subClass({ imageMagick: true }); // Enable ImageMagick integration.
var util = require('util');

// constants
var MAX_WIDTH  = 100;
var MAX_HEIGHT = 100;

// get reference to S3 client 
var s3 = new AWS.S3();

exports.handler = function(event, context, callback) {
    // Read options from the event.
    console.log("Reading options from event:\n", util.inspect(event, {depth: 5}));
    var srcBucket = event.Records[0].s3.bucket.name;
    // Object key may have spaces or unicode non-ASCII characters.
    var srcKey    =
    decodeURIComponent(event.Records[0].s3.object.key.replace(/\+/g, " "));  
    var dstBucket = srcBucket + "resized";
    var dstKey    = "resized-" + srcKey;

    // Sanity check: validate that source and destination are different buckets.
    if (srcBucket == dstBucket) {
        callback("Source and destination buckets are the same.");
        return;
    }

    // Infer the image type.
    var typeMatch = srcKey.match(/\.([^.]*)$/);
    if (!typeMatch) {
        callback("Could not determine the image type.");
        return;
    }
    var imageType = typeMatch[1].toLowerCase();
    if (imageType != "jpg" && imageType != "png") {
        callback(`Unsupported image type: ${imageType}`);
        return;
    }

    // Download the image from S3, transform, and upload to a different S3 bucket.
    async.waterfall([
        function download(next) {
            // Download the image from S3 into a buffer.
            s3.getObject({
                    Bucket: srcBucket,
                    Key: srcKey
                },
                next);
            },
        function transform(response, next) {
            gm(response.Body).size(function(err, size) {
                // Infer the scaling factor to avoid stretching the image unnaturally.
                var scalingFactor = Math.min(
                    MAX_WIDTH / size.width,
                    MAX_HEIGHT / size.height
                );
                var width  = scalingFactor * size.width;
                var height = scalingFactor * size.height;

                // Transform the image buffer in memory.
                this.resize(width, height)
                    .toBuffer(imageType, function(err, buffer) {
                        if (err) {
                            next(err);
                        } else {
                            next(null, response.ContentType, buffer);
                        }
                    });
            });
        },
        function upload(contentType, data, next) {
            // Stream the transformed image to a different S3 bucket.
            s3.putObject({
                    Bucket: dstBucket,
                    Key: dstKey,
                    Body: data,
                    ContentType: contentType
                },
                next);
            }
        ], function (err) {
            if (err) {
                console.error(
                    'Unable to resize ' + srcBucket + '/' + srcKey +
                    ' and upload to ' + dstBucket + '/' + dstKey +
                    ' due to an error: ' + err
                );
            } else {
                console.log(
                    'Successfully resized ' + srcBucket + '/' + srcKey +
                    ' and uploaded to ' + dstBucket + '/' + dstKey
                );
            }

            callback(null, "message");
        }
    );
};

Ошибка в основном в этой строке:

gm(response.Body).size(function(err, size) {
                // Infer the scaling factor to avoid stretching the image unnaturally.
                var scalingFactor = Math.min(
                    MAX_WIDTH / size.width, // In this line where the size is undefined
                    MAX_HEIGHT / size.height
                );

Версия узла 8.10 работает отлично. Я понятия не имею, что делать в этом случае. У меня есть объем памяти 1024 МБ в конфигурации

Может кто-нибудь указать мне, где я должен изменить? Заранее спасибо.

1 Ответ

1 голос
/ 28 октября 2019

Проблема в том, что gm больше не поддерживается с NodeJS 10.x: https://github.com/aheckmann/gm/issues/752.

Так что здесь будут проблемы. Кажется, что вы должны создать и использовать лямбда-слой, чтобы исправить это. Но настоящая проблема возникает, если вы используете Lambda @ Edge, поскольку лямбда-слои здесь не разрешены: https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/lambda-requirements-limits.html

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...