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 小时前
ROS2 Jazzy:执行器
架构
null不是我干的4 小时前
微服务消息队列之RabbitMQ,深入了解
微服务·rabbitmq·java-rabbitmq
●VON4 小时前
重生之我在暑假学习微服务第七天《微服务之服务治理篇》
java·学习·微服务·云原生·nacos·架构·springcloud
贾全4 小时前
Transformer架构全解析:搭建AI的“神经网络大厦“
人工智能·神经网络·ai·语言模型·自然语言处理·架构·transformer
寅时码5 小时前
从“一键部署”到“可观测、可定制的发布流”:我如何打造一个企业级部署工具
运维·开源·node.js
这是个栗子5 小时前
【Node.js安装注意事项】-安装路径不能有空格
前端·npm·node.js
chancygcx_6 小时前
前端核心技术Node.js(二)——path模块、HTTP与模块化
前端·http·node.js
丘色果6 小时前
NPM打包时,报reason: getaddrinfo ENOTFOUND registry.nlark.com
前端·npm·node.js
潘锦6 小时前
架构师必备:解决技术问题当从第一性原理开始
架构·cto
kaliarch6 小时前
IaC 管控资源发生属性偏移修正方案
后端·架构·自动化运维