dubbo配合zookeeper远程调用

本文详细介绍了如何使用Dubbo框架实现微服务的提供者与消费者角色。从服务提供者的角度出发,展示了容器启动、接口定义、实现类创建及配置文件设置的全过程;同时,深入解析了服务消费者的配置与调用流程,包括依赖引入与远程服务调用代理的生成。
摘要由CSDN通过智能技术生成

一、 服务提供者:

1.dubbo容器启动类

import com.alibaba.dubbo.container.Main;

public class App 
{
    public static void main( String[] args )
    {
        Main.main(args);
    }
}

 2.对外暴露的接口:

public interface IOrderServices {
    DoOrderResponse doOrder(DoOrderRequest request);
}

 

3. 接口的实现类:

public class OrderServiceImpl implements IOrderServices{

    @Override
    public DoOrderResponse doOrder(DoOrderRequest request) {
        System.out.println("曾来过:"+request);
        DoOrderResponse response = new DoOrderResponse();
        response.setCode("1000");
        response.setMemo("处理成功");
        return response;
    }
}

4.配置文件:

虚拟机上启动四个zookeeper服务

<?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">
    <!--name:当前项目在整个分布式架构里面的唯一名称,计算依赖关系的标签 owner表示当前application是由谁维护-->
    <dubbo:application name="order-provider" owner="mic"/>
    <!--监控时使用-->
    <dubbo:monitor protocol="registry"/>
    <!--dubbo这个服务所要暴露的服务地址所对应的注册中心,四个zookeeper服务-->
    <dubbo:registry protocol="zookeeper" address="192.168.70.63:2181,192.168.70.64:2181,192.168.70.65:2181,192.168.70.66:2181"/>
    <!--当前服务发布所依赖的协议:webservice Thrift Hession http-->
    <dubbo:protocol name="dubbo" port="20880"/>
    <!--服务发布的配置,需要暴露的服务接口-->
    <dubbo:service interface="com.gupao.vip.mic.dubbo.order.IOrderServices" ref="orderService"/>
    <!--Bean bean定义-->
    <bean id="orderService" class="com.gupao.vip.mic.dubbo.order.OrderServiceImpl"/>
</beans>

 加入依赖的pom文件

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

 二、服务消费者:

1.消费端消费服务端提供的服务(orderService1对应的服务)

public class App 
{
    public static void main( String[] args ) throws IOException {
        ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext("order-consumer.xml");
        //获取服务提供者提供的服务  orderService1与消费端dubbo配置文件代理类id一致
        IOrderServices services=  (IOrderServices)context.getBean("orderService1");
        DoOrderRequest request = new DoOrderRequest();
        request.setName("fangxinde");
        DoOrderResponse response = services.doOrder(request);
        System.out.println(response);
        System.in.read();
    }
}

 2.消费端的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: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">
    <!--name:当前项目在整个分布式架构里面的唯一名称,计算依赖关系的标签 owner表示当前application是由谁维护-->
    <dubbo:application name="order-provider" owner="mic"/>
    <!--dubbo这个服务所要暴露的服务地址所对应的注册中心-->
    <dubbo:registry address="zookeeper://192.168.70.66:2181?backup=192.168.70.65:2181,192.168.70.64:2181,192.168.70.63:2181"/>

    <!--生成一个远程服务的调用代理-->
    <dubbo:reference id="orderService1" interface="com.gupao.vip.mic.dubbo.order.IOrderServices"/>
</beans>

 

3.依赖pom文件(需要引用zookeeper的jar包)

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

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值