springboot整合dubbo(xml形式)[通俗易懂]

dubbo是一个远程服务调用的分布式框架。让我们告别了webservice的wsdl调用方式,取而代之的是服务注册和服务消费模式。下面对dubbo的组成做一个简单的解释,为的是读者能更好的理解下面的代码dubbo在结构上一共分为4个部分。1.provider:服务的提供者,将服务注册到Registry中,供外界调用。2.container:服务容器(加载dubbo配置文件,将配置文件…

大家好,又见面了,我是你们的朋友全栈君。

dubbo是一个远程服务调用的分布式框架。让我们告别了webservice的wsdl调用方式,取而代之的是服务注册和服务消费模式。下面对dubbo的组成做一个简单的解释,为的是读者能更好的理解下面的代码
dubbo在结构上一共分为4个部分。
1 .provider:服务的提供者,将服务注册到Registry中,供外界调用。
2 .container:服务容器 ( 加载dubbo配置文件,将配置文件中的服务部署运行 )
3 .registry:服务的注册中心(本篇使用zookeeper)
3 .consumer:服务的消费者,消费提供者注册的服务。
4 .monitor:统计中心(主要统计服务的调用次数和调用时间)

上述4部分之间的关系为:(原图引自:springboot整合dubbo)
在这里插入图片描述
关于dubbo的详细介绍可以查看 dubbo的详细解释。文章写的很好,想详细了解dubbo,可以阅读这篇帖子。

首先我们在相应的提供者工程中需要导入dubbo的依赖

<!--springboot和dubbo整合-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework</groupId>
                    <artifactId>spring</artifactId>
                </exclusion>
            </exclusions>
            <version>2.5.3</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.7</version>
            <exclusions>
                <exclusion>
                    <groupId>slf4j-log4j12</groupId>
                    <artifactId>org.slf4j</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--zookeeper原生API,经常会发生session expire异常。此依赖可以解决这个问题-->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>

引入依赖之后,开始写提供者代码。

定义一个bean

public class UserCredenceInfoVO implements Serializable {
   
    private String uciFlowno;
    private String uniqueid;
    private String loginName;
    private String credenceClass;
    private String credenceAppend;
    private String credenceStatus;
}

dubbo是靠接口发布服务,写一个测试接口,用来发布。

public interface UserCredenceReadService {
    public UserInfoVO findUserInfoByLoginName(UserCredenceInfoVO userCredenceInfoInfoVO);
}

接口对应的实现类为:

@Service
public class UserCredenceReadServiceImpl implements UserCredenceReadService {
    @Override
    public UserInfoVO findUserInfoByLoginName(UserCredenceInfoVO userCredenceInfoInfoVO) {
        try {
            UserInfoVO userInfoVO = new UserInfoVO();
            String loginName = userCredenceInfoInfoVO.getLoginName();
            System.out.println(loginName);
    }
}

上面的@Service注解是Spring的注解,不是dubbo的。

之后,我们开始写xml文件,注册服务。

<!-- 提供方应用信息,用于计算依赖关系 -->
    <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
                           http://www.springframework.org/schema/beans/spring-beans.xsd
                           http://code.alibabatech.com/schema/dubbo
                           http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    <!-- 提供方应用信息,用于计算依赖关系 -->
    <dubbo:application name="meteor-provider" />
    <dubbo:registry protocol="zookeeper" address="zookeeper://177.177.177.177:2182?backup=177.177.177.178:2182,177.177.177.179:2182" />
    <dubbo:protocol name="dubbo" port="20880" />
    <dubbo:service interface="cn.org.meteor.comp.service.userinfo.UserCredenceReadService" ref="userCredenceReadServiceImpl" version="1.0.0" />
</beans>

zk使用的是集群模式,如果是单机模式。zk地址写法为:

<dubbo:registry protocol="zookeeper" address="127.0.0.1:2181" client="zkclient" />

xml定义好之后,我们要在springboot的主类上扫描这个配置文件。

@EnableAutoConfiguration
@SpringBootApplication
@ComponentScan(basePackages = "cn.org.meteor.comp")
@ImportResource("classpath:dubbo-provider.xml")
public class Application {
    /**
     * 核心启动类
     * @param args
     */
    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
}

关于如何搭建一个简单的springboot工程,可以看我之前的博客
搭建一个简单的springboot版的ssm框架
上面的工作完成后,我们的提供者就定义好了。
然后通过dubbo控制台服务治理模块就可以看到我们注册的服务。
dubbo控制台查看服务的注册
dubbo的控制台,服务是一个dubbo-admin的war包。
如果需要下载这个war包,可以去这个博客,里面分享了一个地址可以下载。
dubbo-admin.war 下载

提供者搞定,下面我们开始写消费者,测试我们的提供者服务。

消费者消费服务,也需要接口支持,推荐的做法是将提供者的接口发布到nexus上。然后,消费者直接引用,很方便。

定义消费者xml文件

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
                           http://www.springframework.org/schema/beans/spring-beans.xsd
                           http://code.alibabatech.com/schema/dubbo
                           http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
    <!--应用名称,用于计算依赖关系-->
    <dubbo:application name="meteor-consumer"/>
    <!--注册中心地址-->
    <dubbo:registry protocol="zookeeper" address="zookeeper://177.177.177.177:2182?backup=177.177.177.178:2182,177.177.177.179:2182" />
    <dubbo:annotation package="cn.org.meteor.comp.service.userinfo" />
    <dubbo:reference interface="cn.org.meteor.comp.service.userinfo.UserCredenceReadService" id="userCredenceReadService" version="1.0.0" timeout="5000" />

</beans>

dubbo的超时时间默认为1000ms,这里定义为5000ms

在主类中扫描这个文件

@SpringBootApplication
@ImportResource("classpath:dubbo-consumer.xml")
public class Application {
    /**
     * 核心启动类
     * @param args
     */
    public static void main(String[] args) {
        SpringApplication.run(Application.class);
    }
}

然后写一个测试类,测试我们是否可以调通发布的服务

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = Application.class)
public class TestUserCredence {
    @Autowired
    UserCredenceReadService userCredenceReadService;

    @Test
    public void test_userCredence() {
        UserCredenceInfoVO userCredenceInfoVO = new UserCredenceInfoVO();
        userCredenceInfoVO.setLoginName("wyy");
 		userCredenceReadService.findUserInfoByLoginName(userCredenceInfoVO);
    }
}

执行test方法,然后查看服务提供端是否打印了我们设置的登录名。
如果有什么问题,欢迎留言。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/126777.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SQL分页查询_Sql根据某个字段分页

    SQL分页查询_Sql根据某个字段分页SQL分页查询:背景​ 在公司的系统中有一个平台是做配置管理的就是所谓的CRUD的平台,但是点击后进去到页面第一次看到的是一次查询的页面(点击页面自动的触发查询的功能)后面就可以你的CRUD的操作是给运营的同事来操作的,但是一般的是我们数据量比较的少的业务是之间查询出来所有的数据,直接返回给前端的让他自己做分页的,但是有一些数据量达到上万级别的时候,不能让他们乱搞了,…

    2022年4月19日
    136
  • document.all用法「建议收藏」

    document.all用法「建议收藏」document.all用法第一:document.all是页面内所有元素的一个集合。例如:document.all(0)表示页面内第一个元素第二:document.all可以判断浏览器是否

    2022年7月4日
    17
  • form表单提交的几种方法

    form表单提交的几种方法form表单提交的几种方法在form标签中添加Action(提交的地址)和method(post),且有一个submit按钮(<inputtype='submit'>)

    2022年7月3日
    21
  • tortoiseSVN汉化(简单飞机有汉化版吗)

    前言我们在进行项目的合作开发的时候一定无法离开一个公共平台,提供大家做项目的一个平台,目前使用较多的是SVN,它是一个开放源代码的版本控制系统。但是大家一定有遇到这样的问题,就是全英文界面(英语好的可以忽略),这个或多或少的让我们的工作效率降低了很多,特别是针对刚接触的小伙伴更是如此,本来就不熟悉,还全英文。下面我就来给大家一起来解决如何将全英文的SVN转化成中文版的SVN。处理前使用…

    2022年4月13日
    60
  • win10查看已连接的wifi密码的方法_WiFi密码

    win10查看已连接的wifi密码的方法_WiFi密码运行中输入CMD,回车,打开命令行窗口。输入:netshwlanshowprofiles执行后,会列出搜友已连接过的WiFi名字;输入:netshwlanshowprofiles&

    2022年8月3日
    3
  • golang 2021激活 3月最新注册码

    golang 2021激活 3月最新注册码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    94

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号