使用Serverless可快速搭建免运维、低成本的自动更新RSS服务,通过定时触发器抓取网页内容并生成RSS,部署简单且支持弹性扩展,适合低频更新场景。
想搭建一个能自动更新的RSS服务,又不想维护服务器?Serverless 是个理想选择。它按需运行、成本低、无需管理基础设施。通过 Serverless 框架,你可以快速部署一个定时抓取内容并生成 RSS 的服务,整个过程几分钟就能完成。
传统方式需要买 VPS、配置环境、写定时任务,还要担心宕机和带宽。而 Serverless 的优势很明显:
使用 Serverless Framework 部署到腾讯云或 AWS Lambda,配合 Node.js 和 Cheerio 抓取网页内容。
你需要准备:
创建一个函数,定时访问目标页面,提取最新文章标题、链接和摘要,生成标准 RSS 输出。
示例代码结构:
// handler.js
const axios = require('axios');
const cheerio = require('cheerio');
const { parseString, Builder } = require('xml2js');
module.exports.rssHandler = async (event, context) => {
const url = 'https://www./link/5fa81016250471111dfca121ae9cdc14';
const response = await axios.get(url);
const $ = cheerio.load(response.data);
const items = [];
$('.post-item').each((i, elem) => {
if (i < 10) { // 取前10篇文章
items.push({
title: $(elem).find('h2 a').text(),
link: $(elem).find('h2 a').attr('href'),
description: $(elem).find('.excerpt').text(),
pubDate: new Date().toUTCString()
});
}
});
const rssObj = {
rss: {
$: { version: '2.0' },
channel: [{
title: 'My Auto RSS',
link: url,
description: 'Automatically generated RSS feed',
item: items
}]
}
};
const xml = new Builder().buildObject(rssObj);
return {
statusCode: 200,
headers: {
'Content-Type': 'application/xml; charset=utf-8'
},
body: xml
};
};
在 serverless.yml 中定义函数和触发周期:
service: auto-rss-serviceprovider: name: tencent runtime: Nodejs14.17 region: ap-guangzhou
functions: rss: handler: handler.rssHandler events:
部署命令:
serverless deploy部署成功后,你会得到一个 HTTPS 地址,比如:https://service-xxx.gz.apigw.tencentcs.com/release/rss,把这个地址添加到 RSS 阅读器即可。
实际使用中要注意几点:
基本上就这些。用 Serverless 构建 RSS 服务,不复杂但容易忽略细节。只要目标网站结构稳定,这个方案可以长期自动运行,帮你省下不少手动刷新的时
间。