• 在线客服

  • 扫描二维码
    下载博学谷APP

  • 扫描二维码
    关注博学谷微信公众号

  • 意见反馈

原创 Dubbo实现调用步骤分析

发布时间:2020-05-12 09:48:07 浏览 3547 来源:博学谷 作者:照照

    Dubbo作为一个RPC框架,其最核心的功能就是要实现跨网络的远程调用。本文将要创建一个应用,即作为服务的提供方,通过Dubbo来实现服务消费方远程调用服务提供方的方法。下面一起来看服务提供方开发的步骤吧~

     

     Dubbo实现调用

     

    1、创建maven工程(打包方式为wardubbodemo_provider,在pom.xml文件中导入如下坐标

     

    ~~~xml

    <properties>

      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

      <maven.compiler.source>1.8</maven.compiler.source>

      <maven.compiler.target>1.8</maven.compiler.target>

      <spring.version>5.0.5.RELEASE</spring.version>

    </properties>

    <dependencies>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-context</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-beans</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-webmvc</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-jdbc</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-aspects</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-jms</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-context-support</artifactId>

        <version>${spring.version}</version>

      </dependency>

      <!-- dubbo相关 -->

      <dependency>

        <groupId>com.alibaba</groupId>

        <artifactId>dubbo</artifactId>

        <version>2.6.0</version>

      </dependency>

      <dependency>

        <groupId>org.apache.zookeeper</groupId>

        <artifactId>zookeeper</artifactId>

        <version>3.4.7</version>

      </dependency>

      <dependency>

        <groupId>com.github.sgroschupf</groupId>

        <artifactId>zkclient</artifactId>

        <version>0.1</version>

      </dependency>

      <dependency>

        <groupId>javassist</groupId>

        <artifactId>javassist</artifactId>

        <version>3.12.1.GA</version>

      </dependency>

      <dependency>

        <groupId>com.alibaba</groupId>

        <artifactId>fastjson</artifactId>

        <version>1.2.47</version>

      </dependency>

    </dependencies>

    <build>

      <plugins>

        <plugin>

          <groupId>org.apache.maven.plugins</groupId>

          <artifactId>maven-compiler-plugin</artifactId>

          <version>2.3.2</version>

          <configuration>

            <source>1.8</source>

            <target>1.8</target>

          </configuration>

        </plugin>

        <plugin>

          <groupId>org.apache.tomcat.maven</groupId>

          <artifactId>tomcat7-maven-plugin</artifactId>

          <configuration>

            <!-- 指定端口 -->

            <port>8081</port>

            <!-- 请求路径 -->

            <path>/</path>

          </configuration>

        </plugin>

      </plugins>

    </build>

    ~~~

     

    2、配置web.xml文件

     

    ~~~xml

    <!DOCTYPE web-app PUBLIC

     "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"

     "http://java.sun.com/dtd/web-app_2_3.dtd" >

    <web-app>

      <display-name>Archetype Created Web Application</display-name>

      <context-param>

        <param-name>contextConfigLocation</param-name>

        <param-value>classpath:applicationContext*.xml</param-value>

      </context-param>

      <listener>

        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

      </listener>

    </web-app>

     

    ~~~

     

    3、创建服务接口

     

    ~~~java

    package com.itheima.service;

    public interface HelloService {

        public String sayHello(String name);

    }

    ~~~

     

    4、创建服务实现类

     

    ~~~java

    package com.itheima.service.impl;

    import com.alibaba.dubbo.config.annotation.Service;

    import com.itheima.service.HelloService;

     

    @Service

    public class HelloServiceImpl implements HelloService {

        public String sayHello(String name) {

            return "hello " + name;

        }

    }

    ~~~

     

    注意:服务实现类上使用的Service注解是Dubbo提供的,用于对外发布服务

     

    5、在src/main/resources下创建applicationContext-service.xml

     

    ~~~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:p="http://www.springframework.org/schema/p"

                       xmlns:context="http://www.springframework.org/schema/context"

                       xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"

                 xmlns:mvc="http://www.springframework.org/schema/mvc"

                       xsi:schemaLocation="http://www.springframework.org/schema/beans

                       http://www.springframework.org/schema/beans/spring-beans.xsd

             http://www.springframework.org/schema/mvc

             http://www.springframework.org/schema/mvc/spring-mvc.xsd

             http://code.alibabatech.com/schema/dubbo

             http://code.alibabatech.com/schema/dubbo/dubbo.xsd

             http://www.springframework.org/schema/context

             http://www.springframework.org/schema/context/spring-context.xsd">

             <!-- 当前应用名称,用于注册中心计算应用间依赖关系,注意:消费者和提供者应用名不要一样 -->

             <dubbo:application name="dubbodemo_provider" />

             <!-- 连接服务注册中心zookeeper ipzookeeper所在服务器的ip地址-->

             <dubbo:registry address="zookeeper://192.168.134.129:2181"/>

             <!-- 注册  协议和port   端口默认是20880 -->

             <dubbo:protocol name="dubbo" port="20881"></dubbo:protocol>

             <!-- 扫描指定包,加入@Service注解的类会被发布为服务  -->

             <dubbo:annotation package="com.itheima.service.impl" />

    </beans>

    ~~~

     

    6、启动服务

     

    tomcat7:run

     

    以上就是Dubbo实现调用的步骤分析,大家都看懂了吗?如果对这一章还有什么疑问,可以在下方申请试学名额,报名学习在线视频课程,还有在线老师对你提供一对一指导的帮助~

    申请免费试学名额    

在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!

上一篇: 认识Dubbo基础学习笔记 下一篇: 自学Java好还是去培训Java好?

相关推荐 更多

热门文章

  • 前端是什么
  • 前端开发的工作职责
  • 前端开发需要会什么?先掌握这三大核心关键技术
  • 前端开发的工作方向有哪些?
  • 简历加分-4步写出HR想要的简历
  • 程序员如何突击面试?两大招带你拿下面试官
  • 程序员面试技巧
  • 架构师的厉害之处竟然是这……
  • 架构师书籍推荐
  • 懂了这些,才能成为架构师
  • 查看更多

扫描二维码,了解更多信息

博学谷二维码