chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

workflow:適合C++開發(fā)者進(jìn)階的開源項目

嵌入式學(xué)習(xí)站 ? 來源:嵌入式學(xué)習(xí)站 ? 作者:嵌入式學(xué)習(xí)站 ? 2022-11-25 16:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

今天分享一個適合C++開發(fā)者進(jìn)階的開源項目,這個項目的名字叫workflow,項目地址如下:https://github.com/sogou/workflow

a4c940ae-6b11-11ed-8abf-dac502259ad0.png

項目適用場景

該項目是搜狗的服務(wù)器引擎,幾乎搜狗所有的后端C++服務(wù)和其他幾十家公司都在使用這個引擎,每日處理超百億請求。

不僅如此,該項目也非常適合在嵌入式應(yīng)用上實現(xiàn)網(wǎng)絡(luò)的框架設(shè)計,框架設(shè)計是一個項目成功與否非常重要的環(huán)節(jié),而網(wǎng)絡(luò)在AIOT、智能家居、智能硬件上尤其重要。

比如在項目中需要使用http,Workflow在設(shè)計上可以通過Cmake配置支持windows 或者 Linux 或 MacOS 等多個平臺上的多個項目編譯,而且,可以在不同平臺上保持相同的接口

如果你新增一個嵌入式設(shè)備,比如ESP32,在服務(wù)器和客戶端只需要維護(hù)一套代碼,就可以完成自己的應(yīng)用需求。

真正做到把云端的技術(shù)移植到嵌入式設(shè)備上運行。

適用于嵌入式幾大特點:

1、支持多平臺、多體系結(jié)構(gòu)

多平臺的代碼說明在配置和耦合上考慮了很多設(shè)計上的細(xì)節(jié)。?前Workflow除了Linux、Windows、MacOS、Android以外,還可以愉快地在樹莓派、國產(chǎn)?芯處理器等不同體系結(jié)構(gòu)上運?。

2、編譯快

Workflow除OpenSSL以外不依賴其他庫,?且在接口層是沒有模版的,因此編譯速度?常快,不到一分鐘即可編出一個可?的lib。

3、體積小、支持編譯剪裁

Workflow的Kafka協(xié)議默認(rèn)是不編譯的,除此之外,還可以裁剪掉其他不常?的模塊。

并且可以通過strip命令去掉符號鏈接,即可讓庫?件縮?到400k左右。

4、運行時內(nèi)存小、調(diào)度快

作為一個異步調(diào)度的庫,Workflow調(diào)度性能一直是?常好的。另外運?時內(nèi)存占?也?常的小。

5、自定義協(xié)議非常方便

社區(qū)活躍以及項目負(fù)責(zé)人積極回復(fù)問題也是一個亮點,如果在框架搭建和移植上出現(xiàn)問題,在社區(qū)上提問都會得到快速響應(yīng)。

a506848c-6b11-11ed-8abf-dac502259ad0.png

移植到嵌入式設(shè)備的開源支持

據(jù)悉?前已經(jīng)有許多?戶?到了嵌?式上了。github官方也做出了耐心的解釋。

a5246c5e-6b11-11ed-8abf-dac502259ad0.png

框架能做什么

1、輕松的搭建server

不用多說,服務(wù)端框架如果不能搭建server那還玩啥了,但使用這個框架非常方便,以http server為例,只需要簡單幾行代碼即可:

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

2、輕松高效的發(fā)起客戶端請求

項目號稱可作為萬能異步客戶端,目前支持http,redis,mysql、websocket和kafka協(xié)議,下面是官方給出的一個mysql的客戶端示例:

int main(int argc, char *argv[]) { ... WFMySQLTask *task = WFTaskFactory::create_mysql_task(url, RETRY_MAX, mysql_callback); task->get_req()->set_query("SHOW TABLES;"); ... task->start(); ... }

以往的C++ server需要訪問mysql時,可能使用的是傳統(tǒng)的客戶端。在一個線程下以同步阻塞的方式等待數(shù)據(jù)到來。如果有多個網(wǎng)絡(luò)請求希望并發(fā),那么用戶需要管理好多個mysql cli對象。

workflow完美的解決了這一系列問題,把所有這種用戶請求交給內(nèi)部的poller線程統(tǒng)一管理,實現(xiàn)了高效的非阻塞IO行為,提升了server作為客戶端請求數(shù)據(jù)時的性能表現(xiàn)。再也不用擔(dān)心這種客戶端行為影響server整體的性能。

支持自定義協(xié)議client/server:用戶可構(gòu)建自己的RPC系統(tǒng),搜狗有個開源項目srpc就是以這個框架為基礎(chǔ)實現(xiàn)的。

3、可建構(gòu)異步任務(wù)流

支持串聯(lián),支持并聯(lián),支持串并聯(lián)的組合體,也支持復(fù)雜的DAG結(jié)構(gòu)。

