dubbo直连模式

1:Spring mvc配置直连

(1)启动参数中添加

在JVM启动参数中加入-D参数映射服务地址,

-Ddubbo.properties.file=/home/aaa/conf/dubbo.properties

配置文件:dubbo.properties

这个文件放到自己相应的目录盘下,启动参数中就配置读那个目录下的这个文件,配置如下:

#=====是否注册到注册中心

dubbo.registry.register=false #不注册到注册中心

dubbo.reference.demoservice=dubbo://127.0.0.1:20880/com.local.services.DemoService # 配置提供者提供出来的service;

(2)Xml中指定

<!--demoService-->
<dubbo:reference id="demoService"  interface="com.local.demo.DemoService" timeout="65000" url="dubbo://127.0.0.1:28088/"/>

直连的优先级高于调注册中心的

Springboot 配置直连

1:在注解中直连注册中心

如:

@Reference(url = "dubbo://127.0.0.1:20880/")
private DemoService demoService;

这种一般是提供者是物理机或者是本地,如果服务器是docker容器,就会有请求不到的情况出现,因为容器中部署的服务重新启动以后,IP会变。

2:启动参数中添加

这个跟SpringMvc配置启动参数一样以外;有一点不一样就是把dubbo.properties 这个文件换成了dubbo-resolve.properties

配置中的配置项也有点区别:com.local.demo.DemoService=dubbo://localhost:20880

参考dubbo官方文档与源码 dubbo.properties这个文件换成了 dubbo-resolve.properties 这个文件,

在本地调式时:用-Ddubbo.resolve.file=/D:dubbo-resolve.properties 也可用这种方式:${user.home}/dubbo-resolve.properties文件,不需要配置 .测试环境也可以前的那种方式,容器的话,可在jekins上直接配置;

如果是windows 电脑; 放在D盘或者E盘下时,读的路径要前面要有/ 如:/D:dubbo-resolve.properties,dubbo就是这样规定的,也可以说是个bug;

注意:列举的这几种都是在本地调试或者在测试环境用,线上(生产)环境绝对禁用;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Dubbo直连模式的示例代码: 1. 在provider端配置服务 ```xml <!-- 配置服务 --> <dubbo:service interface="com.example.service.SomeService" ref="someServiceImpl" /> <!-- 直连地址 --> <dubbo:protocol name="dubbo" port="20880" /> ``` 2. 在consumer端配置直连地址 ```xml <!-- 直连地址 --> <dubbo:reference interface="com.example.service.SomeService" url="dubbo://127.0.0.1:20880" /> ``` 3. 在代码使用 ```java // 获取服务 SomeService someService = DubboReferencer.getReference(SomeService.class); // 调用服务 someService.doSomething(); ``` 其DubboReferencer是一个工具类,用于获取Dubbo服务的引用,示例代码如下: ```java public class DubboReferencer { /** * 获取Dubbo服务引用 * @param clazz 服务接口类 * @param <T> 服务接口泛型 * @return 服务引用 */ public static <T> T getReference(Class<T> clazz) { // 初始化Dubbo配置 ApplicationConfig applicationConfig = new ApplicationConfig(); applicationConfig.setName("consumer"); ReferenceConfig<T> referenceConfig = new ReferenceConfig<>(); referenceConfig.setApplication(applicationConfig); referenceConfig.setInterface(clazz); referenceConfig.setUrl("dubbo://127.0.0.1:20880"); referenceConfig.setRetries(0); return referenceConfig.get(); } } ``` 以上就是使用Dubbo直连模式的示例代码。需要注意的是,直连模式不支持负载均衡、容错等功能,适用于开发环境和调试场景。在生产环境,应该使用注册心来协调服务提供者和消费者之间的通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值