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 会在
超级会员免费看
订阅专栏 解锁全文

96

被折叠的 条评论
为什么被折叠?



