dubbo初探

  1. 定义
  2. 快速开始

2.1 demo-provider部分
2.2 demo-consumer部分
2.3 启动

1.定义

Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和Spring框架无缝集成。

2.快速开始

Dubbo最常用的使用方式是运行在spring 框架中。
创建一个简单的demo我们需要创建两个部分
demo-provider、demo-consumer

demo-provider部分

此部分的结构


image.png

github地址
git clone https://github.com/apache/incubator-dubbo.git
运行时加上 -Djava.net.preferIPv4Stack=true 如果你使用的IDE 是 Intellij Idea

DemoService.java

package org.apache.dubbo.demo;
public interface DemoService {
    String sayHello(String name);
}

DemoServiceImpl.java

package org.apache.dubbo.demo.provider;
import org.apache.dubbo.demo.DemoService;

public class DemoServiceImpl implements DemoService {
    public String sayHello(String name) {
        return "Hello " + name;
    }
}

provider.xml



    
    
    
    
    
    
    
    
    
    

使用multicast不需要额外安装且简单 也可以使用zookeeper

log4j.properties 支持slf4j

###set log levels###
log4j.rootLogger=info, stdout
###output to the console###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d{dd/MM/yy hh:mm:ss:sss z}] %t %5p %c{2}: %m%n

Provider.java

package org.apache.dubbo.demo.provider;

import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Provider {

    public static void main(String[] args) throws Exception {
        System.setProperty("java.net.preferIPv4Stack", "true");
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[]{"META-INF/spring/dubbo-demo-provider.xml"});
        context.start();
        System.out.println("Provider started.");
        System.in.read(); // press any key to exit
    }
}

demo-consumer部分

此部分结构


image.png

github地址:
git clone https://github.com/apache/incubator-dubbo.git
运行前先启动provider
如果IDE使用的是Intellij IDEA 请在运行时加上 -Djava.net.preferIPv4Stack=true

配置
配置文件 resource/META-INFO.spring/dubbo-demo-consumer.xml
修改dubbo:registery 为真正的registery center 地址

consumer.xml




    
    
    
    
    
    

Consumer.java

import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.apache.dubbo.demo.DemoService;
 
public class Consumer {
    public static void main(String[] args) throws Exception {
        ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"META-INF/spring/dubbo-demo-consumer.xml"});
        context.start();
        // Obtaining a remote service proxy
        DemoService demoService = (DemoService)context.getBean("demoService");
        // Executing remote methods
        String hello = demoService.sayHello("world");
        // Display the call result
        System.out.println(hello);
    }
}

配置log4j类似provider中的那样

启动

运行org.apache.dubbo.demo.provider.Provider
再运行org.apache.dubbo.demo.provider.Consumer能看到打印结果:
Hello world

你可能感兴趣的:(dubbo初探)