亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

淺談Thrift內部實現原理

2019-11-11 05:41:28
字體:
來源:轉載
供稿:網友
     Thrift由兩部分組成:編譯器(在compiler目錄下,采用C++編寫)和服務器(在lib目錄下),其中編譯器的作用是將用戶定義的thrift文件編譯生成對應語言的代碼,而服務器是事先已經實現好的、可供用戶直接使用的RPC Server(當然,用戶也很容易編寫自己的server)。同大部分編譯器一樣,Thrift編譯器(采用C++語言編寫)也分為詞法分析、語法分析等步驟,Thrift使用了開源的flex和Bison進行詞法語法分析(具體見thrift.ll和thrift.yy),經過語法分析后,Thrift根據對應語言的模板(在compiler/cpp/src/generate目錄下)生成相應的代碼。對于服務器實現而言,Thrift僅包含比較經典的服務器模型,比如單線程模型(TSimpleServer),線程池模型(TThreadPoolServer)、一個請求一個線程(TThreadedServer)和非阻塞模型(TNonblockingServer)等。本文將以C++為例進行一個實例分析。

假設用戶編寫了以下Thrift文件:

struct LogInfo {

1: required string name,

2: optional string content,

}

service LogSender {

void SendLog(1:list<LogInfo> loglist);

}

用戶使用命令“thrift –gen cpp example.thrift”可生成C++代碼,該代碼包含以下文件:

example_constants.h

example_constants.cpp

example_types.h  //struct定義

example_types.cpp  //struct實現

LogSender.h  //service定義

LogSender.cpp  //service實現和LogSenderClient實現

LogSender_server.skeleton.cpp //一個實例RPC Server

用戶可以這樣編寫Client:

shared_ptr socket(new TSocket(“8.8.8.8″, 9090));

shared_ptr transport(new TBufferedTransport(socket));

shared_ptr PRotocol(new TBinaryProtocol(transport));

LogSenderClient client(protocol);

try {

transport->open();

vector<LogInfo> logInfos;

LogInfo logInfo(“image”, “10:9:0 visit:xxxxxx”);

logInfos.push_back(logInfo);

…..

client.SendLog(logInfos);

transport->close();

} catch (TException &tx) {

printf(“ERROR: %s/n”, tx.what());

}

為了深入分析這段代碼,我們看一下client.SendLog()函數的內部實現(在LogSender.cpp中):

void LogSenderClient::SendLog(const std::vector<LogInfo> & loglist)

{

send_SendLog(loglist);

recv_SendLog();

}

void LogSenderClient::send_SendLog(const std::vector<LogInfo> & loglist)

{

int32_t cseqid = 0;

oprot_->writeMessageBegin(“SendLog”, ::apache::thrift::protocol::T_CALL, cseqid);

LogSender_SendLog_pargs args;

args.loglist = &loglist;

args.write(oprot_);

oprot_->writeMessageEnd();

oprot_->getTransport()->flush();

oprot_->getTransport()->writeEnd();

}

void LogSenderClient::recv_SendLog()

{

int32_t rseqid = 0;

std::string fname;

::apache::thrift::protocol::TMessageType mtype;

iprot_->readMessageBegin(fname, mtype, rseqid);

if (mtype == ::apache::thrift::protocol::T_EXCEPTION) {

…..

}

if (mtype != ::apache::thrift::protocol::T_REPLY) {

……

}

if (fname.compare(“SendLog”) != 0) {

……

}

LogSender_SendLog_presult result;

result.read(iprot_);

iprot_->readMessageEnd();

iprot_->getTransport()->readEnd();

return;

}

閱讀上面的代碼,可以看出,RPC函數SendLog()實際上被轉化成了兩個函數:send_SendLog和recv_SendLog,分別用于發送數據和接收結果。數據是以消息的形式表示的,消息頭部是RPC函數名,消息內容是RPC函數的參數。

