初识thrift以及相关例子演示

windows安装thrift

thrift windows下载链接
选中 thrift-0.9.3.exe 在这里插入图片描述
下载完成后 将该文件置于自定义文件夹下面 , 并修改 thrift-0.9.3.exe 为 thrift.exe。
配置环境变量
在path下加入 D:\Program Files\Thrift 我的是放在 这个目录下

打开cmd 输入 thrift -version 如果出现版本号则代表安装成功

编写.thrift相关的文件

格式标准参考 https://github.com/apache/thrift/tree/master/tutorial 下的shared.thrift和tutorial.thrift
现在对我自己仿照写的做一个说明

//指明包路径
namespace java org.example.thrift

//创建别名
typedef i16 short 
typedef i32 int
typedef i64 long
typedef string String

//类似java的实体数据类 就相当于数据库表所对应的model
struct PersonData{
    1: optional int num1=0,
    2: optional String comment
}

//自定义异常类
exception MyException{
    1: int whatOp,
    2: String why
}

exception NewException{
    1:long code,
    2:String message
}

//类似于java的service类
service CaculatorService{

    string ping(),

    i32 add(1:int num1,2:int num2)

    i64 calculate(1:int num1,2:int num2,3:PersonData data) throws (1:MyException ouch,2:NewException ex)

    PersonData getPerson(1:int num,2:string name)

}

执行命令
打开cmd执行以下命令 java代表生成java文件 person.thrift 是文件名

 thrift -out D:\你自己的想要生成在哪个文件下面  --gen java person.thrift

生成完成后会有如下相关文件

在这里插入图片描述
编写实现类

package org.example.thrift.service;

import org.apache.thrift.TException;
import org.example.thrift.CaculatorService;
import org.example.thrift.MyException;
import org.example.thrift.NewException;
import org.example.thrift.PersonData;

/**
 * @ClassName MyService
 * @Description MyService
 * @Date 2020/5/28 11:34
 * @Author wangyong
 * @Version 1.0
 **/
public class MyService implements CaculatorService.Iface {

    @Override
    public String ping() throws TException {
        return "这是一个完美的thrift程序";
    }

    @Override
    public int add(int num1, int num2) throws TException {
        return num1 + num2;
    }

    @Override
    public long calculate(int num1, int num2, PersonData data) throws MyException, NewException, TException {
        return num1 + num2;
    }

    @Override
    public PersonData getPerson(int num, String name) throws TException {
        PersonData data = new PersonData();
        data.setComment("你好");
        data.setNum1(1);
        return data;
    }
}

编写server

 public static void main(String[] args) throws TTransportException {
        TNonblockingServerSocket socket = new TNonblockingServerSocket(8899);

        THsHaServer.Args arg = new THsHaServer.Args(socket).minWorkerThreads(2).maxWorkerThreads(4);

        CaculatorService.Processor<MyService> processor = new CaculatorService.Processor<>(new MyService());


        arg.protocolFactory(new TCompactProtocol.Factory());
        arg.transportFactory(new TFramedTransport.Factory());
        arg.processorFactory(new TProcessorFactory(processor));

        TServer ser = new THsHaServer(arg);
        System.out.println("Thrift server start");
        ser.serve();
    }

编写client

  public static void main(String[] args) throws TException {
        TTransport transport = new TFastFramedTransport(new TSocket("localhost",8899),600);
        TProtocol protocol = new TCompactProtocol(transport);
        CaculatorService.Client client = new CaculatorService.Client(protocol);
        transport.open();
        PersonData name = client.getPerson(1, "name");
        System.out.println(name.getComment());
        int add = client.add(1, 2);
        transport.close();
    }

分别运行 server以及client。 如果输出comment信息内容则代表成功

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Thrift是一个跨语言的远程服务调用框架,它可以让不同语言的应用程序之间进行通信。下面是一个使用Thrift的简单例子: 1. 定义Thrift文件 首先,我们需要定义一个Thrift文件,它描述了我们要传输的数据类型和服务接口。例如,我们可以定义一个简单的数据类型Person: struct Person { 1: required string name, 2: optional i32 age, 3: optional string email } 然后,我们可以定义一个服务接口,例如: service PersonService { Person getPerson(1: string name), void savePerson(1: Person person) } 2. 生成代码 接下来,我们需要使用Thrift编译器生成代码。Thrift编译器可以根据Thrift文件生成不同语言的代码,例如Java、Python、C++等。例如,我们可以使用以下命令生成Java代码: thrift --gen java Person.thrift 这将生成一个Java包,其中包含了我们定义的数据类型和服务接口的Java类。 3. 实现服务端 接下来,我们需要实现服务端。我们可以使用生成的Java类来实现我们定义的服务接口。例如,我们可以实现一个简单的PersonService服务: public class PersonServiceImpl implements PersonService.Iface { public Person getPerson(String name) throws TException { // 查询数据库或者其他操作 Person person = new Person(); person.setName(name); person.setAge(20); person.setEmail("[email protected]"); return person; } public void savePerson(Person person) throws TException { // 保存到数据库或者其他操作 } } 4. 实现客户端 最后,我们需要实现客户端。我们可以使用生成的Java类来调用服务端提供的服务接口。例如,我们可以实现一个简单的Java客户端: public class PersonServiceClient { public static void main(String[] args) throws Exception { TTransport transport = new TSocket("localhost", 9090); transport.open(); TProtocol protocol = new TBinaryProtocol(transport); PersonService.Client client = new PersonService.Client(protocol); // 调用服务端的getPerson方法 Person person = client.getPerson("张三"); System.out.println(person.getName() + " " + person.getAge() + " " + person.getEmail()); // 调用服务端的savePerson方法 Person newPerson = new Person(); newPerson.setName("李四"); newPerson.setAge(30); newPerson.setEmail("[email protected]"); client.savePerson(newPerson); transport.close(); } } 这个客户端会连接到服务端的9090端口,并调用服务端提供的getPerson和savePerson方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值