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

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

相关推荐
wapicn995 小时前
微服务架构下的数据核验设计,API接入最佳实践
微服务·云原生·架构
Ghost Face...5 小时前
龙芯2K1000 SoC启动全流程与架构解析
架构
侠客工坊6 小时前
移动端 RPA 的架构重构:基于侠客工坊多模态视觉大模型的自动化调度系统压测复盘
人工智能·智能手机·重构·架构·rpa·数字员工·侠客工坊
liang_jy7 小时前
Android 架构中的统一分发与策略路由
android·架构
hsjcjh7 小时前
深度技术拆解:2026年Gemini 3.1 Pro镜像官网架构与推理能力全面解析(附国内实测方案)
架构
若兰幽竹7 小时前
【从零开始编写数据库系统:架构设计与实现】第5章:查询执行引擎与火山模型
数据库·架构·数据库内核·toydb
逻辑诗篇7 小时前
破核拆解:PCIE719——基于Xilinx Zynq UltraScale+的高性能SAS扩展卡设计
fpga开发·架构
wenzhangli78 小时前
Ooder A2UI 核心架构深度解析:WEB 拦截层的设计与实现
前端·架构
福大大架构师每日一题8 小时前
openclaw v2026.4.24 发布:Google Meet 深度集成、DeepSeek V4 上线、浏览器自动化与插件架构全面升级
运维·架构·自动化·openclaw
身如柳絮随风扬8 小时前
深度解析 Elasticsearch 搜索服务:核心原理、架构与优化实践
大数据·elasticsearch·架构