使用 TypeScript 迁移 NestJS 微服务到 Go:一周的发现
上周,我沉浸在 Go 的世界中,目的是将我们在 NestJS 中开发的微服务迁移到 TypeScript。这个旅程是一次激烈的练习,旨在忘记某些范式并采用其他范式,了解这两个开发生态系统之间的根本差异。
我们在 NestJS 中的架构
在 NestJS 堆栈中,我们管理连接到 PostgreSQL 和 Redis 数据库的微服务。我们在微服务之间实施各种通信策略:
- 通过事件进行通信:我们使用 Pub/Sub 进行订阅和主题,从而允许微服务之间进行异步通信。
- 前端后端(BFF):我们实现受 JWT 保护的 REST API,它充当前端和数据库之间的中介。
验证和迁移
DTO 验证和数据迁移在我们的系统中至关重要。 TypeScript 允许我们使用 Knex 和 TypeORM 定义严格的类型和结构来处理迁移。虽然有效,但这种方法需要深入了解该语言以及如何跨不同微服务操作数据流。
NestJS 的挑战
我们检测到事件循环影响性能的问题,我们使用 Clinic.js 库解决了这些问题。我们确定了瓶颈并优化了设计模式以及异步和等待的使用。然而,管理 Node.js 中的并发可能会很复杂,而且会占用大量资源。
进入Go
在探索 Go 时,我们遇到了范式转变和一系列显着差异:
- 编译和静态类型:与TypeScript不同,Go是一种具有强静态类型的编译语言,这迫使我们在编译时检测错误。
- 控制流和错误处理:Go 通过明确关注返回错误而不是异常来简化错误处理。
- 数据结构和内存:Go 中的内存分配和数据结构管理需要对硬件有更深入的了解,这与 JavaScript 更抽象的做法不同。
面向对象编程和接口
在Go中,虽然支持面向对象,但它的表现却有所不同。没有传统的继承和接口的使用提供了独特的灵活性,必须彻底理解才能充分利用它。
比较例
数据验证
-
NestJS:我们在 DTO 中使用装饰器进行验证。
从 'class-validator' 导入 { IsString, IsInt } ; 类 CreateUserDto { @IsString() 名称:字符串; @IsInt() 年龄:数字; }
-
Go:我们使用 go-playground/validator 等库进行验证。
导入( “gopkg.in/go-playground/validator.v9” ) 类型用户结构{ 名称字符串`验证:“必需”` 年龄 int `验证:"gte=0"` } 验证 := 验证器.New() user := &User{姓名:“Alice”,年龄:25} err := validate.Struct(用户)
异步通信
-
NestJS:使用 async/await 处理 Promise。
异步函数 fetchData(): Promise<void> { const 数据 = 等待 apiCall(); 控制台.log(数据); }
-
Go:使用 goroutine 和通道来实现并发。
func fetchData() { dataChan := make(chan 字符串) 去函数(){ dataChan <- apiCall() }() 数据 := <-dataChan fmt.Println(数据) }
工具和设置
在 Go 中,我们采用了 Gin 等工具用于 REST API,以及 Gorm 作为 ORM。在 VSCode 中使用 make 设置我们的环境来自动化任务对于保持生产力和适应这种新的工作流程至关重要。
最后的想法
从带有 TypeScript 的 NestJS 迁移到 Go 充满挑战,但也很有回报。虽然 NestJS 在快速 API 开发方面提供了丰富的经验,重点是重用和抽象,但 Go 为我们提供了对并发和性能的更精细的控制,这对于高度可扩展的应用程序至关重要。
我们继续试验和调整我们的工作流程,尽管面临挑战,但我们对 Go 为我们的微服务的未来提供的可能性感到兴奋。
我希望这个博客能为那些考虑类似转变的人提供指导和启发。您在技术迁移方面有哪些经验?一路走来你发现了哪些挑战和解决方案?
分享你的故事,让我们一起继续学习!
本站部分资源来源于网络,仅限用于学习和研究目的,请勿用于其他用途。
如有侵权请发送邮件至1943759704@qq.com删除
码农资源网 » 使用 TypeScript 迁移 NestJS 微服务到 Go:一周的发现