我們再進一步分析RPC Server端,一個server的編寫方法(在LogSender.cpp中)如下:

shared_ptr protocolFactory(new TBinaryProtocolFactory());

shared_ptr handler(new LogSenderHandler());

shared_ptr processor(new LogSenderProcessor(handler));

shared_ptr serverTransport(new TServerSocket(9090));

shared_ptr transportFactory(new TBufferedTransportFactory());

TSimpleServer server(processor,

serverTransport,

transportFactory,

protocolFactory);

printf(“Starting the server…/n”);

server.serve();

Server端最重要的類是LogSenderProcessor,它內部有一個映射關系processMap_,保存了所有RPC函數名到函數實現句柄的映射,對于LogSender而言,它只保存了一個RPC映射關系:

processMap_[" SendLog"] = &LogSenderProcessor::process_SendLog;

其中,process_SendLog是一個函數指針,它的實現如下:

void LogSenderProcessor::process_SendLog(int32_t seqid, ::apache::thrift::protocol::TProtocol* iprot, ::apache::thrift::protocol::TProtocol* oprot)

{

LogSender_SendLog_args args;

args.read(iprot);

iprot->readMessageEnd();

iprot->getTransport()->readEnd();

LogSender_SendLog_result result;

try {

iface_->SendLog(args.loglist);//調用用戶編寫的函數

} catch (const std::exception& e) {

……

}

oprot->writeMessageBegin(“SendLog”, ::apache::thrift::protocol::T_REPLY, seqid);

result.write(oprot);

oprot->writeMessageEnd();

oprot->getTransport()->flush();

oprot->getTransport()->writeEnd();

}

LogSenderProcessor中一個最重要的函數是process(),它是服務器的主體函數,服務器端(socket server)監聽到客戶端有請求到達后,會檢查消息類型,并檢查processMap_映射,找到對應的消息處理函數,并調用之(注意,這個地方可以采用各種并發模型,比如one-request-one-thread,thread pool等)。

