Nestjs微服务简单案例

相信大家,来看这篇博客,就应该知道微服务的概念。只是不太知道实用方法而已。下面我通过最简单的案例,来教会大家。

首先这是我的项目目录:

复制代码
nestwfw/
├── app/
├── project-microserices

app 是web服务,用来接收前端请求的网络请求

project-microserices 是一个微服务,名字都是随意的

安装

bash 复制代码
nest new app
nest new project-microservices

逻辑代码

1.首先编写微服务的代码,再去到web服务中去注册调用。所以我们先写project-microservices。

TypeScript 复制代码
// project-microservices/main.ts

import { NestFactory } from '@nestjs/core';
import { Transport, MicroserviceOptions } from '@nestjs/microservices';
import { AppModule } from './app.module';

async function bootstrap() {
  const app = await NestFactory.createMicroservice<MicroserviceOptions>(
    AppModule,
    {
      transport: Transport.TCP,
      options: {
        host: '127.0.0.1',
        port: 3001,
      }
    },
  );
  await app.listen();
}
bootstrap();
TypeScript 复制代码
// project-microservices/app.controller.ts

import { Controller, Get } from '@nestjs/common';
import { MessagePattern } from '@nestjs/microservices';
import { AppService } from './app.service';

@Controller()
export class AppController {
  constructor(private readonly appService: AppService) { }

  @MessagePattern('project:computedCount')
  computedCount(data: { num1: number, num2: number }): number {
    return this.appService.computedCount(data.num1, data.num2);
  }
}
TypeScript 复制代码
// project-microservices/app.service.ts
import { Injectable } from '@nestjs/common';

@Injectable()
export class AppService {
  computedCount(num1: number, num2: number): number {
    console.log('project被调用来了')
    return num1 + num2;
  }
}

修改完这三出,你的一个微服务就横空出世了,接下来再去web服务中去调用即可。

2.在web服务中注册并使用

注册微服务,需要去app.module.ts中进行注册。

TypeScript 复制代码
// app/app.module.ts

import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { ClientsModule, Transport } from '@nestjs/microservices';

@Module({
  imports: [
    ClientsModule.register([
      {
        name: 'PRODUCT_SERVICE',
        transport: Transport.TCP,
        options: {
          host: '127.0.0.1',
          port: 3001
        }
      }
    ])
  ],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule { }

注册完之后,可以去使用了。

TypeScript 复制代码
// app/app.controller.ts

import { Controller, Get, Inject, Query } from '@nestjs/common';
import { AppService } from './app.service';
import { ClientProxy } from '@nestjs/microservices';

@Controller()
export class AppController {
  constructor(private readonly appService: AppService,
    @Inject('PRODUCT_SERVICE') private client: ClientProxy
  ) { }
  @Get('/count')
  computeCount(@Query() query: { num1: number, num2: number }) {
    console.log(query)
    return this.client.send('project:computedCount', query)
  }
}

这样,就是一个最简单的微服务案例。如果大家还是有不懂可以自行百度或者留下评论。

相关推荐
CoLiuRs13 分钟前
异步任务使用场景与实践
微服务·性能优化·golang
zandy10112 小时前
HENGSHI SENSE异构过滤架构:基于三层执行引擎的跨源联邦查询性能优化实践
性能优化·架构·agentic bi·异构结构
许久'2 小时前
环境搭建node.js gnvm
node.js
brzhang2 小时前
我用 Flutter 做了个小游戏,结果发现这玩意有点意思
前端·后端·架构
用户6387994773052 小时前
我把我的 monorepo 迁移到 Bun,这是我的真实反馈
javascript·架构
brzhang2 小时前
用 Vue 写原生 iOS/Android 应用,我发现这个库比 uni 要轻量且靠谱些
前端·后端·架构
细节控菜鸡2 小时前
Webpack 核心知识点详解:proxy、热更新、Loader与Plugin全解析
前端·webpack·node.js
spmcor3 小时前
Nest.js 文件分片上传:当大文件来敲门,别慌,我们有“分尸”妙计!
node.js
Value_Think_Power3 小时前
golang struct 里组合interface 可以解决什么问题
架构
my91115263 小时前
地平线征程6芯片深度解析2:BPU 纳什架构如何重构智能驾驶计算范式
重构·架构