<< 电力系统的销售怎么做? | 首页 | 为你的 Hadoop 集群选择合适的硬件 - 技术翻译 - 开源中国社区 >>

Dubbo Zookeeper 初探

2. 服务提供者的工程

a. dubbo-demo-api 定义接口

1
2
3
public interface IProcessData {
    public String deal(String data);
}

b. dubbo-demo-provider 服务提供者

1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class ProcessDataImpl implements IProcessData {
    /*
     * @see com.xxx.bubbo.provider.IProcessData#deal(java.lang.String)
     */
    @Override
    public String deal(String data) {
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return "Finished:" + data;
    }
}

c. applicationProvider.xml配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<?xml version="1.0" encoding="UTF-8"?> 
        "> 
   
    <!-- Application name --> 
    <dubbo:application name="hello-world-app" /> 
   
    <!-- registry address, used for service to register itself --> 
    <dubbo:registry address="zookeeper://127.0.0.1:2181" /> 
   
    <!-- expose this service through dubbo protocol, through port 20880 --> 
    <!-- 
    <dubbo:protocol name="dubbo" port="20880" /> 
       
    <dubbo:protocol name="dubbo" port="9090" server="netty" 
        client="netty" codec="dubbo" serialization="hessian2" charset="UTF-8" 
        threadpool="fixed" threads="100" queues="0" iothreads="9" buffer="8192" 
        accepts="1000" payload="8388608" /> 
        --> 
    <!-- Service interface   Concurrent Control  --> 
    <dubbo:service interface="com.huangjie.dubbo_Service.service.IProcessData" 
        ref="demoService" executes="10" /> 
   
    <!-- Default Protocol --> 
    <!-- 
    <dubbo:protocol server="netty" /> 
    --> 
   
    <!-- designate implementation --> 
    <bean id="demoService" class="com.huangjie.dubbo_Service.service.impl.ProcessDataImpl" /> 
   
</beans>

d. 启动服务

1
2
3
4
5
6
7
8
9
10
public class DubboProviderMain { 
    public static void main(String[] args) throws Exception { 
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext( 
                new String[]{"applicationProvider.xml"}); 
        context.start();
   
        System.out.println("Press any key to exit."); 
        System.in.read(); 
    
}

3. 服务调用者的工程

a. 调用类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
public class ConsumerThd implements Runnable { 
   
    /* 
     * @see java.lang.Runnable#run()
     */ 
    @Override 
    public void run() {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext( 
                new String[]{"applicationConsumer.xml"}); 
        context.start(); 
   
        IProcessData demoService = (IProcessData) context.getBean("demoService"); // get 
                                                                                // service 
                                                                                // invocation 
        // proxy 
        String hello = demoService.deal("nihao"); // do invoke! 
   
        System.out.println(Thread.currentThread().getName() + " "+hello); 
    
     
    public static void main(String[] args) {
        new Thread(new ConsumerThd()).start();
        /**
         * 输出结果:
         * Thread-0 Finished:nihao
         */
    }
}

b. applicationConsumer.xml配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?xml version="1.0" encoding="UTF-8"?> 
        "> 
   
    <!-- consumer application name --> 
    <dubbo:application name="consumer-of-helloworld-app" /> 
   
    <!-- registry address, used for consumer to discover services --> 
    <dubbo:registry address="zookeeper://127.0.0.1:2181" /> 
    <dubbo:consumer timeout="5000"/> 
    <!-- which service to consume? --> 
    <dubbo:reference id="demoService" interface="com.huangjie.dubbo_Service.service.IProcessData" /> 
</beans>

4. 最后需要把zookeeper的服务给启动,在zookeeper安装文件夹下面的bin目录里面的zkServer.cmd给点击运行。不要关闭窗口,保持服务运行

这样整个调用就完成了,这样的好处是只要远程提供ip地址及端口号,以及对外调用的类,客户端就可以调用,客户端不必知道服务端的地址之类的。

而且服务端可以开多个zookeeper服务,这样如果其中一个zookeeper 服务死掉了,其他服务还能正常运行。

阅读全文……

标签 : , ,



发表评论 发送引用通报