Dorado 快速使用指南

优质
小牛编辑
140浏览
2023-12-01

快速使用指南,便于使用者快速了解Dorado的应用,更多详细内容可以阅读Dorado使用说明手册

1. 运行准备

1.1 提前安装:JDK 7+、Maven 3+ 并配置好环境

1.2 下载仓库代码准备Dorado依赖

  git clone https://github.com/Meituan-Dianping/octo-rpc.git octo-rpc

2. 运行(二选一)

以下两种方式选择一种快速运行 dorado

2.1 运行Dorado项目Demo

2.1.1 IDE导入dorado 完整项目

注意:Dorado和Whale(C++框架)在一个仓库,选择dorado目录导入即可

2.1.2 进入derado-demo模块

2.1.3 选择一个demo, 如simple package下

2.1.4 run ThriftProvider main

2.1.5 run ThriftConsumer main

在ThriftConsumer控制台将看到服务端的返回

2.2 独立Project运行

2.2.1 install dorado到本地仓库

切换到dorado目录

cd octo-rpc/dorado

本地install

mvn clean install -Dmaven.test.skip=true

注意:dorado-registry-mns、dorado-trace-cat模块因需要mns和cat的依赖,若构建失败可忽略

  • 默认dorado包未包含需以上模块,若需要使用见源码编译说明

  • dorado-registry-mns是OCTO-NS注册中心的集成模块,若使用请到OCTO-NS获取依赖mns-invoker依赖(需要有OCTO-NS注册服务)

  • dorado-trace-cat是Cat应用监控的集成,若使用请到Cat获取依赖(需要有Cat服务)

2.2.2 创建maven工程

pom.xml添加dorado依赖

<dependency>
    <groupId>com.meituan.octo</groupId>
    <artifactId>dorado</artifactId>
    <version>1.0.0</version>
</dependency>

2.2.3 创建接口类 和 实现类

将接口HelloService.java 和 实现类HelloServiceImpl.java 拷贝到你的工程中,注意包路径。 说明:调用端有接口类就行,服务端需要接口类和实现类。

2.2.4 创建服务端启动类,发布服务

下面的代码通过mock的方式发布实现HelloService接口的服务,注意需要对服务端口号、服务于appkey、服务注册地址、服务接口以及服务实现类进行配置,最后通过init方法发布服务

import com.meituan.dorado.config.service.ProviderConfig;
import com.meituan.dorado.config.service.ServiceConfig;
import com.meituan.dorado.demo.thrift.api.HelloService;
import com.meituan.dorado.demo.thrift.api.HelloServiceImpl;

public class QuickStartServer {
    public static void main(String[] args) {
        ServiceConfig<HelloService.Iface> serviceConfig = new ServiceConfig<>();
        serviceConfig.setServiceInterface(HelloService.class);        // 服务接口
        serviceConfig.setServiceImpl(new HelloServiceImpl());         // 服务实现类

        ProviderConfig providerConfig = new ProviderConfig();
        providerConfig.setAppkey("com.meituan.octo.dorado.server");           // 服务appkey
        providerConfig.setServiceConfig(serviceConfig);                       // 服务接口类
        providerConfig.setRegistry("mock");                                   // 服务注册, mock伪注册中心
        providerConfig.setPort(9001);                                         // 服务端口号
        providerConfig.init();                                                // 启动服务
    }
}

2.2.5 创建调用端启动类,订阅服务,发起调用

下面的代码通过直连方式访问mock发布的服务

import com.meituan.dorado.config.service.ReferenceConfig;
import com.meituan.dorado.demo.thrift.api.HelloService;
import org.apache.thrift.TException;
import org.junit.Assert;

public class QuickStartClient {
    public static void main(String[] args) {
        ReferenceConfig<HelloService.Iface> referenceConfig = new ReferenceConfig<>();
        referenceConfig.setAppkey("com.meituan.octo.dorado.client");           //调用端appkey
        referenceConfig.setRemoteAppkey("com.meituan.octo.dorado.server");     //服务端appkey
        referenceConfig.setServiceInterface(HelloService.class);               //服务接口
        referenceConfig.setRegistry("mock");                                   //服务发现, mock伪注册中心
        referenceConfig.setDirectConnAddress("localhost:9001");                //直连访问

        HelloService.Iface client = referenceConfig.get();
        try {
            String result = client.sayHello("OCTO");
            System.out.println(result);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}