本文介绍: 基于 Dubbo3 定义的 Triple 协议,你可以轻松编写浏览器移动端、gRPC 兼容的 RPC 服务,并让这些服务同时运行在 HTTP/1 和 HTTP/2 上。Dubbo Node.js SDK 支持使用 IDL 或编程语言特有的方式定义服务,并提供一套轻量的 API 来发布调用这些服务

关于Apache Dubbo3

Apache Dubbo 是一款易用、高性能的 WEB 和 RPC 框架,同时为构建企业级服务提供服务发现流量治理、可观测、认证鉴权等能力工具与最佳实践。经过近几年发展,Dubbo3 已在阿里巴巴集团各条业务线实现全面推广,成功取代运行多年的 HSF 框架,同时 Dubbo3 的多语言体系也有了快速发展,目前涵盖的多语言体系

基于 Dubbo3 定义的 Triple 协议,你可以轻松编写浏览器、移动端、gRPC 兼容的 RPC 服务,并让这些服务同时运行在 HTTP/1 和 HTTP/2 上。Dubbo Node.js SDK 支持使用 IDL 或编程语言特有的方式定义服务,并提供一套轻量的 API 来发布调用这些服务。

关于 Dubbo3 Node.js 首个发布版

Dubbo-js 项目于 9 月份刚刚发布了支持 Dubbo3 协议的首个 alpha 版本,该项目是 Dubbo3 的 Typescript 版本实现,提供了 Web、Node.js 两种发布包。其中,Web 框架能让开发者直接浏览器页面访问后端服务,Node.js 则进一步丰富了后端微服务技术栈的选择当前 Node.js 版本主要是实现了 Triple 协议完整支持接下来的版本中,社区将继续完善地址发现负载均衡等服务治理能力

Node.js 微服务开发完整示例

示例基于最新发布的 Node.js 版本,演示基于 Triple 协议的 RPC 通信模式示例使用 Protocol Buffer 定义 RPC 服务,并演示代码生成、服务发布和服务访问过程

前置条件

因为使用 Protocol Buffer原因我们首先需要安装相关代码生成工具,这包括 @bufbuild/protocgen-es、@bufbuild/protobuf、@apachedubbo/protocgen-apachedubboes、@apachedubbo/dubbo

npm install @bufbuild/protoc-gen-es @bufbuild/protobuf @apachedubbo/protoc-gen-apache-dubbo-es @apachedubbo/dubbo

定义服务

现在,使用 Protocol Buffer (IDL) 来定义一个 Dubbo 服务。

创建目录,并生成文件

mkdir -p proto && touch proto/example.proto

写入内容

syntax = "proto3";

package apache.dubbo.demo.example.v1;

message SayRequest {
  string sentence = 1;
}

message SayResponse {
  string sentence = 1;
}

service ExampleService {
  rpc Say(SayRequest) returns (SayResponse) {}
}

这个文件声明一个叫做 ExampleService 的服务,为这个服务定义了 Say 方法以及它的请求参数 SayRequest 和返回值 SayResponse。

生成代码

创建 gen 目录,做为生成文件放置目标目录

mkdir -p gen

运行以下命令,在 gen 目录生成代码文件

PATH=$PATH:$(pwd)/node_modules/.bin 
  protoc -I proto 
  --es_out gen 
  --es_opt target=ts 
  --apache-dubbo-es_out gen 
  --apache-dubbo-es_opt target=ts 
  example.proto

运行命令后,应该可以在目标目录中看到以下生成文件:

├── gen
│   ├── example_dubbo.ts
│   └── example_pb.ts
├── proto
│   └── example.proto

实现服务

接下来我们需要添加业务逻辑了,实现 ExampleService ,并将其注册到 DubboRouter 中。

创建 dubbo.ts 文件

import { DubboRouter } from "@apachedubbo/dubbo";
import { ExampleService } from "./gen/example_dubbo";

export default (router: DubboRouter) =>
  // registers apache.dubbo.demo.example.v1
  router.service(ExampleService, {
    // implements rpc Say
    async say(req) {
      return {
        sentence: `You said: ${req.sentence}`,
      };
    },
  }, { serviceGroup: 'dubbo', serviceVersion: '1.0.0' });

启动 Server

Dubbo 服务可以嵌入到普通的 Node.js 服务器、Next.js、Express 或 Fastify 中。在这里我们使用 Fastify,所以让我们安装 Fastify 以及我们为 Fastify 准备插件

npm install fastify @apachedubbo/dubbo-fastify

创建 server.ts 文件新建一个 Server,把上一步实现的 ExampleService 注册给它。

接下来可以直接初始化启动 Server 了,它将在指定端口接收请求

import { fastify } from "fastify";
import { fastifyDubboPlugin } from "@apachedubbo/dubbo-fastify";
import routes from "./dubbo";

async function main() {
  const server = fastify();
  await server.register(fastifyDubboPlugin, {
    routes,
  });
  server.get("/", (_, reply) => {
    reply.type("text/plain");
    reply.send("Hello World!");
  });
  await server.listen({ host: "localhost", port: 8080 });
  console.log("server is listening at", server.addresses());
}

void main();

最后,运行代码启动服务。

npx tsx server.ts

访问服务

简单的方式是使用 HTTP/1.1 POST 请求访问服务,参数则作以标准 JSON 格式作为 HTTP 负载传递如下使用 cURL 命令的访问示例:

curl 
 --header 'Content-Type: application/json' 
 --header 'TRI-Service-Version: 1.0.0' 
 --header 'TRI-Service-group: dubbo' 
 --data '{"sentence": "Hello World"}' 
 http://localhost:8080/apache.dubbo.demo.example.v1.ExampleService/Say

也可以使用标准的 Dubbo client 请求服务,我们首先需要从生成代码即 dubbo-node 包中获取服务代理,为它指定 server 地址并初始化,之后就可以发起起 RPC 调用了。

创建 client.ts 文件

import { createPromiseClient } from "@apachedubbo/dubbo";
import { ExampleService } from "./gen/example_dubbo";
import { createDubboTransport } from "@apachedubbo/dubbo-node";

const transport = createDubboTransport({
  baseUrl: "http://localhost:8080",
  httpVersion: "1.1",
});

async function main() {
  const client = createPromiseClient(ExampleService, transport, { serviceVersion: '1.0.0', serviceGroup: 'dubbo' });
  const res = await client.say({ sentence: "Hello World" });
  console.log(res);
}
void main();

运行客户端

npx tsx client.ts

总结

当前 Node.js 版本主要是实现了 Triple 协议完整支持,接下来的版本中,社区将继续完善地址发现负载均衡等服务治理能力

相关链接

[1] apache/dubbo

https://github.com/apache/dubbo

[2] apache/dubbo-go

https://github.com/apache/dubbo-go

[3] apache/dubbo-js

https://github.com/apache/dubbo-js

[4] apache/dubbo-rust

https://github.com/apache/dubbo-rust

作者:蔡建怿

点击立即免费试用云产品 开启云上实践之旅!

原文链接

本文阿里云原创内容,未经允许不得转载。

原文地址:https://blog.csdn.net/yunqiinsight/article/details/133353658

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_36428.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注