您好,登錄后才能下訂單哦!
這篇文章主要講解了“分享多線程場景下一種可靈活編排的軟件架構”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“分享多線程場景下一種可靈活編排的軟件架構”吧!
1 一個基本的軟件運行結構圖
上圖中,
main 函數在主線程中,子線程 1 和子線程 2 都用來處理任務,任務存放在任務隊列中;
每個任務需要兩個階段才能完成,先經過階段 1 處理,再經過階段 2 處理;
階段 1 需要兩個函數處理,分別是函數 A 和函數 B;
階段 2 需要一個函數處理,即函數 C.
2 函數和隊列如何部署到不同的線程上?
說到底,每個線程上運行的都是一些基本的功能函數,我們可以把實現某個功能的函數劃分到一個函數集合里。這個例子中,子線程 1 上運行的是函數集合 1,子線程 2 上運行的是函數集合 3.
線程、函數集合、任務隊列的綁定關系圖
當線程上的函數從任務隊列取任務進行處理的時候,我們要明確以下幾點:
同一個任務隊列可以被多個線程調度
多個線程可以調度同一個任務隊列
不同的函數集合可以部署在同一個線程上
同一個函數集合也可以部署在不同線程上
線程、函數集合、任務隊列的具體綁定關系,我們可以靈活地寫在配置文件中,比如 json、yaml 等。在進程起來之后,通過加載配置文件的方式實現資源的部署。為什么一個線程上可以掛多個任務隊列呢?因為任務隊列可以有不同的類型呀,比如說系統任務,用戶業務等。
3 線程上的函數如何調度?
在業務線程實際運行的過程中,我們只會看到一個個函數,那如何控制函數的執行順序呢?最簡單的一種方案就是狀態機。線程每執行一個循環,從初始狀態開始,經過中間狀態,到最終狀態結束。任務到達每一種狀態時,就會進行相應的動作處理(即對應了一個有序的函數集合),根據任務處理的結果,選擇需要跳轉的下一個狀態,直到遇到最終狀態,當前任務處理結束。接著,從任務隊列上取下一個任務,循環調度。
狀態機循環調度任務
4 線程起來之后,哪些函數集合會真正運行起來?
前文講到,在部署框架中指定了每個線程上需要運行哪些函數集合。但是,當線程實際起來之后,我們卻是根據狀態機進行調度,狀態機也指定了每個狀態需要執行哪些動作(也就是函數集合),那我們到底是執行部署框架中定義的函數集合還是執行狀態機中對應的函數集合呢?答案當然是狀態機中對應的函數集合呀。
感謝各位的閱讀,以上就是“分享多線程場景下一種可靈活編排的軟件架構”的內容了,經過本文的學習后,相信大家對分享多線程場景下一種可靈活編排的軟件架構這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。