通過上面的分析可以看出,Thrift最重要的組件是編譯器(采用C++編寫),它為用戶生成了網絡通信相關的代碼,從而大大減少了用戶的編碼工作。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人精品一区二区在线| 超在线视频97| 国产精品v片在线观看不卡| 97人人模人人爽人人喊中文字| 久久久97精品| 色综合老司机第九色激情| 国产福利成人在线| 亚洲国产成人在线视频| 中文字幕最新精品| 亚洲影院色无极综合| 成人欧美一区二区三区在线| 日韩电影大全免费观看2023年上| 超碰精品一区二区三区乱码| 丝袜情趣国产精品| 性欧美长视频免费观看不卡| 欧美一乱一性一交一视频| 日韩精品视频免费| 欧美高清激情视频| 欧美电影免费观看| 98精品国产自产在线观看| 欧美最猛黑人xxxx黑人猛叫黄| 日韩网站免费观看高清| 亚洲国产日韩欧美在线动漫| 欧美大成色www永久网站婷| 亚洲国产女人aaa毛片在线| 亚洲国产精品成人精品| 国产精品丝袜久久久久久高清| 国产精品一区二区av影院萌芽| 午夜精品一区二区三区在线播放| 91成人在线观看国产| 成人免费淫片aa视频免费| 91精品视频大全| 久久亚洲欧美日韩精品专区| 国产丝袜一区二区三区| 久青草国产97香蕉在线视频| 日韩免费av在线| 久久精品国产欧美激情| 亚洲女人天堂色在线7777| 中国日韩欧美久久久久久久久| 欧美日韩亚洲一区二| 成人做爽爽免费视频| 欧美色xxxx| 热久久美女精品天天吊色| 福利一区福利二区微拍刺激| 97精品欧美一区二区三区| 国产精品成人久久久久| 精品夜色国产国偷在线| 欧美在线一级va免费观看| 国产精品久久久av久久久| 日韩美女视频中文字幕| 欧美最猛黑人xxxx黑人猛叫黄| 日韩经典中文字幕| 国产精品91久久| 国内伊人久久久久久网站视频| 日韩高清电影免费观看完整| 2025国产精品视频| 日韩av网址在线| 亚洲乱码一区二区| 91精品国产色综合久久不卡98口| 亚洲aa在线观看| 欧美午夜片欧美片在线观看| 色噜噜狠狠狠综合曰曰曰88av| 美日韩精品免费观看视频| 91av网站在线播放| 黑人巨大精品欧美一区二区| 国产一区二区三区精品久久久| 成人精品一区二区三区| 亚洲xxxxx电影| 97精品国产97久久久久久| 国产69精品久久久久久| 久久综合电影一区| 96pao国产成视频永久免费| 欧美日韩成人精品| 午夜精品久久久久久久白皮肤| 97碰在线观看| 国产精品观看在线亚洲人成网| 亚洲另类图片色| 国产一区二区三区免费视频| 91欧美精品成人综合在线观看| 精品国产999| 亚洲v日韩v综合v精品v| 久久久久国产精品一区| 国产精品电影一区| 亚洲欧美国产一区二区三区| 国产精品1区2区在线观看| 日韩亚洲综合在线| 亚洲欧美www| 欧美大全免费观看电视剧大泉洋| 日韩在线观看免费高清完整版| 国内精品在线一区| 91国内免费在线视频| 日韩福利在线播放| 欧美性猛交xxxx黑人猛交| 久久久精品久久久| 亚洲乱码av中文一区二区| 在线观看视频99| 欧洲美女免费图片一区| 亚洲欧洲一区二区三区在线观看| 亚洲日本欧美中文幕| 国产精品成人va在线观看| 亚洲精品电影网站| 中文字幕精品在线视频| 久久久久久国产精品美女| 亚洲福利视频二区| 久久久久久亚洲精品| 亚洲一区二区三区视频播放| 久99久在线视频| 欧美午夜影院在线视频| 亚洲一区二区久久久久久久| 在线观看欧美日韩| 日韩成人在线视频观看| www.欧美精品一二三区| 91嫩草在线视频| 日韩成人激情视频| 日韩视频免费在线观看| 91午夜理伦私人影院| 欧美国产乱视频| 国内精品久久久久久久| 欧美午夜激情视频| 91大神在线播放精品| 日韩精品小视频| 欧美大尺度激情区在线播放| 国产亚洲aⅴaaaaaa毛片| 欧美性xxxxxxx| 亚洲专区国产精品| 91精品视频在线免费观看| 亚洲欧美一区二区三区久久| 亚洲国产一区自拍| 美日韩精品视频免费看| 成人免费淫片视频软件| 亚洲精品欧美日韩| 欧美一区在线直播| 国内精品视频一区| 中文欧美日本在线资源| 欧美激情精品久久久久久免费印度| 欧美亚洲日本网站| 成人有码视频在线播放| 亚洲黄页网在线观看| 一区国产精品视频| www日韩欧美| 国产精品无码专区在线观看| 亚洲电影天堂av| 国产精品成人国产乱一区| 久久久精品999| 欧美精品久久久久久久久| 成人亚洲欧美一区二区三区| 在线日韩欧美视频| 中文字幕视频一区二区在线有码| 精品国产区一区二区三区在线观看| 91性高湖久久久久久久久_久久99| 国产精品成人一区二区| 97精品国产97久久久久久| 中文在线资源观看视频网站免费不卡| 2019中文字幕在线| 97视频在线观看亚洲| 亚洲美女喷白浆| 亚洲深夜福利视频| 亚洲日韩欧美视频| 久久香蕉国产线看观看av| 午夜精品理论片| 最新69国产成人精品视频免费| 91久久国产精品| 国产精品高精视频免费| 91在线观看免费高清|