6、Node.js 微服务:从单体到微服务架构的转型之路

Node.js 微服务:从单体到微服务架构的转型之路

1. Node.js 任务运行器

在 Node.js 开发中,任务运行器起着至关重要的作用,它能帮助我们更好地管理应用程序的生命周期。

1.1 PM2 简介

PM2 是一款生产进程管理器,它能对 Node.js 应用进行上下扩展,还能对服务器实例进行负载均衡。此外,它能确保进程持续运行,解决了 Node.js 线程模型的一个副作用:未捕获的异常会杀死线程,进而导致应用程序崩溃。

1.2 单线程应用与异常处理

Node.js 应用以单线程运行,但这并不意味着它不具备并发能力,只是应用程序在单线程上运行,而其他操作可以并行执行。然而,如果异常未被处理,应用程序就会崩溃。解决办法是大量使用像 bluebird 这样的 Promise 库,它能添加成功和失败的处理程序,防止异常导致应用崩溃。不过,仍存在一些无法控制的情况,即不可恢复的错误或 bug,最终可能导致应用程序因处理不当的错误而崩溃。在 Java 等语言中,异常不会造成太大影响,线程死亡但应用程序仍可继续运行,而在 Node.js 中,这是个大问题。最初,我们使用像 forever 这样的任务运行器来解决这个问题,当应用程序因某种原因退出时,它们会重新运行应用程序,确保其正常运行时间。

1.3 forever 和 nodemon
  • forever :以 helloWorld.js 应用为例,forever 会在应用程序崩溃时重新运行它。例如,我们可以杀死应用程序的进程(如 kill -9 4093 ),但 forever 会在
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值