精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

workflow:適合C++開發者進階的開源項目

嵌入式學習站 ? 來源:嵌入式學習站 ? 作者:嵌入式學習站 ? 2022-11-25 16:28 ? 次閱讀

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

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

項目適用場景

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

不僅如此,該項目也非常適合在嵌入式應用上實現網絡的框架設計,框架設計是一個項目成功與否非常重要的環節,而網絡在AIOT、智能家居智能硬件上尤其重要。

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

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

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

適用于嵌入式幾大特點:

1、支持多平臺、多體系結構

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

2、編譯快

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

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

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

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

4、運行時內存小、調度快

作為一個異步調度的庫,Workflow調度性能一直是?常好的。另外運?時內存占?也?常的小。

5、自定義協議非常方便

社區活躍以及項目負責人積極回復問題也是一個亮點,如果在框架搭建和移植上出現問題,在社區上提問都會得到快速響應。

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

移植到嵌入式設備的開源支持

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

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

框架能做什么

1、輕松的搭建server

不用多說,服務端框架如果不能搭建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、輕松高效的發起客戶端請求

項目號稱可作為萬能異步客戶端,目前支持http,redis,mysql、websocket和kafka協議,下面是官方給出的一個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時,可能使用的是傳統的客戶端。在一個線程下以同步阻塞的方式等待數據到來。如果有多個網絡請求希望并發,那么用戶需要管理好多個mysql cli對象。

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

支持自定義協議client/server:用戶可構建自己的RPC系統,搜狗有個開源項目srpc就是以這個框架為基礎實現的。

3、可建構異步任務流

支持串聯,支持并聯,支持串并聯的組合體,也支持復雜的DAG結構。

4、異步IO

在Linux系統下可作為文件異步IO工具使用,性能超過任何標準調用。

5、通信與計算一體化

多數框架都著重于網絡IO的效率問題,而計算與任務調度等需要用戶自己實現,workflow會自動對任務進行調度,打通網絡和磁盤等資源,特別適合需要網絡通信的重計算模塊。

任務流框架設計

在作者的設計理念中,一切業務邏輯皆是任務,多個任務會組成任務流,任務流可組成圖,這個圖可能是串聯圖、并聯圖,也可能是串并聯圖,類似于這種:

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

或者是這種復雜的DAG圖:

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

當然圖的層次結構可由用戶自定義,很牛的一點是支持動態創建任務流。

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

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5069

    文章

    19021

    瀏覽量

    303384
  • C++
    C++
    +關注

    關注

    22

    文章

    2104

    瀏覽量

    73498
  • workflows
    +關注

    關注

    0

    文章

    6

    瀏覽量

    5919

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