4、異步IO

在Linux系統(tǒng)下可作為文件異步IO工具使用,性能超過任何標(biāo)準(zhǔn)調(diào)用。

5、通信與計算一體化

多數(shù)框架都著重于網(wǎng)絡(luò)IO的效率問題,而計算與任務(wù)調(diào)度等需要用戶自己實現(xiàn),workflow會自動對任務(wù)進(jìn)行調(diào)度,打通網(wǎng)絡(luò)和磁盤等資源,特別適合需要網(wǎng)絡(luò)通信的重計算模塊。

任務(wù)流框架設(shè)計

在作者的設(shè)計理念中,一切業(yè)務(wù)邏輯皆是任務(wù),多個任務(wù)會組成任務(wù)流,任務(wù)流可組成圖,這個圖可能是串聯(lián)圖、并聯(lián)圖,也可能是串并聯(lián)圖,類似于這種:

a5513f72-6b11-11ed-8abf-dac502259ad0.png

或者是這種復(fù)雜的DAG圖:

a589510a-6b11-11ed-8abf-dac502259ad0.png

當(dāng)然圖的層次結(jié)構(gòu)可由用戶自定義,很牛的一點是支持動態(tài)創(chuàng)建任務(wù)流。

分享結(jié)束,希望小伙伴喜歡,嵌入式真需要不斷學(xué)習(xí)去充實自己的大腦,相信你們都能夠成為最厲害的程序員

最近很多小伙伴領(lǐng)取了程序員知識圖譜,反饋很好。我們知道每一個技術(shù)領(lǐng)域都有它完整地知識體系,而良好的知識體系有助于技術(shù)人員的發(fā)展和成長,減少學(xué)習(xí)過程中所走的彎路。所以還沒有領(lǐng)取的小伙伴趕緊領(lǐng)取起來吧!(底部有領(lǐng)取入口哦)

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5175

    文章

    19973

    瀏覽量

    324378
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2120

    瀏覽量

    76452
  • workflows
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    6093

原文標(biāo)題:分享一個適合嵌入式的C++開源項目-Workflow

