[英]How to deploy expressjs static templates to AWS without restarting the server?
我有部署到AWS Elastic beantalk的express.js服务器服务器。 我使用车把引擎进行模板制作。 模板的结构更改比服务器代码更频繁,因此我希望有一种快速的方法来部署它们。 我已经尝试过在单独的S3静态存储桶上托管模板,然后从nodejs代码加载它们。 这样,我可以使用S3静态部署真正快速地将更改部署到模板,而不是通过eb deploy
重新启动所有服务器节点。
这是我用于模板加载的node.js服务器代码:
const s3 = new aws.S3();
s3.getObject({Bucket: 'bucketname.com', Key: 'views/' + path}, (err, data) => {
const template = handlebars.compile(data.Body.toString('utf-8'));
resolve(template);
});
这解决了模板部署速度的问题,但是我不确定它是否不会带来额外的性能损失。 我以为,由于S3和Elastic beantalk都是亚马逊服务,因此影响应该很小,但是网站基准使我不这么认为。
也许有更好的方法来解决模板部署速度的问题?
关于基准测试编号,我认为这是因为您的代码每次需要渲染视图时,都会尝试从s3
获取视图模板。 这些网络呼叫将导致开销。
在我以前的一个项目中,我曾经面临过类似的挑战。 但是,在我们的情况下,这些频繁更改的模板的大小和数量都在可接受的范围内,并且可以将它们存储在内存中。
我们最终创建了一个不同的GIT存储库来存储这些静态模板。 express
服务器将在启动时加载这些模板并将其缓存在内存中。
每次模板更改(git repo中的新提交)时,我们都配置了一个Webhook来ping express
服务器。 然后,服务器使其缓存无效,并从同一存储库加载新模板。 这样,我们无需为静态模板中的每个更改重新启动服务器。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.