dubbo本地直连方式1-代码配置注解方式

这种适合本地调试,比如说你让你本地的consumer直接连你本地的provider

查看ip地址

C:UsersAdministrator>ipconfig

Windows IP 配置


以太网适配器 以太网:

   媒体状态  . . . . . . . . . . . . : 媒体已断开连接
   连接特定的 DNS 后缀 . . . . . . . :

无线局域网适配器 本地连接* 1:

   媒体状态  . . . . . . . . . . . . : 媒体已断开连接
   连接特定的 DNS 后缀 . . . . . . . :

无线局域网适配器 本地连接* 2:

   媒体状态  . . . . . . . . . . . . : 媒体已断开连接
   连接特定的 DNS 后缀 . . . . . . . :

以太网适配器 VMware Network Adapter VMnet8:

   连接特定的 DNS 后缀 . . . . . . . :
   本地链接 IPv6 地址. . . . . . . . : fe80::e997:a63e:622c:987a%3
   IPv4 地址 . . . . . . . . . . . . : 172.16.10.1
   子网掩码  . . . . . . . . . . . . : 255.255.255.0
   默认网关. . . . . . . . . . . . . : 172.16.10.2

无线局域网适配器 WLAN:

   连接特定的 DNS 后缀 . . . . . . . :
   本地链接 IPv6 地址. . . . . . . . : fe80::f43e:1970:3cf2:3bda%7
   IPv4 地址 . . . . . . . . . . . . : 10.10.87.80
   子网掩码  . . . . . . . . . . . . : 255.255.255.0
   默认网关. . . . . . . . . . . . . : 10.10.87.254

发现ip地址是 10.10.87.80

配置hosts

image.png

本机名字叫root,所以配置hosts

key是 你本机的名字,我本机是root, value就是你本机的ip地址,我的是10.10.87.80 ,不知道的看上面步骤自己用ipconfig 看下自己的 IPv4 地址

root 10.10.87.80

provider配置文件配置

注意dubbo.protocol.host 的配置是你本机配置

dubbo.protocol.name=dubbo
dubbo.protocol.port=20880
# 暴露服务的ip地址
dubbo.protocol.host=10.10.87.80

consumer配置文件配置

注意配置10.10.87.80是本机ip地址

dubbo:
  provider:
    host: 10.10.87.80

服务接口配置

注意url写成provider的 dubbo.protocol.host 配置和dubbo.protocol.port

10.10.87.80 要和provider的 dubbo.protocol.host配置一致
20880要和dubbo.protocol.host配置一致

    @Reference(protocol = "dubbo", url = "dubbo://10.10.87.80:20880",  version = "default")
    private DemoService demoService;

测试

先启动生产者后启动消费者

代码地址

https://gitee.com/zjj19941/ZJJ_Dubbo.git 下的 local-direct-connection-1 项目

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值