dubbo、zookeeper和spring整合

xiaoxiao2021-02-28  41

一  zookeeper下载和操作

    1 下载zookeeper

       下载地址 https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/ 

        将下载的源码包上传到linux机器上(我的在/usr/local/zookeeper/目录下),并解压

        解压的根目录的conf文件夹下有一个zoo_sample.cfg

        使用命令:cp zoo_sample.cfg  zoo.cfg  复制一份 在启动的时候会加载配置文件

    2 操作zookeeper

${zookeeper path}/bin/zkServer.sh start            进入bin目录 执行服务脚本 默认监听2181端口 ${zookeeper path}/bin/zkServer.sh stop

二  项目搭建

       

  1  创建maven工程   下面创建4个模块

    api: 里面写服务接口

    service: 写api里面接口的实现类

    provider: 服务提供者  暴露服务  接收消费者的请求之后  调用实现类返回数据

    customer: 服务消费者  调用provider暴露的服务

    这里面provider和customer要发送接收请求,所以使用工程

    api和service里面只有一些类,使用工程就行了

  2  在api里面写一个接口

public interface TestRPC {     public Map<String,String> test(); }

  3  在service里 写实现类

     首先 在service的pom文件加入api模块的依赖

public class TestRPCimpl implements TestRPC {     public Map<String, String> test(){         System.out.println("hello world");         Map<String, String> map = new HashMap<String, String>();         map.put("hello", "dubbo");         map.put("hello", "zookeeper");         return map;     } }

  4  provider服务提供者

    4.1 pom文件加入这些依赖后   再加入service模块的依赖

<properties>     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>     <org.springframework.version>4.3.12.RELEASE</org.springframework.version>     <jackson.version>2.9.3</jackson.version> </properties> <dependencies> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${org.springframework.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>${org.springframework.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${org.springframework.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${org.springframework.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${org.springframework.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>${jackson.version}</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>dubbo</artifactId> <version>2.5.3</version> <exclusions> <exclusion> <artifactId>spring</artifactId> <groupId>org.springframework</groupId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.8</version> <exclusions> <exclusion> <groupId>log4j</groupId> <artifactId>log4j</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.16</version> </dependency> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> </dependency> </dependencies>

    4.2  spring配置文件applicationContext.xml(这里面 配置dubbo 暴露服务) 

<?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:dubbo="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"> <!-- 用于配置当前应用信息,不管该应用是提供者还是消费者 --> <dubbo:application name="test_provider" /> <!-- 使用zookeeper注册中心暴露服务地址 ip为第一步启动zookeeper的linux机器ip 默认端口2181 --> <dubbo:registry address="zookeeper://192.168.0.202:2181" /> <!-- 协议配置,用于配置提供服务的协议信息 --> <dubbo:protocol name="dubbo" port="20880"/> <!-- 声明需要暴露的服务接口 --> <dubbo:service interface="org.dubbo_zk.api.TestRPC" ref="testRpc" /> <!-- 具体的实现bean --> <bean id="testRpc" class="org.dubbo_zk.service.TestRPCimpl" /> </beans>

 4.3 spring-mvc.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:context="http://www.springframework.org/schema/context" xmlns:task="http://www.springframework.org/schema/task" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd" default-lazy-init="false"> <mvc:annotation-driven> <!-- 消息转换器 --> <mvc:message-converters register-defaults="true"> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="supportedMediaTypes" value="text/html;charset=UTF-8" /> </bean> </mvc:message-converters> </mvc:annotation-driven> <!-- 静态资源 --> <mvc:resources mapping="/resources/**" location="/resources/" /> <!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/plain;charset=UTF-8</value> </list> </property> </bean> </list> </property> </bean> </beans>

 4.4  web.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>dubbo_zk-provider</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> <servlet> <servlet-name>dubbo_provider_Servlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath*:spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dubbo_provider_Servlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>

5  customer消费者

   5.1  pom文件

    加入4.1中的依赖后  加入api模块的依赖

    5.2  applicationContex.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:dubbo="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">     <!-- 提供方应用信息,用于计算依赖关系 --> <dubbo:application name="test_consumer" /> <!-- 使用zookeeper注册中心暴露服务地址 ip为第一步启动zookeeper的linux机器ip 默认端口2181 --> <dubbo:registry address="zookeeper://192.168.0.202:2181" /> <!-- 声明需要暴露的服务接口 --> <dubbo:reference interface="org.dubbo_zk.api.TestRPC" id="testRpc" check="false" /> </beans>

    5.3  spring-mvc.xml文件

    和4.3的一样

    5.4  web.xml文件

    和4.4的一样

    5.5  写controller类  远程调用服务

@Controller public class TestRPCustomer { @Resource private TestRPC testRPC; @RequestMapping("/test") public @ResponseBody Map<String,String> test(){ Map<String,String> map = testRPC.test(); Set<String> set = map.keySet(); for(String s:set) { System.out.println(s+":"+map.get(s)); } return testRPC.test(); } }

这个时候整个项目搭建完成了  

可以下载看一下代码  https://github.com/hello-piper/piper

可以放到tomcat中  请求一下了

6  dubbo的监控页面

   项目启动之后,我们可以打开dubbo的监控页面看一下 消费者和提供者的状态

    这个把我坑的好惨   网上有人提供了一个dubbo-admin-2.6.0.war的包  说放到tomcat中就可以了

    我下载了他们的war包后却怎么也访问不到页面 

    后来想了一下   官网都下载不到这个war包  这些人怎么找到的呢    带着这个疑问找度娘

    这有一个小哥说了怎么自己生成一个war包  https://www.cnblogs.com/xhkj/p/7407092.html 

    把官网上的github地址的项目下载下来    在dos窗口 进入目录的dubbo-admin目录  使用maven打包工具 

    之后会生成一个war包  讲这个包放到tomcat中就行了

转载请注明原文地址: https://www.6miu.com/read-2612482.html

最新回复(0)