Node.js躬行记(22)——Node环境升级日志

简介: Node.js躬行记(22)——Node环境升级日志

 公司之前所有的 Node 项目,其环境都是 8.9.4 版本,发布于 2018 年的一个比较古老的版本。

  老版本有两个比较明显的问题:

  1. Node 高版本的特性和方法都无法使用。
  2. 有些第三方新版本的包无法安装和升级,该包可能依赖比较高的 Node 版本。

  之前在开发项目时就遇到第三方包自身的问题,必须升级或换个包才能解决,但因为 Node 版本的原因,无法替换,只能用其他方式来修补漏洞。

  为了提升维护性和开发体验,还是决定升级 Node 版本,2021年升级过一次,升级到 14 版本。

  但是因为一些奇怪的问题加上业务繁重,没有时间细究,就又回滚了,一直拖到今年的 7 月份,才继续推进升级的事情,本次会升级到 16.15 版本。

  目前总共有 4 个 Node 环境需要升级,测试资源紧张,在升级后,是没有人力来验证是否有问题发生,所以只能靠自己想办法安全升级。

1)分项目阶梯升级

  在 4 个待升级的项目中,有 3 个是对外的项目,有 1 个是对内的项目。

  那么先升级对内项目的 Node 版本,这样有两个好处:

  1. 即使出问题了,影响范围也能最小。
  2. 响应也能最及时,因为有问题的话,在公司内部能马上反馈到我们组。

2)分环境阶梯升级

  我们每个项目都会有 3 套运行环境:测试、预发和生产。

  首先将测试环境升级,测试环境都是开发人员使用,影响最小,反馈最快。

  观察一段时间后,再升级预发,预发环境与生产环境最为接近,数据库采用的也是一套。

  最后才是生产,给真实用户使用,再获取反馈。

3)邀请内部人员体验

  首先升级的是那个内部项目,所以在飞书上建了个群,将各个组的负责人拉进来。

  邀请他们在预发环境体验各自的业务,再给出反馈。

  在验收时发现了时区的问题,纠正后,再让他们验收。

4)部署自动错误告警

  让人来验收,难免会有遗漏,所以让运维给加了个自动错误告警。

  每分钟有 5 个 500 以上的错误,就自动在飞书上发告警信息。

  这类规则比较适合接口,而定时任务的规则比较特殊。

  因为任务可能是 5 分钟运行一次,那么报错的频率不会那么高。

  因此改成 5 分钟内有一个错误就告警,免得告警太多,也比较烦人。

5)增加单元测试流程

  在将对内的项目升级完成后,公司员工在访问一个服务时报错。

  让运维查看后,发现是因为连接地址配置错了。

  为了避免这种问题的发生,就需要有地方可以测试服务连接是否异常。

  手动测试比较繁琐,最好的办法是在发布代码的流程中,加一环服务连接。

  若成功,那么就继续后面的流程,否则就中断。

  公司使用的是阿里云提供的发布系统,里面可以加一步单元测试。

  服务连接是测试的一个场景,未来可以再加其他各类测试,保证项目质量。

 

  从开始升级到全部项目升级完成,前前后后操作了 20 多天,因为在一个环境或项目升级后,就要观察几天,然后再升级另一个环境或项目。在升级完成后,还部署了阿里云提供的一款 Node 监控系统。


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
13天前
|
开发框架 JavaScript 中间件
node+express搭建服务器环境
node+express搭建服务器环境
node+express搭建服务器环境
|
13天前
|
前端开发 测试技术
测Nuxt.js入坑,配置dev、test、pro三种环境的变量env
先下载一个cross-env模块,比较好控制环境
30 5
|
13天前
|
JavaScript 前端开发 持续交付
【专栏】Vue.js和Node.js如何结合构建现代Web应用
【4月更文挑战第27天】本文探讨了Vue.js和Node.js如何结合构建现代Web应用。Vue.js作为轻量级前端框架,以其简洁易懂、组件化开发、双向数据绑定和虚拟DOM等特点受到青睐;而Node.js是高性能后端平台,具备事件驱动、非阻塞I/O、丰富生态系统和跨平台优势。两者结合实现前后端分离,高效通信,并支持热更新、持续集成、跨平台和多端适配,为开发高性能、易维护的Web应用提供强有力的支持。
|
13天前
|
存储 JavaScript 前端开发
❤Nodejs 第十四章(node中间件multer的认识安装使用)
【4月更文挑战第14天】Multer是Node.js用于处理multipart/form-data的中间件,专注于文件上传。。基本用法包括设置存储引擎,如磁盘存储(DiskStorage)或内存存储(MemoryStorage),并指定处理单个或多个文件的方法。例如,`multer.single('file')`处理单个文件上传。存储引擎DiskStorage适合永久保存,而MemoryStorage适合临时处理。可以通过`limits`选项限制文件大小,实现不同类型的文件有不同的大小限制。
50 0
|
6天前
|
JavaScript 前端开发
autox.js如何打印日志?
autox.js如何打印日志?
|
6天前
|
传感器 JavaScript 前端开发
VSCOde安装node.js环境
VSCOde安装node.js环境
|
13天前
|
数据可视化 JavaScript NoSQL
搭建接口平台YApi详解(含搭建node环境)
搭建接口平台YApi详解(含搭建node环境)
32 0
|
13天前
|
JavaScript API 开发者
深入了解Node.js的文件系统:Node.js文件系统API的使用与探索
【4月更文挑战第30天】本文深入探讨了Node.js的文件系统API,介绍了如何引入`fs`模块进行文件操作。内容包括异步读取和写入文件、删除文件、创建目录以及使用文件流进行高效操作。此外,还提到了文件系统的监视功能,帮助开发者全面掌握在Node.js中处理文件和目录的方法。
|
13天前
|
JSON JavaScript 关系型数据库
❤Nodejs 第十六章(Nodejs环境安装和依赖使用)
【4月更文挑战第16天】本文介绍了Node.js环境安装和项目搭建步骤。检查Node.js和npm版本安装核心依赖,如Express(Web应用框架)、MySQL库、CORS(解决跨域问题)、body-parser(解析POST数据)、express-jwt和jsonwebtoken(JWT验证)、multer(文件上传处理)、ws(WebSocket支持),以及可选的dotenv(管理环境变量)和ejs(模板引擎)。完整源码可在Gitee开源项目[nexusapi](https://gitee.com/lintaibai/nexusapi)中找到。
28 0
|
13天前
|
运维 JavaScript Java
Serverless 应用引擎产品使用之阿里云Serverless函数计算中,在Node.js环境中执行jar文件如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。