分佈式服務dubbo使用

SOA 服務框架dubbo


節點角色說明:
Provider: 暴露服務的服務提供方。
Consumer: 調用遠程服務的服務消費方。
Registry: 服務註冊與發現的註冊中心。
Monitor: 統計服務的調用次調和調用時間的監控中心。
Container: 服務運行容器html

遠程生產者

至於dubbo的詳細介紹網上不少,此次主要是簡單測試。
遠程接口java

package com.tony.dubbo.service;

public interface CustomerService {
    public String getName();
}

遠程接口實現方法linux

package com.tony.dubbo.service;

public class CustomerServiceImpl implements CustomerService {
    public String getName() {
        System.out.println("remote method~~~~");
        return "CustomerServiceImpl=====>getName";
    }
}

**遠程dobbo的接口dubbo-provide.xmll文件git

由於要用到zookeeper,至於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 ">
    <!-- 提供方應用名稱信息,這個至關於起一個名字,咱們dubbo管理頁面比較清晰是哪一個應用暴露出來的 -->
    <dubbo:application name="dubbo_provider"></dubbo:application>
    <!-- 使用zookeeper註冊中心暴露服務地址 -->
    <dubbo:registry address="zookeeper://192.168.163.33:2181"></dubbo:registry>
    <dubbo:protocol name="dubbo" port="20880" />
    <!-- 具體的實現bean -->
    <bean id="demoService" class="com.tony.dubbo.service.CustomerServiceImpl" />
    <!-- 聲明須要暴露的服務接口 -->
    <dubbo:service interface="com.tony.dubbo.service.CustomerService" ref="demoService" />

</beans>

DemoProvider.javagithub

package com.tony.dubbo.service;

import java.io.IOException;

import org.springframework.context.support.ClassPathXmlApplicationContext;

public class DemoProvider {
    public static void main(String[] args) throws IOException {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath*:META-INF/spring/*.xml");
        context.start();
        System.out.println("run DemoProvider...");
        System.in.read();
    }
}
Maven依賴配置
<dependencies>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.5.3</version>
        </dependency>

        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.5.0-alpha</version>
        </dependency>

        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
    </dependencies>
簡單工程

以上是遠程的的方法,咱們要把遠程的接口方法打成jar。提供給消費者使用。spring

消費者方法

package com.tony.dubbo.serviceImpl;

import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.tony.dubbo.service.CustomerService;

public class DemoConsumer {
    public static void main(String[] args) {

        // Consumer
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("classpath*:META-INF/spring/*.xml");
        context.start();
        CustomerService userService = (CustomerService) context.getBean("demoService");
        System.out.println(userService.getName());
    }
}

dubbo-consumer.xml配置apache

<?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:jee="http://www.springframework.org/schema/jee"  
    xmlns:tx="http://www.springframework.org/schema/tx"  
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xmlns:context="http://www.springframework.org/schema/context"  
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd  
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd  
    http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.1.xsd  
    http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd"  
    default-lazy-init="false" >  
  
<!--    <dubbo:application name="dubbo_consumer"></dubbo:application>   -->
   <!-- 使用zookeeper註冊中心暴露服務地址 -->    
   <dubbo:registry address="zookeeper://192.168.163.33:2181" check="false"></dubbo:registry>   
     <!-- 要引用的服務 -->    
   <dubbo:reference interface="com.tony.dubbo.service.CustomerService" id="demoService"></dubbo:reference>  
</beans>

Maven依賴 pom.xml配置api

<dependencies>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.5.3</version>
        </dependency>

        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.5.0-alpha</version>
        </dependency>

        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
        <dependency>
            <groupId>com.tony</groupId>
            <artifactId>dubbo-api</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
    </dependencies>

消費者工程
app

運行結果

  • 首先運行遠程生產方法
  • 運行消費服務方法
  • 能夠進入linux中查看zookeeper的鏈接狀態,發現 dubbo

以上是基於dubbo 2.5.3 版本,zookeeper的3.5.0-alpha版本測試,開始測試過程用的zookeeper其餘版本測試發現有些依賴jar不全。框架

進過測試發現基於SOA,能夠調用到遠程的方法。固然能夠debug遠程的方法就和本地調試同樣。

固然咱們dobbo也有monitor監控中心,能夠詳細看到如今啓動的服務,有哪些機器正在調用等等。

相關文章
相關標籤/搜索