Brpc服务接入

此篇文介绍如何将 Brpc 服务接入到 Apache ShenYu 网关,Apache ShenYu 网关使用 Brpc 插件来接入Brpc服务。

接入前,请正确启动 shenyu-admin,并开启Brpc插件,在网关端和Brpc服务端引入相关依赖。可以参考前面的 Brpc快速开始

应用客户端接入的相关配置请参考:客户端接入配置

数据同步的相关配置请参考:数据同步配置

在网关中引入 Brpc 插件

引入网关对Brpc的代理插件,在网关的 pom.xml 文件中增加如下依赖:

  1. <!-- apache shenyu brpc plugin -->
  2. <dependency>
  3. <groupId>org.apache.shenyu</groupId>
  4. <artifactId>shenyu-spring-boot-starter-plugin-brpc</artifactId>
  5. <version>${project.version}</version>
  6. </dependency>
  • 重启你的网关服务。

Brpc服务接入网关

可以参考: shenyu-examples-brpc

  1. 在由Brpc构建的微服务中,引入如下依赖:
  1. <dependency>
  2. <groupId>org.apache.shenyu</groupId>
  3. <artifactId>shenyu-spring-boot-starter-client-brpc</artifactId>
  4. <version>${shenyu.version}</version>
  5. </dependency>
  1. application.yaml 配置文件增加如下配置:
  1. server:
  2. port: 8011
  3. address: 0.0.0.0
  4. servlet:
  5. context-path: /
  6. spring:
  7. main:
  8. allow-bean-definition-overriding: true
  9. application:
  10. name: brpc-exmaples
  11. shenyu:
  12. register:
  13. registerType: http #zookeeper #etcd #nacos #consul
  14. serverLists: http://localhost:9095 #localhost:2181 #http://localhost:2379 #localhost:8848
  15. props:
  16. username: admin
  17. password: 123456
  18. client:
  19. brpc:
  20. props:
  21. contextPath: /brpc
  22. ipAndPort: brpc
  23. appName: brpc
  24. port: ${starlight.server.port}
  25. # starlight
  26. starlight:
  27. server:
  28. enable: true
  29. port: 8005
  1. Brpc服务接口实现类的方法上加上注解@ShenyuBrpcClient,启动你的服务提供者,成功注册后,在后台管理系统进入插件列表 -> rpc proxy -> brpc,会看到自动注册的选择器和规则信息。

示例:

  1. @ShenyuBrpcService
  2. public class BrpcDemoServiceImpl implements BrpcDemoService {
  3. @Override
  4. @ShenyuBrpcClient("/connect")
  5. public void connect() {
  6. LOG.info("Connect Success");
  7. }
  8. }

用户请求

可以通过 http 的方式来请求你的Brpc服务。Apache ShenYu网关需要有一个路由前缀,这个路由前缀就是接入网关配置的 contextPath。比如: http://localhost:9195/brpc/connect