使用Java如何实现创建一个thrift服务器?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
公司主营业务:成都做网站、成都网站制作、成都外贸网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联公司推出芒康免费做网站回馈大家。
Thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发。它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 等等编程语言间无缝结合的、高效的服务。
Thrift最初由facebook开发,07年四月开放源码,08年5月进入apache孵化器。thrift允许你定义一个简单的定义文件中的数据类型和服务接口。以作为输入文件,编译器生成代码用来方便地生成RPC客户端和服务器通信的无缝跨编程语言。
首先环境介绍一下:
1.IntelliJ IDEA 2017.1
2.thrift-0.9.3
相信大家在看我这篇文章的时候已经对thrift通信框架已有所调研,这里就不再赘述了,直接进入正题:
<1>创建HelloWorld.thrift
namespace java com.thrift.demo
service HelloWorldService{ string sayHello(1:string username) }
<2>利用thrift生成HelloWorld.java文件,cmd指令下进入thrift当前目录下输入命令
thrift.exe -gen java HelloWorld.thrift
java为要生成文件的类型,HelloWorld.thrift为前面的文件。
<3>创建IDEA 下的maven项目,其中的好处就不一一说明了,最重要的一条就是可以在pom.xml文件中添加dependency,能够在项目中自行下载库文件,方便协同开发中出现的开发包不对应的情况。
javax.servlet javax.servlet-api 3.1.0 jstl jstl 1.2 org.apache.thrift libthrift 0.9.3 org.slf4j slf4j-log4j12 1.7.5
上述pom引入相应的依赖项就可以让它自行下载。
<4>项目的结构图当前如下所示:
File--Project Structure--Modules,在main文件夹下新建java文件夹并设为Soueces类型(因为在Sources文件下可以新建java class文件)
同时将thrift生成的HelloWorld.java文件复制到该目录下
<5>实现接口Iface
java代码:HelloWorldImpl.java
package com.jmust.thrift.demo; import org.apache.thrift.TException; /** * Created by Administrator on 2017/3/31. */ public class HelloWorldImpl implements HelloWorldService.Iface { public HelloWorldImpl() { } @Override public String sayHello(String username) throws TException { return "Hi,"+username+"Welcome to my blog http://www.cnblogs.com/zfygiser"; } }
<6>服务端TSimpleServer
java代码:HelloServer.java
/** * Created by Administrator on 2017/3/31. */ package com.jmust.thrift.demo; import org.apache.thrift.TProcessor; import org.apache.thrift.protocol.TBinaryProtocol; import org.apache.thrift.server.TServer; import org.apache.thrift.server.TSimpleServer; import org.apache.thrift.transport.TServerSocket; public class HelloServer { public final static int SERVER_PORT = 7099; private static String SERVER_IP = "localhost"; public void startServer() { try { System.out.println("HelloWorld Server start..."); TServerSocket serverTransport = new TServerSocket(SERVER_PORT); TServer.Args args = new TServer.Args(serverTransport); TProcessor process = new HelloWorldService.Processor(new HelloWorldImpl()); TBinaryProtocol.Factory portFactory = new TBinaryProtocol.Factory(true, true); args.processor(process); args.protocolFactory(portFactory); TServer server = new TSimpleServer(args); server.serve(); } catch (Exception e) { System.out.println("Server start error"); e.printStackTrace(); } } public static void main(String[] args) { HelloServer server = new HelloServer(); server.startServer(); } }
<7>编写客户端代码
java代码:Client.java
package com.jmust.thrift.demo; import org.apache.thrift.protocol.TBinaryProtocol; import org.apache.thrift.protocol.TProtocol; import org.apache.thrift.transport.TSocket; import org.apache.thrift.transport.TTransport; /** * Created by Administrator on 2017/4/1. */ public class Client { public static final int SERVER_PORT = 7099; public static final String SERVER_IP = "localhost"; public void startClient(String username) { TTransport tTransport = null; try { tTransport = new TSocket(SERVER_IP, SERVER_PORT); //协议要和服务端一致 TProtocol protocol = new TBinaryProtocol(tTransport); HelloWorldService.Client client = new HelloWorldService.Client(protocol); tTransport.open(); String result = client.sayHello(username); System.out.println("Thrift client result=" + result); } catch (Exception e) { e.printStackTrace(); } } public static void main(String[] args) { Client client = new Client(); client.startClient("zfy"); } }
客户端测试成功,截图如下:
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。