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

注册服务:

创建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.csdn.net/jeffli1993/article/details/71480627

猜你喜欢

转载自blog.csdn.net/cosisis/article/details/79268416