欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

10行C++代碼實(shí)現(xiàn)高性能HTTP服務(wù)

 更新時(shí)間:2021年04月28日 14:52:47   作者:Kevin Wan  
這篇文章主要介紹了10行C++代碼如何實(shí)現(xiàn)高性能HTTP服務(wù),幫助大家更好的理解和學(xué)習(xí)使用c++,感興趣的朋友可以了解下

前言

是不是覺得C++寫個(gè)服務(wù)太累,但又沉迷于C++的真香性能而無(wú)法自拔?作為一個(gè)老牌C++程序員(可以看我 github 上十幾年前的C++項(xiàng)目:https://github.com/kevwan ),這幾天聽一個(gè)好友跟我聊起他寫的C++框架,說(shuō)極簡(jiǎn)代碼即可完成各種C++服務(wù)的開發(fā),不禁讓我心生好奇!于是我去研究了一下,發(fā)現(xiàn)確實(shí)有點(diǎn)意思!

實(shí)戰(zhàn)(干貨)

話不多說(shuō),我們來(lái)一起看看,10行C++代碼怎么實(shí)現(xiàn)一個(gè)高性能的Http服務(wù),輕松QPS幾十萬(wàn)。Linus說(shuō):talk is cheap,show me the code ↓

int main() {
    WFHttpServer server([](WFHttpTask *task) {
        task->get_resp()->append_output_body("Hello World!");
    });
    if (server.start(8888) == 0) {
        getchar(); // press "Enter" to end.
        server.stop();
    }
    return 0;
}

這個(gè) server 使用了 workflow,安裝編譯都非常簡(jiǎn)單,以 Linux 為例,把代碼拉下來(lái)后,一行命令即搞定編譯:

➜ git clone https://github.com/sogou/workflow
➜ cd workflow
➜ make
➜ cd tutorial
➜ make
➜ ./helloworld

代碼在 tutorial 目錄,編譯后的 helloworld 可以直接運(yùn)行,偵聽在 8888 端口,curl 即可訪問(wèn):

➜ curl -i http://localhost:8888
HTTP/1.1 200 OK
Content-Length: 25
Connection: Keep-Alive

Hello World!

伴隨著以上這10行代碼,我們?cè)敿?xì)地解讀:

  1. 我們選用 Http 協(xié)議,因此構(gòu)造了一個(gè)WFHttpServer;
  2. 一次網(wǎng)絡(luò)交互就是一次任務(wù),因?yàn)槭?Http 協(xié)議,因此我們是WFHttpTask;
  3. 對(duì)server來(lái)說(shuō),我的交互任務(wù)就是收到請(qǐng)求之后,填好回復(fù),這些通過(guò):task->get_req()task->get_resp()可以獲得;
  4. 邏輯在一個(gè)函數(shù)中(即上面的 lambda),表示收到消息之后要做的事情,這里填了一句 “Hello World!”;
  5. Server啟動(dòng)和退出使用start()和stop()兩個(gè)簡(jiǎn)單的api,而中間要用getchar();卡住,是因?yàn)?workflow 是個(gè)純異步的框架。

純異步就是這個(gè) Http 服務(wù)器的高性能所在:

  • 第一,多線程提供服務(wù)

如果我們收到請(qǐng)求之后在這個(gè)函數(shù)里做了一些阻塞的事情(比如等鎖、io請(qǐng)求或者忙碌的計(jì)算等),那么再有用戶請(qǐng)求我的時(shí)候,我就沒有線程去處理新用戶了

  • 第二,網(wǎng)絡(luò)線程和執(zhí)行線程有優(yōu)秀的調(diào)度策略

再多的線程也可能會(huì)有被霸占完的時(shí)候。我們需要無(wú)論 server 函數(shù)想要做任何耗時(shí)的操作,都不會(huì)影響到網(wǎng)絡(luò)線程

  • 第三,以 linux 為例,對(duì)epoll的封裝高效好用

如果服務(wù)只打算支持一萬(wàn)的QPS,其實(shí)底層怎么實(shí)現(xiàn)都很簡(jiǎn)單,但如果我們希望十萬(wàn),甚至接近百萬(wàn),則我們對(duì)server底層做收發(fā)的I/O模型有非常高的要求

我們來(lái)看看 workflow 是怎么來(lái)實(shí)現(xiàn)以上這些高并發(fā)能力:

基于以上的架構(gòu),基于 workflow 的 server 輕輕松松就可以達(dá)到幾十萬(wàn) QPS,高吞吐、低成本、開發(fā)快,完美支撐了搜狗的所有后端在線服務(wù)!詳細(xì)代碼實(shí)現(xiàn)請(qǐng)參考 workflow 源碼。然后我們以數(shù)據(jù)說(shuō)話,通過(guò)跟名譽(yù)全球的高性能 Http 服務(wù)器 nginx 和國(guó)內(nèi)開源框架先驅(qū) brpc 一起做比較,看一下固定數(shù)據(jù)長(zhǎng)度下 QPS 與并發(fā)度的關(guān)系:

以上是在同一臺(tái)機(jī)器上用相同的變量做的 wrk 壓測(cè),具體可以到 github 查看機(jī)器配置、參數(shù)及壓測(cè)工具代碼。當(dāng)數(shù)據(jù)長(zhǎng)度保持不變,QPS 隨著并發(fā)度提高而增大,后趨于平穩(wěn)。此過(guò)程中 workflow 一直有明顯優(yōu)勢(shì),高于 nginx 和 brpc。 特別是數(shù)據(jù)長(zhǎng)度為64和512的兩條曲線, 并發(fā)度足夠的時(shí)候,可以保持50W的QPS。

總結(jié)

workflow 能在開源大半年在github上收獲4k星星的認(rèn)可,當(dāng)然是除了簡(jiǎn)單和高性能以外,還有其他許多的特點(diǎn),如果你對(duì)其他使用場(chǎng)景還有所好奇,或者希望嘗試壓測(cè)一下感受高QPS帶來(lái)的心跳加速,那么歡迎點(diǎn)擊 workflow 的 github 獵奇更多腦洞大開的功能和用法。

項(xiàng)目地址

https://github.com/sogou/workflow

歡迎使用 workflow 并 star 支持一下!

以上就是10行C++代碼實(shí)現(xiàn)高性能HTTP服務(wù)的詳細(xì)內(nèi)容,更多關(guān)于c++實(shí)現(xiàn)高性能HTTP服務(wù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論