文章出處:【微信號:嵌入式學(xué)習(xí)站,微信公眾號:嵌入式學(xué)習(xí)站】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    開發(fā)者眼中的開源魅力

    、openKylin、OpenTenBase開源項目社區(qū)的開發(fā)者,聆聽他們與開源相遇、相伴、相成長的故事,感受那份超越代碼本身的價值與魅力。
    的頭像 發(fā)表于 06-24 11:38 ?583次閱讀

    從“開發(fā)者孤島”到“生態(tài)星河”:開鴻Bot如何重構(gòu)開源鴻蒙開發(fā)體驗

    在中國操作系統(tǒng)發(fā)展史上,“開發(fā)者”似乎從來都是一個邊緣角色。他們是開源社區(qū)中最活躍的群體,卻也是最常被忽視的那群人。具體到開源鴻蒙社區(qū),其生態(tài)構(gòu)建初期,諸多開發(fā)者曾坦言,“鴻蒙很好,但
    的頭像 發(fā)表于 06-10 17:12 ?1252次閱讀
    從“<b class='flag-5'>開發(fā)者</b>孤島”到“生態(tài)星河”:開鴻Bot如何重構(gòu)<b class='flag-5'>開源</b>鴻蒙<b class='flag-5'>開發(fā)</b>體驗

    潤和軟件旗下潤開鴻亮相開源鴻蒙開發(fā)者大會2025

    近日,開源鴻蒙開發(fā)者大會2025(OHDC.2025)于深圳再啟新篇,會上正式發(fā)布了開源鴻蒙5.1 Release版本,并進(jìn)行開源鴻蒙應(yīng)用技術(shù)組件共建啟動等重要儀式,面向
    的頭像 發(fā)表于 06-03 16:22 ?1211次閱讀

    華為亮相2025開源鴻蒙開發(fā)者大會

    近日,開源鴻蒙開發(fā)者大會2025(以下簡稱大會)在深圳成功舉辦。大會以開源鴻蒙5.1 Release版本發(fā)布為契機,聚焦開源鴻蒙技術(shù)革新和社區(qū)發(fā)展,全面呈現(xiàn)“Powered
    的頭像 發(fā)表于 05-29 09:07 ?843次閱讀

    開發(fā)者分享】開源硬核玩家集結(jié):這些MCU板子泰酷了!

    前言本篇文章內(nèi)容主要收錄了由開發(fā)者基于先楫半導(dǎo)體高性能MCU開發(fā)的各類DIY開源硬件項目,涵蓋不同應(yīng)用方向與創(chuàng)意實踐。部分項目代碼可直接在本
    的頭像 發(fā)表于 05-26 17:31 ?1094次閱讀
    【<b class='flag-5'>開發(fā)者</b>分享】<b class='flag-5'>開源</b>硬核玩家集結(jié):這些MCU板子泰酷了!

    2025開源鴻蒙開發(fā)者大會圓滿落幕

    近日,開源鴻蒙開發(fā)者大會2025(OHDC.2025,簡稱“大會”)在深圳隆重開幕。大會正式發(fā)布了開源鴻蒙5.1 Release版本,舉行了開源鴻蒙應(yīng)用技術(shù)組件共建啟動、
    的頭像 發(fā)表于 05-26 17:03 ?876次閱讀

    深開鴻CEO王成錄:開發(fā)者開源鴻蒙生態(tài)的原點

    5月24日,深開鴻正式發(fā)布全國首款面向開發(fā)者開源鴻蒙學(xué)習(xí)平臺——開鴻Bot系列產(chǎn)品。這是開源鴻蒙在開發(fā)者終端領(lǐng)域的關(guān)鍵落地,更是深開鴻貫徹“以開發(fā)
    的頭像 發(fā)表于 05-26 12:06 ?595次閱讀
    深開鴻CEO王成錄:<b class='flag-5'>開發(fā)者</b>是<b class='flag-5'>開源</b>鴻蒙生態(tài)的原點

    蘋果開源Swift Build,強化開發(fā)者生態(tài)建設(shè)

    近日,蘋果公司宣布了一項重大決策:將用于構(gòu)建Xcode開發(fā)環(huán)境的工具引擎Swift Build進(jìn)行開源。這一舉措不僅展現(xiàn)了蘋果對于開發(fā)者社區(qū)的深度關(guān)注,更彰顯了其致力于拓展和優(yōu)化開發(fā)者
    的頭像 發(fā)表于 02-05 15:03 ?673次閱讀

    開發(fā)者開源鴻蒙故事

    近日,在以“一切為了開發(fā)者”為主題的“2024開放原子開發(fā)者大會暨首屆開源技術(shù)學(xué)術(shù)大會”上,開源鴻蒙5.0 Release版本正式發(fā)布,備受各方關(guān)注。該版本在系統(tǒng)完備度、分布式創(chuàng)新、
    的頭像 發(fā)表于 01-06 10:28 ?1096次閱讀

    AKI跨語言調(diào)用庫神助攻C/C++代碼遷移至HarmonyOS NEXT

    ,真正做到所“鍵”即所得。 這一創(chuàng)新框架的出現(xiàn),正是為了解決開發(fā)者在遷移C/C++項目到HarmonyOS NEXT時面臨的核心痛點。傳統(tǒng)的NAPI接口調(diào)用復(fù)雜,學(xué)習(xí)成本高,
    發(fā)表于 01-02 17:08

    2024開放原子開發(fā)者大會暨首屆開源技術(shù)學(xué)術(shù)大會成功舉辦

    近日,以“一切為了開發(fā)者”為主題的2024開放原子開發(fā)者大會暨首屆開源技術(shù)學(xué)術(shù)大會在武漢成功舉辦。大會為眾多開源項目
    的頭像 發(fā)表于 12-23 14:23 ?718次閱讀

    2024年度國內(nèi)活躍開源項目開發(fā)者在武漢揭曉

    近日,2024年度國內(nèi)活躍開源項目&開發(fā)者致謝儀式,亮相2024開放原子開發(fā)者大會暨首屆開源技術(shù)學(xué)術(shù)大會開幕式。
    的頭像 發(fā)表于 12-23 11:25 ?803次閱讀

    高校開源開發(fā)者培養(yǎng)分論壇亮點前瞻

    數(shù)字化時代,開源成為了全球軟件與技術(shù)創(chuàng)新的重要驅(qū)動力,從Linux操作系統(tǒng)到Android移動平臺,從人工智能框架到云計算基礎(chǔ)設(shè)施,一個個開源項目遍地開花。然而,在開源蓬勃發(fā)展的背后,
    的頭像 發(fā)表于 12-17 14:06 ?682次閱讀

    簡儀科技第九屆開源測控開發(fā)者大會精彩回顧

    由簡儀科技主辦的第九屆開源測控開發(fā)者大會,近日在上海圓滿落幕。
    的頭像 發(fā)表于 11-19 09:16 ?1025次閱讀

    開源共生 商業(yè)共贏 | RT-Thread 2024開發(fā)者大會報名啟動!

    開發(fā)者大會將以“開源共生,商業(yè)共贏”為主題,將于2024年12月21日全天在上海臨港中心舉行。開源RT-Thread如何實現(xiàn)商業(yè)化?這一直是外界對RT-Thread最
    的頭像 發(fā)表于 10-29 08:06 ?1154次閱讀
    <b class='flag-5'>開源</b>共生 商業(yè)共贏 | RT-Thread 2024<b class='flag-5'>開發(fā)者</b>大會報名啟動!