Dubbo服务接入
说明
- 此篇文章是介绍
dubbo服务接入到Apache ShenYu网关,Apache ShenYu网关使用dubbo插件来接入Dubbo服务。 - 当前支持
alibaba dubbo(< 2.7.x)以及apache dubbo (>=2.7.x)。 - 接入前,请正确启动
shenyu-admin,并开启dubbo插件,在网关端和Dubbo服务端引入相关依赖。可以参考前面的 Dubbo快速开始。
应用客户端接入的相关配置请参考:客户端接入配置。
数据同步的相关配置请参考:数据同步配置。
在 网关中引入 dubbo 插件
-
在网关的
pom.xml文件中增加如下依赖:-
alibaba dubbo用户,dubbo版本换成你的,引入你需要的注册中心依赖,以下是参考。<!-- apache shenyu alibaba dubbo plugin start-->
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-spring-boot-starter-client-alibaba-dubbo</artifactId>
<version>${project.version}</version>
</dependency>
<!-- apache shenyu alibaba dubbo plugin end-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.6.5</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-client</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>4.0.1</version>
</dependency> -
apache dubbo用户,dubbo版本换成你的,引入你需要的注册中心依赖,如下是参考。<!-- apache shenyu apache dubbo plugin start-->
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-spring-boot-starter-client-apache-dubbo</artifactId>
<version>${project.version}</version>
</dependency>
<!-- apache shenyu apache dubbo plugin end-->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo</artifactId>
<version>2.7.5</version>
</dependency>
<!-- Dubbo Nacos registry dependency start -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-registry-nacos</artifactId>
<version>2.7.5</version>
</dependency>
<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
<version>1.1.4</version>
</dependency>
<!-- Dubbo Nacos registry dependency end-->
<!-- Dubbo zookeeper registry dependency start-->
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-client</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>4.0.1</version>
</dependency>
<!-- Dubbo zookeeper registry dependency end -->
-
-
重启网关服务。
dubbo 服务接入网关
- alibaba dubbo 用户
如果是springboot构建,引入以下依赖:
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-spring-boot-starter-client-alibaba-dubbo</artifactId>
<version>${shenyu.version}</version>
</dependency>
如果是spring构建,引入以下依赖:
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-client-alibaba-dubbo</artifactId>
<version>${shenyu.version}</version>
</dependency>
并在你的 bean 定义的 xml 文件中新增如下 :
<bean id="clientConfig" class="org.apache.shenyu.register.common.config.PropertiesConfig">
<property name="props">
<map>
<entry key="contextPath" value="/你的contextPath"/>
<entry key="appName" value="你 的名字"/>
</map>
</property>
</bean>
<bean id="shenyuRegisterCenterConfig" class="org.apache.shenyu.register.common.config.ShenyuRegisterCenterConfig">
<property name="registerType" value="http"/>
<property name="serverList" value="http://localhost:9095"/>
</bean>
<bean id="shenyuClientRegisterRepository" class="org.apache.shenyu.client.core.register.ShenyuClientRegisterRepositoryFactory" factory-method="newInstance">
<property name="shenyuRegisterCenterConfig" ref="shenyuRegisterCenterConfig"/>
</bean>
<bean id ="alibabaDubboServiceBeanListener" class ="org.apache.shenyu.client.alibaba.dubbo.AlibabaDubboServiceBeanListener">
<constructor-arg name="clientConfig" ref="clientConfig"/>
<constructor-arg name="shenyuClientRegisterRepository" ref="shenyuClientRegisterRepository"/>
</bean>
- apache dubbo 用户
如果是springboot构建,引入以下依赖:
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-spring-boot-starter-client-apache-dubbo</artifactId>
<version>${shenyu.version}</version>
</dependency>
需要在你的 客户端项目 定义的 application.yml 文件中新增如下:
dubbo:
registry:
address: dubbo注册中心地址
shenyu:
register:
registerType: shenyu服务注册类型 #http #zookeeper #etcd #nacos #consul
serverLists: shenyu服务注册地址 #http://localhost:9095 #localhost:2181 #http://localhost:2379 #localhost:8848
client:
dubbo:
props:
contextPath: /你的contextPath
appName: 你的应用名称
如果是spring构建,引入以下依赖:
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-client-apache-dubbo</artifactId>
<version>${shenyu.version}</version>
</dependency>
需要在你的 bean 定义的 xml 文件中新增如下 :
<bean id = "apacheDubboServiceBeanListener" class="org.apache.shenyu.client.apache.dubbo.ApacheDubboServiceBeanListener">
<constructor-arg ref="clientPropertiesConfig"/>
<constructor-arg ref="clientRegisterRepository"/>
</bean>
<!-- 根据实际的注册类型配置注册中心 -->
<bean id="shenyuRegisterCenterConfig" class="org.apache.shenyu.register.common.config.ShenyuRegisterCenterConfig">
<property name="registerType" value="你的服务注册类型"/>
<property name="serverLists" value="你的服务注册地址"/>
</bean>
<!-- 客户端属性配置 -->
<bean id="clientPropertiesConfig"
class="org.apache.shenyu.register.common.config.ShenyuClientConfig.ClientPropertiesConfig">
<property name="props">
<map>
<entry key="contextPath" value="/你的contextPath"/>
<entry key="appName" value="你的应用名字"/>
</map>
</property>
</bean>
<!-- 根据实际的注册类型配置客户端注册仓库 -->
<bean id="clientRegisterRepository" class="org.apache.shenyu.register.client.http.HttpClientRegisterRepository">
<constructor-arg ref="shenyuRegisterCenterConfig"/>
</bean>
<bean id="shenyuClientShutdownHook" class="org.apache.shenyu.client.core.shutdown.ShenyuClientShutdownHook">
<constructor-arg ref="shenyuRegisterCenterConfig"/>
<constructor-arg ref="clientRegisterRepository"/>
</bean>
需要在你的 客户端项目 定义的 application.yml 文件中新增如下:
dubbo:
registry:
address: dubbo注册中心地址
port: dubbo服务端口号
dubbo 插件设置
-
首先在
shenyu-admin插件管理中,把dubbo插件设置为开启。 -
其次在
dubbo插件中配置你的注册地址,或者其他注册中心的地址。
{"register":"zookeeper://localhost:2181"} or {"register":"nacos://localhost:8848"}
接口注册到网关
-
在
dubbo服务实现类的方法上加上@ShenyuDubboClient注解,表示该接口方法注册到网关。 -
启动你的提供者,成功启动后,进入后台管理系统的
插件列表 -> rpc proxy -> dubbo