文章出處:【微信號:嵌入式學習站,微信公眾號:嵌入式學習站】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

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

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

    開源共生 商業共贏 | RT-Thread 2024開發者大會報名啟動!

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

    KaihongOS 4.1.2開發者預覽版正式上線,誠邀開發者免費試用!

    深開鴻在2024開放原子開源生態大會上正式宣布KaihongOS4.1.2開發者預覽版全面上線,并向全球開發者開放免費下載。作為KaihongOS不斷創新與發展的重要里程碑,此次預覽版為開發者
    的頭像 發表于 09-28 08:07 ?298次閱讀
    KaihongOS 4.1.2<b class='flag-5'>開發者</b>預覽版正式上線,誠邀<b class='flag-5'>開發者</b>免費試用!

    2023 開放原子開發者大會:賦予開發者高光時刻 推進開源生態健康發展

    今天,我們擁抱美好的開源時代,更期待開源的蓬勃未來。今天,我們聚焦開發者的時代價值,更攜手行業之力,為其提供肥沃的成長土壤和夢想的施展舞臺。 年終歲末,2023 開放原子開發者大會,在
    的頭像 發表于 12-22 10:18 ?358次閱讀
    2023 開放原子<b class='flag-5'>開發者</b>大會:賦予<b class='flag-5'>開發者</b>高光時刻 推進<b class='flag-5'>開源</b>生態健康發展

    開源治理與開發者運營分論壇圓滿舉辦

    日益受到廣泛關注。 為深度探討全球開源治理所面對的挑戰,12 月 16 日,2023 開放原子開發者大會【開源治理與開發者運營論壇】成功舉辦,論壇聚焦
    的頭像 發表于 12-22 09:59 ?461次閱讀
    <b class='flag-5'>開源</b>治理與<b class='flag-5'>開發者</b>運營分論壇圓滿舉辦

    大咖云集,2023 開放原子開發者大會助力開發者實現夢想

    ? ? 12 月 16 日,以“一切為了開發者”為主題的開放原子開發者大會在無錫開幕。大會聚焦大模型、云原生、前端、自動駕駛、物聯網、開源治理與開發者運營等多內容,匯聚頂尖
    的頭像 發表于 12-22 09:57 ?838次閱讀
    大咖云集,2023 開放原子<b class='flag-5'>開發者</b>大會助力<b class='flag-5'>開發者</b>實現夢想

    2023 開放原子開發者大會全日程

    ,基金會做出了哪些成績? · 開源在科技領域的發展趨勢是什么? · 開源可以在哪些領域發揮更大作用的地方? 開源如何助力開發者個人成長? · 開源
    的頭像 發表于 12-21 15:06 ?290次閱讀
    2023 開放原子<b class='flag-5'>開發者</b>大會全日程

    「代碼舞」2023 開放原子開發者大會——開源大俠秘聞

    ? ? ? 2023 開放原子開發者大會 OPEN ATOM DEVELOPERS CONFERENCE 開源大俠 隆重登場 ? 2023.12.16-17 ? 各位技術奇才和編程大咖們,準備好
    的頭像 發表于 12-20 16:48 ?402次閱讀
    「代碼舞<b class='flag-5'>者</b>」2023 開放原子<b class='flag-5'>開發者</b>大會——<b class='flag-5'>開源</b>大俠秘聞

    觸覺智能亮相2023開放原子開發者大會 創新引領開源新篇章

    12月16日,2023開放原子開發者大會在無錫盛大舉行,此次大會將通過多樣的活動形式,全方位為開發者賦能,共設置1場開幕式主論壇、1場開源大賽決賽、1場編程馬拉松、15場技術平行專場、3大專題大會
    的頭像 發表于 12-19 08:32 ?485次閱讀
    觸覺智能亮相2023開放原子<b class='flag-5'>開發者</b>大會  創新引領<b class='flag-5'>開源</b>新篇章

    大咖云集,2023開放原子開發者大會助力開發者實現夢想

    12月16日,以“一切為了開發者”為主題的開放原子開發者大會在無錫開幕。大會聚焦大模型、云原生、前端、自動駕駛、物聯網、開源治理與開發者運營等多內容,匯聚頂尖
    的頭像 發表于 12-18 16:05 ?513次閱讀

    鴻智谷亮相2023開放原子開發者大會

    12月16日-17日,2023開放原子開發者大會在無錫落下帷幕,作為開放原子開源基金會的年度盛典,以“一切為了開發者”為主題,聚焦開發者感興趣熱點內容,使參會
    的頭像 發表于 12-18 08:30 ?518次閱讀
    鴻智谷亮相2023開放原子<b class='flag-5'>開發者</b>大會

    2023開放原子開發者大會全日程

    ,基金會做出了哪些成績? · 開源在科技領域的發展趨勢是什么? · 開源可以在哪些領域發揮更大作用的地方? 開源如何助力開發者個人成長? · 開源
    的頭像 發表于 12-16 16:10 ?373次閱讀
    2023開放原子<b class='flag-5'>開發者</b>大會全日程

    歡迎加入飛騰派開發者社區,感謝每一位開發者

    板緊密地結合在一起,為開發者提供了一個展示和分享自己才華的平臺。 基于此次合作,飛騰(廣州)技術有限公司給華秋 · 電子發燒友發來了感謝信,這是對此次合作的充分肯定! 來自飛騰派項目組的感謝信
    發表于 12-11 16:11

    「代碼舞」2023開放原子開發者大會——開源大俠秘聞

    2023開放原子開發者大會 . OPEN ATOM DEVELOPERS CONFERENCE 開源大俠 隆重登場 2023.12.16-17 各位技術奇才和編程大咖們,準備好了嗎? 讓我們躍馬揚鞭
    的頭像 發表于 11-30 20:55 ?513次閱讀
    「代碼舞<b class='flag-5'>者</b>」2023開放原子<b class='flag-5'>開發者</b>大會——<b class='flag-5'>開源</b>大俠秘聞

    開箱即用!教你如何正確使用華為云CodeArts IDE for C/C++

    華為云CodeArts IDE 定位華為云開發者桌面 ,是華為云面向開發者提供的一款智能化桌面集成開發環境。CodeArts IDE for C/C
    的頭像 發表于 11-29 17:40 ?760次閱讀
    開箱即用!教你如何正確使用華為云CodeArts IDE for <b class='flag-5'>C</b>/<b class='flag-5'>C++</b>!