`
dreamoftch
  • 浏览: 498715 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

阿里巴巴 Dubbo框架demo

阅读更多

 

 

三个module:

 

service:定义接口

 

provider:定义接口实现

 

consumer:模拟接口调用

 

 

1:service

只是象征性的定义了一个接口:

 

package com.tch.test.dubbo.service;

public interface DemoService {

    String sayHello(String name);

}

 

 

2:provider:

 

pom.xml:

 

		<dependency>
			<groupId>com.tch.test.dubbo</groupId>
			<artifactId>service</artifactId>
			<version>0.0.1-SNAPSHOT</version>
		</dependency>
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>dubbo</artifactId>
			<version>2.8.4</version>
		</dependency>
		<dependency>
			<groupId>com.101tec</groupId>
			<artifactId>zkclient</artifactId>
			<version>0.7</version>
		</dependency>

 

 

还有一个接口的简单实现:

 

package com.tch.test.dubbo.provider.serviceimpl;

import com.tch.test.dubbo.service.DemoService;

public class DemoServiceImpl implements DemoService {

    public String sayHello(String name) {

        return "Hello " + name;

    }

}

 

 

然后是spring配置文件applicationContext.xml,里面保护了dubbo的配置,我这里使用到了本地localhost的zookeeper,端口是默认的2181,如果不用zookeeper的话,直接将

 

<dubbo:registry address="zookeeper://localhost:2181" check="false"></dubbo:registry>

 

这句话注释掉,将

 

<dubbo:registry address="multicast://224.5.6.7:1234" />

 

放开即可。至于为什么建议zookeeper部署奇数台,是因为根据zookeeper的leader选举算法,由于zookeeper挂掉一半的机器集群就不可用,所以部署4台和3台的集群都是在挂掉2台后集群不可用,所以使用奇数台机器,不浪费资源

 

 

<?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="hello-world-app" />
	<!-- 使用multicast广播注册中心暴露服务地址 -->
	<!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
	<dubbo:registry address="zookeeper://localhost:2181" check="false"></dubbo:registry>
	<!-- 用dubbo协议在20880端口暴露服务 -->
	<dubbo:protocol name="dubbo" port="20880" />
	<!-- 声明需要暴露的服务接口 -->
	<dubbo:service interface="com.tch.test.dubbo.service.DemoService"
		ref="demoService" />
	<!-- 和本地bean一样实现服务 -->
	<bean id="demoService" class="com.tch.test.dubbo.provider.serviceimpl.DemoServiceImpl" />
</beans>

 

 

然后是provider的测试类:

 

package com.tch.test.dubbo.provider.test;

import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Provider {

    public static void main(String[] args) throws Exception {
        ClassPathXmlApplicationContext context = null;
        try {
            context = new ClassPathXmlApplicationContext(new String[] { "applicationContext.xml" });
            context.start();
            context.registerShutdownHook();
            System.in.read();
        } catch (Exception e) {
            e.printStackTrace();
        }finally{
            context.close();
        }
    }
}

 

 

 

3:consumer:

 

pom.xml和provider一样:

 

		<dependency>
			<groupId>com.tch.test.dubbo</groupId>
			<artifactId>service</artifactId>
			<version>0.0.1-SNAPSHOT</version>
		</dependency>
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>dubbo</artifactId>
			<version>2.8.4</version>
		</dependency>
		<dependency>
			<groupId>com.101tec</groupId>
			<artifactId>zkclient</artifactId>
			<version>0.7</version>
		</dependency>

 

 

然后是spring配置文件applicationContext.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="consumer-of-helloworld-app" />
	<!-- 使用multicast广播注册中心暴露发现服务地址 -->
	<!-- <dubbo:registry address="multicast://224.5.6.7:1234" /> -->
	<dubbo:registry address="zookeeper://localhost:2181" check="false"></dubbo:registry>
	<!-- 生成远程服务代理,可以和本地bean一样使用demoService -->
	<dubbo:reference id="demoService"
		interface="com.tch.test.dubbo.service.DemoService" />
</beans>

 

 

最后是consumer的测试类:

 

package com.tch.test.dubbo.consumer.test;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.tch.test.dubbo.service.DemoService;

public class Consumer {

    public static void main(String[] args) throws Exception {
        ClassPathXmlApplicationContext context = null;
        try {
            context = new ClassPathXmlApplicationContext(new String[] { "applicationContext.xml" });
            context.start();
            context.registerShutdownHook();
            DemoService demoService = (DemoService) context.getBean("demoService"); // 获取远程服务代理
            String hello = demoService.sayHello("world"); // 执行远程方法
            System.out.println(hello); // 显示调用结果
            context.stop();
        } catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(context != null){
                context.close();
            }
        }

    }

}

 

 

 

接下来,先运行Provider.java,在运行Consumer.java即可看到调用结果(当前前提是zookeeper是启动的啦):

 

Hello world

 

 关于zookeeper client的简单demo:

 

添加依赖:

 

		<dependency>
			<groupId>com.101tec</groupId>
			<artifactId>zkclient</artifactId>
			<version>0.7</version>
		</dependency>

 

 

一方面对zookeeper进行修改等操作,一方面进行监测:

 

package com.tch.zookeeper.test;
import java.util.UUID;

import org.I0Itec.zkclient.ZkClient;
import org.apache.zookeeper.CreateMode;


public class ZookeeperOperator {
    
    private ZkClient zkClient;
    
    public ZkClient getZkClient() {
        return zkClient;
    }

    public void setZkClient(ZkClient zkClient) {
        this.zkClient = zkClient;
    }


    /**
     * 函数入口
     * @param args
     */
    public static void main( String[] args ) {
       
        ZookeeperOperator bootStrap=new ZookeeperOperator();
        bootStrap.initialize();
        
        try {
            Thread.sleep(100000000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
            
    }
    
  
    /**
     * 初始化zookeeper
     */
    public void initialize() {
        
        String connectionString="localhost:2181";
        int connectionTimeout=50000;
        
        zkClient=new ZkClient(connectionString, connectionTimeout);
        
        if(!zkClient.exists("/root1")) {
            zkClient.create("/root1", new Long(System.currentTimeMillis()), CreateMode.EPHEMERAL);
        }
            
        new Thread(new RootNodeChangeThread()).start();
    }
    
    /**
     * 每20s改变一次 'root1'节点的数据
     * @author yang
     *
     */
    private class RootNodeChangeThread implements Runnable{

        public void run() {
            
            while(true) {
            
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    //ignore
                }
                
                String uuidStr=UUID.randomUUID().toString();    
                
                System.out.println(">>>>>>>>>> 产生随机的 uuid string,'uuidStr'===>"+uuidStr);
                
                zkClient.writeData("/root1", uuidStr);
                
            }
            
        }
        
    }
}

 

 

package com.tch.zookeeper.test.slave;
import org.I0Itec.zkclient.IZkDataListener;
import org.I0Itec.zkclient.ZkClient;

public class ZookeeperMonitor {
    
    private ZkClient zkClient;
    
    public ZkClient getZkClient() {
        return zkClient;
    }

    public void setZkClient(ZkClient zkClient) {
        this.zkClient = zkClient;
    }

    /**
     * 初始化zookeeper
     */
    public void initialize() {
        
        String connectionString="localhost:2181";
        int connectionTimeout=500000;
        
        zkClient=new ZkClient(connectionString, connectionTimeout);
        
        new Thread(new Runnable() {
            
            public void run() {
            
                zkClient.subscribeDataChanges("/root1", new IZkDataListener() {
                    
                    public void handleDataDeleted(String dataPath) throws Exception {
                        System.out.println("the node 'dataPath'===>");    
                    }
                    
                    public void handleDataChange(String dataPath, Object data) throws Exception {
                        System.out.println("the node 'dataPath'===>"+dataPath+", data has changed.it's data is "+String.valueOf(data));
                        
                    }
                });
                
            }
            
        }).start();
    }
    
    /**
     * 函数入口
     * @param args
     */
    public static void main( String[] args ) {
       
        ZookeeperMonitor bootStrap=new ZookeeperMonitor();
        bootStrap.initialize();
        
        try {
            Thread.sleep(100000000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
            
    }
}

 

通过运行结果即可明白

 

分享到:
评论

相关推荐

    dubbo-demo

    【Dubbo】是阿里巴巴开源的一款高性能、轻量级的Java服务框架,它专注于远程调用服务,具有服务注册与发现、负载均衡、容错、监控等核心功能。在本示例中,`dubbo-demo` 提供了对 Dubbo 功能的直观体验。 【服务...

    dubbo-demo-consumer、dubbo-demo-provider、dubbo-simple-monitor

    Dubbo是阿里巴巴开源的一款高性能、轻量级的服务治理框架,广泛应用于分布式系统中的服务调用。本篇将详细讲解基于dubbo-demo-consumer、dubbo-demo-provider和dubbo-simple-monitor的实例服务,带你深入理解Dubbo的...

    java-springmvc-dubbo集成demo

    在本项目"java-springmvc-dubbo集成demo"中,主要展示了如何将Spring MVC与阿里巴巴的Dubbo框架进行集成,创建一个完整的微服务架构。这个资源包含三个关键部分:api服务接口定义工程、provider服务提供者工程以及...

    Dubbo-Demo

    Dubbo是中国阿里巴巴开源的一款高性能、轻量级的Java RPC框架,它提供了服务治理、负载均衡、容错机制等功能,极大地促进了微服务架构的发展。 【描述】"初学Dubbo的一个简单案例"意味着这个项目包含了一个基本的...

    dubbo-demo项目源码

    Dubbo是一个由阿里巴巴开源的分布式服务框架,它设计的目标是提高服务的可治理性和性能,简化微服务架构中的服务调用。 【描述】提到的“dubbo项目的demo文件”,意味着这个压缩包包含了完整的源代码,可以供开发者...

    Dubbo demo

    【标题】"Dubbo Demo" 是一个专门为初学者设计的示例项目,旨在帮助他们快速理解和上手Apache Dubbo框架。Dubbo是一个高性能、轻量级的开源Java RPC框架,它提供了服务治理、集群容错、负载均衡等功能,是阿里巴巴...

    dubbo-demo服务端

    【标题】"dubbo-demo服务端" 是一个基于Apache Dubbo框架构建的服务端示例项目,主要用于展示如何在实际开发中运用Dubbo实现服务提供与消费。Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了服务治理、监控...

    dubbo-demo-maven版

    Dubbo,作为阿里巴巴开源的一款高性能、轻量级的Java分布式服务框架,深受广大开发者喜爱。本示例项目“dubbo-demo-maven版”是基于Maven构建的,旨在帮助开发者快速理解并掌握Dubbo的核心功能与使用方式。在本文中...

    Dubbo框架Demo

    【标题】"Dubbo框架Demo"揭示了我们即将探讨的核心主题——如何利用Apache Dubbo构建一个实际的应用示例。Dubbo是一款由阿里巴巴开源的高性能、轻量级的Java RPC框架,它致力于解决分布式系统中的服务治理问题,如...

    spring dubbo demo

    Spring Dubbo Demo是一个基于Spring和Dubbo框架的简单示例项目,主要用于展示如何在IntelliJ IDEA(简称Idea)开发环境中实现生产者-消费者模式。在这个项目中,我们将探讨Dubbo的核心概念、Spring整合Dubbo的方式...

    springboot-dubbo-demo.zip

    Dubbo是阿里巴巴开源的一款高性能、轻量级的Java RPC框架,它提供了服务治理、监控等功能。在本Demo中,Dubbo作为服务调用的桥梁,使得服务提供者(Provider)和消费者(Consumer)可以有效地通信。 接着,...

    dubbo-demo.zip

    而Dubbo作为阿里巴巴开源的高性能服务框架,结合Zookeeper作为注册中心,可以构建高效、稳定的服务治理平台。本示例“dubbo-demo.zip”提供了一个基础的Spring Boot整合Dubbo和Zookeeper的小型演示项目,分为api、...

    dubbo入门demo样例

    Dubbo是一款高性能、轻量级的Java开源服务框架,由阿里巴巴开发并维护,它主要提供了服务治理、远程调用、集群容错、监控等核心功能,是微服务架构中常见的服务治理组件。在这个“dubbo入门demo样例”中,我们将探讨...

    dubbo-demo-provider-consumer

    1. **Dubbo**:阿里巴巴开源的高性能、轻量级的Java RPC框架,它提供了服务治理、负载均衡、故障转移等功能,使得分布式服务的开发和管理变得更加简单。 2. **服务提供者(Provider)**:在Dubbo中,服务提供者是...

    dubbo的demo

    Dubbo是中国阿里巴巴开源的一款高性能、轻量级的Java RPC框架,它提供了丰富的服务治理功能,如服务注册、发现、负载均衡、监控等,是微服务架构中的重要组件。 【描述】提到“刚学习测试过的dubbo的demo”,这表明...

    dubbo-demo-provider-2.1.5-assembly.tar.gz

    【标题】"dubbo-demo-provider-2.1.5-assembly.tar.gz" 是一个与Dubbo框架相关的服务提供者示例项目的二进制压缩包,版本号为2.1.5。这个压缩包通常包含了运行该示例所需的所有组件和配置文件,用于帮助开发者理解和...

Global site tag (gtag.js) - Google Analytics