SpringBoot下集成Dubbo/Dubbox, 无XML, 无自定义config, 支持特定group

本文详细介绍如何使用Dubbo进行服务注册与消费的过程,包括创建接口和服务实现、配置pom依赖及application属性,并通过示例展示了如何在消费者端调用服务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注册服务:

创建Interface和实现类

public interface DubboProvider {

    String testDubbo(String arg);
}


服务注册在test group下, 版本是1.0, 注意注解service要引用com.alibaba.dubbo.config.annotation下的注解

@Service(group="test", version = "1.0")
public class DubboProviderImpl implements DubboProvider {
    @Override
    public String testDubbo(String arg) {
        return "test dubbo, " + arg;
    }
}

pom文件中的引用增加dubbo

<dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
</dependency>

application.properties文件中的配置, zookeeper路径改成你自己的注册中心地址

server.port=8081

spring.dubbo.application.name=my_provider
spring.dubbo.registry.address=zookeeper://10.16.4.30:2181
spring.dubbo.protocol.port=20880
#发布服务的类包路径
spring.dubbo.scan=com.example.test


============ �服务端开发完毕, 启动即可� =========


消费服务:

在消费服务应用中新建一个interface, 注意包名和类名和provider的interface保持一致, 可以把provider中的interface拷贝过来, 也可写一个api打成jar包在consumer中引用(推荐)

public interface DubboProvider {

    String testDubbo(String arg);
}

pom.xml中引入

<dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
</dependency>

application.properties文件中的配置, 注意修改address地址

server.port=8088

spring.dubbo.application.name=consumer
# 单注册地址配置
spring.dubbo.registry.address=zookeeper://10.141.4.39:2181
# 多注册中心地址配置
#spring.dubbo.application.registries[0].address=zookeeper://10.141.4.39:2181
#spring.dubbo.application.registries[0].address=zookeeper://10.141.4.38:2181
#spring.dubbo.application.registries[0].address=zookeeper://10.141.4.37:2181


# 调用dubbo的类所在包路径,最好写到顶层
spring.dubbo.scan=com.example.test

写一个测试用例调用服务, 注意reference调用com.alibaba.dubbo.config.annotationz下的注解

@Slf4j
@RunWith(SpringRunner.class)
@SpringBootTest(classes = MyConsumerApplication.class)
public class MyConsumerApplicationTests {

      @Reference(group="test", version = "1.0")
	public DubboProvider dubboProvider;

	@Test
	public void testDubbo() {
            log.info(" >>>>>>>   " + dubboProvider.testDubbo("hello") + "  <<<<<<<<<<<");
        }
}

=================== 消费服务开发完毕, 启动测试用例, 结果如下 ====================

集成DUBBOX

dubbox和dubbo的使用方式是一致的, 只是dubbox中的dubbo版本是2.8.3(具体版本需要看你用的dubbox版本), 总之就是消费者和提供者dubbo版本需要保持一致, 如果按照上面这种引入spring-boot-starter-dubbo的方式, dubbo版本最高只到2.5.x,因此pom文件需要做一些改变

在消费者/提供者pom中加入, 强制使用2.8.3的dubbo, 其他都和上面一致

     <dependencyManagement>
		<dependencies>
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>dubbo</artifactId>
			<version>2.8.3</version>
		</dependency>
		</dependencies>
	</dependencyManagement>

参考文章: http://blog.youkuaiyun.com/jeffli1993/article/details/71480627

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值