zoukankan      html  css  js  c++  java
  • Dubbo直连方式

    一、简介

    官网:http://dubbo.apache.org/zh-cn/

    Dubbo是 [1]  阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 [2]  Spring框架无缝集成。

    Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现

    二、Dubbo程序(直连式)

    业务接口名即服务名称。无论是服务提供者向服务注册中心注册服务,还是服务消费者从注册中心索取服务,都是通过接口名称进行注册与查找的。即,提供者与消费者都依赖于业务接口。所以,一般情况下,会将业务接口专门定义为一个工程,让提供者与消费者依赖

    三、创建业务接口工程00-api

    (1)创建业务接口工程00-api


     

    (2)创建业务接口

    (3) 修改pom文件

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <project xmlns="http://maven.apache.org/POM/4.0.0"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    5. <modelVersion>4.0.0</modelVersion>
    6. <groupId>00-api</groupId>
    7. <artifactId>00-api</artifactId>
    8. <version>1.0-SNAPSHOT</version>
    9. <properties>
    10. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    11. <maven.compiler.source>1.8</maven.compiler.source>
    12. <maven.compiler.target>1.8</maven.compiler.target>
    13. </properties>
    14. </project>

    四、创建提供者(自建Spring容器)00-api-provider

    (1)创建工程

    创建一个Maven的Java工程,并命名为00-api-provider

    (2) 在pom中导入依赖

    主要包含三类依赖:

    • 业务接口依赖
    • Dubbo依赖(2.7.0版本)
    • Spring依赖(4.3.16版本)
    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <project xmlns="http://maven.apache.org/POM/4.0.0"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    5. <modelVersion>4.0.0</modelVersion>
    6. <groupId>00-api-provider</groupId>
    7. <artifactId>00-api-provider</artifactId>
    8. <version>1.0-SNAPSHOT</version>
    9. <properties>
    10. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    11. <maven.compiler.source>1.8</maven.compiler.source>
    12. <maven.compiler.target>1.8</maven.compiler.target>
    13. <!-- 自定义版本号 -->
    14. <spring-version>4.3.16.RELEASE</spring-version>
    15. </properties>
    16. <dependencies>
    17. <!--业务接口工程依赖-->
    18. <dependency>
    19. <groupId>00-api</groupId>
    20. <artifactId>00-api</artifactId>
    21. <version>1.0-SNAPSHOT</version>
    22. </dependency>
    23. <!-- dubbo依赖 -->
    24. <dependency>
    25. <groupId>org.apache.dubbo</groupId>
    26. <artifactId>dubbo</artifactId>
    27. <version>2.7.2</version>
    28. </dependency>
    29. <!-- Spring依赖 -->
    30. <dependency>
    31. <groupId>org.springframework</groupId>
    32. <artifactId>spring-beans</artifactId>
    33. <version>${spring-version}</version>
    34. </dependency>
    35. <dependency>
    36. <groupId>org.springframework</groupId>
    37. <artifactId>spring-core</artifactId>
    38. <version>${spring-version}</version>
    39. </dependency>
    40. <dependency>
    41. <groupId>org.springframework</groupId>
    42. <artifactId>spring-context</artifactId>
    43. <version>${spring-version}</version>
    44. </dependency>
    45. <dependency>
    46. <groupId>org.springframework</groupId>
    47. <artifactId>spring-expression</artifactId>
    48. <version>${spring-version}</version>
    49. </dependency>
    50. <dependency>
    51. <groupId>org.springframework</groupId>
    52. <artifactId>spring-aop</artifactId>
    53. <version>${spring-version}</version>
    54. </dependency>
    55. <dependency>
    56. <groupId>org.springframework</groupId>
    57. <artifactId>spring-aspects</artifactId>
    58. <version>${spring-version}</version>
    59. </dependency>
    60. <dependency>
    61. <groupId>org.springframework</groupId>
    62. <artifactId>spring-tx</artifactId>
    63. <version>${spring-version}</version>
    64. </dependency>
    65. <dependency>
    66. <groupId>org.springframework</groupId>
    67. <artifactId>spring-jdbc</artifactId>
    68. <version>${spring-version}</version>
    69. </dependency>
    70. <!-- commons-logging依赖 -->
    71. <dependency>
    72. <groupId>commons-logging</groupId>
    73. <artifactId>commons-logging</artifactId>
    74. <version>1.2</version>
    75. </dependency>
    76. </dependencies>
    77. </project>

    (3) 定义接口实现类

    (4) 定义spring-provider配置文件

    在src/main/resources下定义spring-provider.xml配置文件

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
    4. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
    5. <!--指定当前工程在管控平台中的名称-->
    6. <dubbo:application name="01-provider"/>
    7. <!--指定注册中心:不使用注册中心-->
    8. <dubbo:registry address="N/A"/>
    9. <!--注册业务接口实现类,它是真正的服务提供者-->
    10. <bean id="someService" class="com.dubbo.provider.SomeServiceImpl"/>
    11. <!--服务暴露-->
    12. <dubbo:service interface="com.dubbo.provider.SomeService" ref="someService"/>
    13. </beans>

    (5) 定义测试类

    在/src/test/java中创建测试类RunProvider

    五、创建提供者(Main启动) 01-api-provider

    使用自建Spring容器方式是比较浪费资源的。容器的作用仅仅就是创建一个单例的提供者对象,其本身并不需要 Tomcat 或 JBoss 等 Web 容器的功能。如果硬要用 Web 容器去加载服务提供方,就增加了代码的复杂性,也浪费了资源。
    Dubbo提供了一个Main.main()方法可以直接创建并启动Provider,其底层仅仅是加载了一个简单的用于暴露服务的Spring容器。该方式要求Spring配置文件必须要放到类路径下的META-INF/spring目录中,Spring配置文件名称无所谓

    (1)工程创建

    复制00-api-provider工程,并修改其工程名01-api-provider

    (2) 创建目录并移动配置文件

    在resources目录中创建META-INF/spring目录,并将spring-provider.xml配置文件拖入其中

    (3) 修改启动类

    六、创建消费者01-consumer

    (1) 创建工程

    创建一个Maven的Java工程,并命名为01-consumer

    (2) 在pom中导入依赖

    该工程的依赖与Provider中的完全相同,直接复制来就可以
    (3) 定义spring-consumer配置文件

    (4) 定义消费者类

    七、效果

    (1)启动提供者

    (2)消费者消费

  • 相关阅读:
    Neo4j图形数据库备份
    Linux中Tomcat 自动设置CATALINA_HOME方法
    VNC viewer 无法打开oracle 11g图形界面方案
    CYPHER 语句(Neo4j)
    Tomcat部署时war和war exploded区别
    java中不能使用小数点(.)来作为分隔符
    做一个完整的Java Web项目需要掌握的技能
    从零讲Java,给你一条清晰地学习道路!该学什么就学什么!
    MYSQL数据库表排序规则不一致导致联表查询,索引不起作用问题
    chrome浏览器的跨域设置——包括版本49前后两种设置
  • 原文地址:https://www.cnblogs.com/edda/p/13259639.html
Copyright © 2011-2022 走看看