AWS Lambda 函数超时错误: 'errorMessage': 'Function timed out after 120 seconds (maxMemoryUsage: 242MB)'
这个错误提示是函数在运行时达到了 AWS Lambda 的时间限制,导致函数超时。默认的运行时间限制是 3 秒钟,但是可以通过 AWS 控制台或者 AWS CLI 来修改这个限制。在这个代码中,可能是因为 Puppeteer 加载页面和截图需要的时间较长,导致函数超时。你可以尝试增加函数的运行时间限制,或者优化代码以加快运行速度。
可能的解决方法:
- 增加函数的运行时间限制: 在 AWS Lambda 控制台中,您可以设置函数的运行时间限制。
- 优化代码: 您可以尝试优化代码,例如减少 Puppeteer 加载页面和截图所需的时间。例如,可以使用 Puppeteer 的
waitForNavigation方法来等待页面完全加载后再进行截图,或者使用puppeteer-extra库来优化 Puppeteer 的性能。
示例代码:
const fs = require('fs');
const path = require('path');
const puppeteer = require('puppeteer');
const launchBrowser = async () => {
const browser = await puppeteer.launch({
args: [
'--disable-gpu',
'--disable-dev-shm-usage',
'--disable-setuid-sandbox',
'--no-first-run',
'--no-zygote',
'--no-sandbox'
],
headless: true,
});
return browser;
};
const autoScroll = async (page) => {
return page.evaluate(() => {
return new Promise((resolve, reject) => {
var totalHeight = 0;
var distance = 100;
var timer = setInterval(() => {
var scrollHeight = document.body.scrollHeight;
window.scrollBy(0, distance);
totalHeight += distance;
if (totalHeight >= scrollHeight) {
clearInterval(timer);
resolve();
}
}, 100);
});
});
};
module.exports.handler = async (event, response, context) => {
const input = JSON.parse(event.body).input;
console.log('Input:', input);
const fileinput = `${Date.now()}.mmd`;
fs.writeFileSync(`/tmp/${fileinput}`, input);
const output = `${Date.now()}.png`;
const browser = await launchBrowser();
const page = await browser.newPage();
await page.emulateTimezone('Asia/Shanghai');
try {
const html = fs.readFileSync(path.join(__dirname, 'template.html'), 'utf8');
const renderedHtml = html.replace('{{mermaid}}', input);
const filehtml = `${Date.now()}.html`;
fs.writeFileSync(`/tmp/${filehtml}`, renderedHtml);
let url = 'file://' + path.join('/tmp', filehtml);
await page.goto(url, { waitUntil: 'networkidle2' }); // 等待页面完全加载
await page.setViewport({ width: 1200, height: 800 });
await autoScroll(page);
await page.screenshot({ path: `/tmp/${output}`, fullPage: true, type: 'png' });
console.log('Image generated:', output);
const imageStream = fs.createReadStream(`/tmp/${output}`);
response.setHeader('content-type', contentType);
response.send(imageStream);
} catch (err) {
console.error(err);
} finally {
await browser.close();
}
};
注意:
- 确保您已正确安装并配置了 Puppeteer。
- 可以根据实际情况调整代码中的参数,例如
waitUntil、setViewport和autoScroll的参数。
希望这些信息对您有所帮助。如果您还有其他问题,请随时提出。
原文地址: http://www.cveoy.top/t/topic/oyae 著作权归作者所有。请勿转载和采集!