注册服务:
创建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
io.dubbo.springboot
spring-boot-starter-dubbo
1.0.0
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中引入
io.dubbo.springboot
spring-boot-starter-dubbo
1.0.0
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, 其他都和上面一致
com.alibaba
dubbo
2.8.3
参考文章: http://blog.csdn.net/jeffli1993/article/details/71480627