SpringBoot中如何使用Dubbo分布式服务-创新互联

SpringBoot中如何使用Dubbo分布式服务,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名注册、网页空间、营销软件、网站建设、开封网站维护、网站推广。

改造前

之前在 SpringBoot 中使用 Dubbox是这样的。先简单记录下版本,Dubbox-2.8.4、zkclient-0.6、zookeeper-3.4.6。

项目中引入 spring-context-dubbo.xml 配置文件如下:


    
    
    
    
    
    
    
    
    
    
         
    

启动类引入以下注解:

@SpringBootApplication@ImportResource({"classpath:spring-context-dubbo.xml"})public class Application{    private static final Logger logger = Logger.getLogger(Application.class);    public static void main(String[] args) throws InterruptedException,
            IOException {
        logger.info("支付项目启动 ");
    }
}

改造后

然而 SpringBoot 引入了新的概念 Spring Boot Starter,它有效的降低了项目开发过程的复杂程度,对于简化开发操作有着非常好的效果。

starter的理念

starter 会把所有用到的依赖都给包含进来,避免了开发者自己去引入依赖所带来的麻烦。

需要注意的是不同的 starter 是为了解决不同的依赖,所以它们内部的实现可能会有很大的差异,例如 jpa 的starter 和 Redis 的 starter 可能实现就不一样,这是因为 starter 的本质在于 synthesize,这是一层在逻辑层面的抽象,也许这种理念有点类似于 Docker,因为它们都是在做一个“包装”的操作,如果你知道 Docker 是为了解决什么问题的,也许你可以用 Docker 和 starter 做一个类比。

starter的实现

虽然不同的starter实现起来各有差异,但是他们基本上都会使用到两个相同的内容:ConfigurationProperties和AutoConfiguration。

因为Spring Boot坚信“约定大于配置”这一理念,所以我们使用ConfigurationProperties来保存我们的配置,并且这些配置都可以有一个默认值,即在我们没有主动覆写原始配置的情况下,默认值就会生效,这在很多情况下是非常有用的。

除此之外,starter的ConfigurationProperties还使得所有的配置属性被聚集到一个文件中(一般在resources目录下的application.properties),这样我们就告别了Spring项目中XML地狱。

starter的整体逻辑

SpringBoot中如何使用Dubbo分布式服务

强如Dubbo,当然也会创建属于自己的 starter 来迎合Spring Boot 的火热。

这里我们使用Dubbo比较新的版本,pom.xml 引入以下:


    com.alibaba
    dubbo
    2.6.2
    com.alibaba.spring.boot
    dubbo-spring-boot-starter
    2.0.0
    org.apache.curator
    curator-recipes
    4.0.1

application.properties 配置:

## dubbo springboot 配置spring.dubbo.application.id=springboot_pay
spring.dubbo.application.name=springboot_pay
spring.dubbo.registry.address=zookeeper://192.168.1.127:2181spring.dubbo.provider.threads=10spring.dubbo.provider.threadpool=fixedspring.dubbo.provider.loadbalance=roundrobin
spring.dubbo.server=truespring.dubbo.protocol.name=dubbo

启动类加入以下注解:

@EnableDubboConfiguration@SpringBootApplicationpublic class Application{    private static final Logger logger = Logger.getLogger(Application.class);    public static void main(String[] args) throws InterruptedException,
            IOException {
        logger.info("支付项目启动 ");
    }
}

相关暴露接口实现配置:

import org.springframework.stereotype.Component;import com.alibaba.dubbo.config.annotation.Service;@Service@Componentpublic class AliPayServiceImpl implements IAliPayService {      //省略代码}

关于SpringBoot中如何使用Dubbo分布式服务问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联-成都网站建设公司行业资讯频道了解更多相关知识。


分享标题:SpringBoot中如何使用Dubbo分布式服务-创新互联
本文URL:http://scyanting.com/article/csgisg.html