
上周,我沉浸在 Go 的世界中,目的是将我们在 NestJS 中开发的微服务迁移到 TypeScript。这个旅程是一次激烈的练习,旨在忘记某些范式并采用其他范式,了解这两个开发生态系统之间的根本差异。
在 NestJS 堆栈中,我们管理连接到 PostgreSQL 和 Redis 数据库的微服务。我们在微服务之间实施各种通信策略:
DTO 验证和数据迁移在我们的系统中至关重要。 TypeScript 允许我们使用 Knex 和 TypeORM 定义严格的类型和结构来处理迁移。虽然有效,但这种方法需要深入了解该语言以及如何跨不同微服务操作数据流。
我们检测到事件循环影响性能的问题,我们使用 Clinic.js 库解决了这些问题。我们确定了瓶颈并优化了设计模式以及异步和等待的使用。然而,管理 Node.js 中的并发可能会很复杂,而且会占用大量资源。
在探索 Go 时,我们遇到了范式转变和一系列显着差异:
在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 为我们的微服务的未来提供的可能性感到兴奋。
我希望这个博客能为那些考虑类似转变的人提供指导和启发。您在技术迁移方面有哪些经验?一路走来你发现了哪些挑战和解决方案?
分享你的故事,让我们一起继续学习!
以上就是使用 TypeScript 迁移 NestJS 微服务到 Go:一周的发现的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号