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)
  }
}

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

相关推荐
小马爱打代码1 小时前
Spring Boot 3.4 :@Fallback 注解 - 让微服务容错更简单
spring boot·后端·微服务
小庞在加油1 小时前
Apollo源码架构解析---附C++代码设计示例
开发语言·c++·架构·自动驾驶·apollo
森焱森1 小时前
60 美元玩转 Li-Fi —— 开源 OpenVLC 平台入门(附 BeagleBone Black 驱动简单解析)
c语言·单片机·算法·架构·开源
前端付豪3 小时前
13、表格系统架构:列配置、嵌套数据、复杂交互
前端·javascript·架构
JustHappy3 小时前
SPA?MPA?有啥关系?有啥区别?聊一聊页面形态 or 路由模式
前端·javascript·架构
年纪轻轻就扛不住3 小时前
Express 入门指南(超详细教程)
前端·前端框架·node.js·express·js
阿里云云原生4 小时前
微服务引擎 MSE 及云原生 API 网关 2025 年 6 月产品动态
微服务·云原生·架构
HeXDev4 小时前
【SkyWalking】服务端部署与微服务无侵入接入实战指南
java·微服务·架构·skywalking·链路追踪·微服务治理
亿牛云爬虫专家4 小时前
微服务化采集平台:可扩展性与容错机制
python·微服务·架构·爬虫代理·扩展性·新浪财经·财经新闻
CSJ200203144 小时前
LUMP+NFS架构的Discuz论坛部署
运维·架构