基于thrift的微服务框架
前一陣開源過一個(gè)基于spring-boot的rest微服務(wù)框架,今天再來一篇基于thrift的微服務(wù)加框,thrift是啥就不多了,大家自行百度或參考我之前介紹thrift的文章, thrift不僅支持tcp/ip協(xié)議的rpc調(diào)用,也支持http協(xié)議的rest服務(wù)調(diào)用,同一個(gè)項(xiàng)目中甚至可同時(shí)支持這二種方式。thrift項(xiàng)目2007年由facebook開源以來,已經(jīng)有無數(shù)成功的應(yīng)用,完全可以基于這一框架來設(shè)計(jì)自己的服務(wù)架構(gòu),示意圖如下:
github上我開源了基于thrift的微服務(wù)框架,地址:https://github.com/yjmyzz/thrift-service-framework ,其主要特性:
支持rpc調(diào)用
支持常規(guī)的tcp/ip協(xié)議的rpc調(diào)用
支持http協(xié)議的servlet調(diào)用
1、 支持以servlet方式嵌入web容器(tomcat/weblogic/jboss之類)運(yùn)行
2、 也可以直接用嵌入式j(luò)etty直接從jar包運(yùn)行
支持javascript調(diào)用
支持js直接調(diào)用,post的json格式為:
以下格式無需手動(dòng)拼寫,thrift生成的js客戶端會(huì)自動(dòng)封裝及解析
[1,"hello",1,0,{"1":{"str":"jimmy"}}]返回結(jié)果以json格式返回:
[1,"hello",2,0,{"0":{"str":"hello,jimmy"}}]部署方式
本框架支持以下二種部署方式:
1、 jetty嵌入式模式,mvn package將在target目錄下生成可直接運(yùn)行的thrift-service-framework.jar, 然后java -jar thrift-service-framework.jar
2、 將pom.xml中的<packaging>jar</packaging>中的jar改成war,同時(shí)注釋掉plug中的maven-shade-plugin,然后mvn package 生成war包,可部署到任何兼容servlet 2.5+的web容器
注:方式1下,默認(rèn)http端口為8080,如需修改,可在啟動(dòng)時(shí)指定端口,例如:java -jar thrift-service-framework.jar -port=9090 , rpc端口在src/main/resources/spring-thrift.xml中修改
測(cè)試運(yùn)行
1、 js調(diào)用直接瀏覽http://localhost:8080/thrift-service-framework/ ,點(diǎn)擊頁面的call thrift按鈕,即可測(cè)試js方式直接調(diào)用
2、 src/test/java/com/cnblogs/yjmyzz/thrift/proxy/ThriftServiceClientTest.java 里提供了rpc及http方式調(diào)用的測(cè)試用例
?
總結(jié)
以上是生活随笔為你收集整理的基于thrift的微服务框架的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: IPV4报头格式详解
- 下一篇: 界面