成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

多線程場景下一種可靈活編排的軟件架構

開發 架構
說到現代大型軟件架構,很容易想到的就是分布式、緩存數據庫、負載均衡、資源虛擬化、微服務、組件等等。然而,如果你總是和我夸夸其談分布式、并行等各種花里胡哨的框架,卻不告訴我代碼怎么寫,那么你一定在耍流氓。

 引言

說到現代大型軟件架構,很容易想到的就是分布式、緩存數據庫、負載均衡、資源虛擬化、微服務、組件等等。然而,如果你總是和我夸夸其談分布式、并行等各種花里胡哨的框架,卻不告訴我代碼怎么寫,那么你一定在耍流氓。作為一個基層的軟件開發人員,更關心的是 main 函數該怎么寫、大量功能函數怎么分配到不同的線程上,而這才是最底層的軟件架構,也是最重要的。今天,我給大家介紹一種靈活的可編程軟件框架,可以說,這個框架能夠滿足絕大數場景下的軟件功能、性能及靈活性需求。

1 一個基本的軟件運行結構圖

 

多線程場景下一種可靈活編排的軟件架構

 

上圖中,

main 函數在主線程中,子線程 1 和子線程 2 都用來處理任務,任務存放在任務隊列中;

每個任務需要兩個階段才能完成,先經過階段 1 處理,再經過階段 2 處理;

階段 1 需要兩個函數處理,分別是函數 A 和函數 B;

階段 2 需要一個函數處理,即函數 C.

2 函數和隊列如何部署到不同的線程上?

 

多線程場景下一種可靈活編排的軟件架構

 

說到底,每個線程上運行的都是一些基本的功能函數,我們可以把實現某個功能的函數劃分到一個函數集合里。這個例子中,子線程 1 上運行的是函數集合 1,子線程 2 上運行的是函數集合 3.

 

多線程場景下一種可靈活編排的軟件架構

 

線程、函數集合、任務隊列的綁定關系圖

當線程上的函數從任務隊列取任務進行處理的時候,我們要明確以下幾點:

  • 同一個任務隊列可以被多個線程調度
  • 多個線程可以調度同一個任務隊列
  • 不同的函數集合可以部署在同一個線程上
  • 同一個函數集合也可以部署在不同線程上

線程、函數集合、任務隊列的具體綁定關系,我們可以靈活地寫在配置文件中,比如 json、yaml 等。在進程起來之后,通過加載配置文件的方式實現資源的部署。為什么一個線程上可以掛多個任務隊列呢?因為任務隊列可以有不同的類型呀,比如說系統任務,用戶業務等。

3 線程上的函數如何調度?

在業務線程實際運行的過程中,我們只會看到一個個函數,那如何控制函數的執行順序呢?最簡單的一種方案就是狀態機。線程每執行一個循環,從初始狀態開始,經過中間狀態,到最終狀態結束。任務到達每一種狀態時,就會進行相應的動作處理(即對應了一個有序的函數集合),根據任務處理的結果,選擇需要跳轉的下一個狀態,直到遇到最終狀態,當前任務處理結束。接著,從任務隊列上取下一個任務,循環調度。

 

多線程場景下一種可靈活編排的軟件架構

 

狀態機循環調度任務

4 線程起來之后,哪些函數集合會真正運行起來?

前文講到,在部署框架中指定了每個線程上需要運行哪些函數集合。但是,當線程實際起來之后,我們卻是根據狀態機進行調度,狀態機也指定了每個狀態需要執行哪些動作(也就是函數集合),那我們到底是執行部署框架中定義的函數集合還是執行狀態機中對應的函數集合呢?答案當然是狀態機中對應的函數集合呀。

總結

這篇文章中,我嘗試總結了一種基于多線程并行技術下的可靈活編排的軟件架構。這個架構核心的地方有兩點:一是資源部署(即隊列、函數、線程的綁定關系);二是基于狀態機原理進行調度,每個狀態處理之后如何選擇下個狀態,直接關系到軟件性能。朋友們,在摩爾定律失效、軟件性能要求越來越高的需求下,你們有更好的軟件架構,能實現 CPU 多核、多線程資源的最大化利用及高效的調度框架嗎?

責任編輯:華軒 來源: 今日頭條
相關推薦

2015-03-13 15:24:49

開源軟件代碼Github重定義

2022-07-13 11:49:18

接口遷移方案

2011-02-25 13:52:18

Proftpd管理

2011-02-25 13:52:18

Proftpd管理

2011-03-01 09:43:13

MapReduce架構

2023-10-24 09:03:05

C++編程

2022-04-06 12:00:46

HEAT安全架構新威脅

2022-06-20 14:03:11

區塊鏈可持續安全

2018-03-20 09:25:19

AI

2017-10-27 18:40:01

機器學習終身機器學習遷移學習

2022-11-24 08:00:00

2016-04-18 13:41:10

軟件IC網

2017-07-05 14:09:04

系統設計與架構java云計算

2020-12-09 10:15:34

Pythonweb代碼

2020-12-23 10:10:23

Pythonweb代碼

2022-07-07 10:33:27

Python姿勢代碼

2022-06-22 09:44:41

Python文件代碼

2023-12-04 08:21:18

虛擬線程Tomcat

2017-03-08 16:25:54

Linux多線程函數

2015-01-26 15:58:02

MDM應用指南
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一区二区在线观看 | 久久久区 | 日韩一区二区在线观看 | 91精品国产一区二区三区 | 国产免费观看久久黄av片涩av | 精品欧美乱码久久久久久1区2区 | av在线免费播放 | 99视频免费在线 | 亚洲区中文字幕 | 爱爱免费视频 | 久久精品国产免费一区二区三区 | 日韩1区| 另类专区亚洲 | 亚洲免费在线 | 综合色婷婷 | 久久久久九九九九 | 日本精品一区二区三区视频 | 91视频在线网站 | 国产成人99久久亚洲综合精品 | 成人免费小视频 | 少妇av片| 欧美日韩久久 | 日韩在线欧美 | 成人伊人网 | 亚洲 欧美 另类 日韩 | 亚洲精品乱码久久久久v最新版 | 中文字幕一区二区在线观看 | 亚洲激情在线观看 | 欧美色综合 | 欧日韩不卡在线视频 | 日韩中文字幕一区 | 91av视频在线播放 | 久久精品中文字幕 | 视频一区二区中文字幕 | 国产精品久久久久久 | 欧美黄色一区 | 中文字幕在线播放不卡 | 日韩在线精品强乱中文字幕 | 免费成人av| 欧美日韩精品中文字幕 | 成人在线精品视频 |