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

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

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

3天內不再提示

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

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

掃碼添加小助手

加入工程師交流群

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

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

項目適用場景

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

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

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

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

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

適用于嵌入式幾大特點:

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

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

2、編譯快

Workflow除OpenSSL以外不依賴其他庫,?且在接口層是沒有模版的,因此編譯速度???欤坏揭环昼娂纯删幊鲆粋€可?的lib。

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

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

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

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

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

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

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

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、輕松高效的發(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)的客戶端。在一個線程下以同步阻塞的方式等待數據到來。如果有多個網絡請求希望并發(fā),那么用戶需要管理好多個mysql cli對象。

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

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

3、可建構異步任務流

支持串聯(lián),支持并聯(lián),支持串并聯(lián)的組合體,也支持復雜的DAG結構。

4、異步IO

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

5、通信與計算一體化

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

任務流框架設計

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

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

或者是這種復雜的DAG圖:

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

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

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

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

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

    關注

    5193

    文章

    20274

    瀏覽量

    331717
  • C++
    C++
    +關注

    關注

    22

    文章

    2123

    瀏覽量

    76873
  • workflows
    +關注

    關注

    0

    文章

    6

    瀏覽量

    6117

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    2025全球開發(fā)者先鋒大會開源項目與AI的雙向賦能分論壇圓滿舉辦

    12月12日,2025全球開發(fā)者先鋒大會——開源項目與AI的雙向賦能分論壇在上海張江科學會堂成功舉行。論壇以“共生共榮,智創(chuàng)未來”為主題,匯聚開放原子開源基金會、華為、中國移動、深開鴻
    的頭像 發(fā)表于 12-22 15:58 ?374次閱讀

    CC++之間的聯(lián)系

    ,后來才逐漸演變?yōu)橐环N成熟的面向對象編程語言。 總之,C語言和C++雖然有很多共同之處,但在編程范式、安全性、抽象層次等方面存在顯著差異。開發(fā)者可以根據項目需求選擇合適的語言,
    發(fā)表于 12-11 06:51

    開發(fā)者為核心驅動開源項目邁向成熟

    11月21-22日,以“一切為了開發(fā)者——AI共智·開源共享”為主題的2025開放原子開源開發(fā)者大會在北京成功舉辦。大會聚焦人工智能、基礎軟件等重點方向,來自產業(yè)界、高校、科研機構和
    的頭像 發(fā)表于 12-04 10:09 ?615次閱讀

    2025開放原子開發(fā)者大會初創(chuàng)與高潛開源項目發(fā)展分論壇成功舉辦

    近日,2025開放原子開發(fā)者大會——初創(chuàng)和高潛項目分論壇在北京成功舉辦。這場聚焦行業(yè)新生力量的專業(yè)盛會,匯聚了開源領域資深實踐、初創(chuàng)項目
    的頭像 發(fā)表于 12-04 10:05 ?614次閱讀

    2025開源鴻蒙開發(fā)者激勵計劃正式啟動

    11月21日,2025開放原子開發(fā)者大會盛大啟幕,聚焦“AI共智,開源共享”主題,吸引了來自全球的開發(fā)者、企業(yè)技術領袖、社區(qū)維護及高校科研力量參會。作為大會的重要組成部分,
    的頭像 發(fā)表于 11-27 14:44 ?561次閱讀

    RT-Thread榮膺開放原子開源先鋒項目,社區(qū)開發(fā)者斬獲“開源貢獻之星”|新聞速遞

    近日,2025開放原子開發(fā)者大會在京開幕。大會舉行了“中國開源創(chuàng)新力量致謝儀式”,向操作系統(tǒng)、數據庫、人工智能三大技術領域28個開源先鋒項目中作出卓越貢獻的47位
    的頭像 發(fā)表于 11-24 18:48 ?392次閱讀
    RT-Thread榮膺開放原子<b class='flag-5'>開源</b>先鋒<b class='flag-5'>項目</b>,社區(qū)<b class='flag-5'>開發(fā)者</b>斬獲“<b class='flag-5'>開源</b>貢獻之星”|新聞速遞

    2025開放原子開發(fā)者大會初創(chuàng)與高潛開源項目發(fā)展分論壇即將啟幕

    開源生態(tài)蓬勃發(fā)展的當下,一批技術創(chuàng)新性強、成長潛力大的開源項目正嶄露頭角。為賦能更多“潛能之星”,傳遞可復用的解決方案與行動路徑,2025開放原子開發(fā)者大會——初創(chuàng)與高潛
    的頭像 發(fā)表于 11-20 11:39 ?640次閱讀

    2025開放原子開發(fā)者大會AtomGit開源實踐交流分論壇即將開啟

    當前,全球開源生態(tài)正持續(xù)蓬勃發(fā)展,開發(fā)者協(xié)作模式與開源創(chuàng)新范式也隨之經歷深刻變革。在此趨勢下,以開發(fā)者為中心的AtomGit,創(chuàng)新融合“開源
    的頭像 發(fā)表于 11-17 16:32 ?885次閱讀

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

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

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

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

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

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

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

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

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

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

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

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

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

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