[發明專利]任務管線執行方法、裝置及電子設備有效
| 申請號: | 202010401618.4 | 申請日: | 2020-05-13 |
| 公開(公告)號: | CN111625326B | 公開(公告)日: | 2023-06-27 |
| 發明(設計)人: | 白戈;王長虎 | 申請(專利權)人: | 北京字節跳動網絡技術有限公司 |
| 主分類號: | G06F9/48 | 分類號: | G06F9/48;G06F9/50;G06F9/4401;G06F9/445;G06F9/455 |
| 代理公司: | 北京風雅頌專利代理有限公司 11403 | 代理人: | 車英慧 |
| 地址: | 100041 北京市石景山區*** | 國省代碼: | 北京;11 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 任務 管線 執行 方法 裝置 電子設備 | ||
1.一種任務管線執行方法,其特征在于,包括:
在任務容器中設置與主進程隔離設置的多個子進程,每個子進程用于執行一個管線任務;
在獲取到主進程相關的待執行任務之后,從所述多個子進程中選擇一個目標子進程,所述目標子進程用于運行所述待執行任務;
在所述目標子進程中的待執行任務執行完成之后,按照預設的策略執行與所述目標子進程相關的關聯子進程中的任務;
在所述容器中所有的子進程中的任務執行完畢之后,釋放所述所有的子進程在執行任務的過程中所占用的系統資源;
其中,在所述按照預設的策略執行與所述目標子進程相關的關聯子進程中的任務之前,所述方法還包括:
在所述目標子進程中預先加載所述關聯子進程所對應的程序模塊;
將加載后的程序模塊與所述關聯子進程進行綁定處理。
2.根據權利要求1所述的方法,其特征在于,所述在任務容器中設置與主進程隔離設置的多個子進程之前,所述方法包括:
在喚醒主進程喚醒之后,判斷是否存在容器配置文件;
若存在,則進一步基于所述容器系統配置文件,判斷所述任務容器是否存在;
若不存在,則主進程創建容器設立子進程,利用所述容器設立子進程創建所述任務容器;
若存在,則主進程將包裝好的啟動消息發送給任務啟動子進程,任務啟動子進程解包發送過來的消息,得到啟動容器消息實體,開始啟動所述任務容器。
3.根據權利要求1所述的方法,其特征在于,所述在任務容器中設置與主進程隔離設置的多個子進程,包括:
設置所述任務容器的內核資源隔離參數,更新配置文件;
根據更新后的配置文件開啟資源隔離機制,設置父子進程隔離屬性;
創建任務容器子進程,所述子進程用于任務進程實體加載到子進程中。
4.根據權利要求1所述的方法,其特征在于,所述在獲取到主進程相關的待執行任務之后,從所述多個子進程中選擇一個目標子進程,包括:
獲取所述主進程需要執行的任務列表;
確定所述任務列表中每個任務的執行順序;
基于所述執行順序,將確定所述多個子進程的執行順序;
基于所述子進程的執行順序,確定與當前任務匹配的目標子進程。
5.根據權利要求1所述的方法,其特征在于,所述在獲取到主進程相關的待執行任務之后,從所述多個子進程中選擇一個目標子進程,包括:
獲取當前待執行任務的任務ID;
從所述多個子進程中選擇與所述任務ID相匹配的子進程作為所述目標子進程。
6.根據權利要求1所述的方法,其特征在于,所述按照預設的策略執行與所述目標子進程相關的關聯子進程中的任務,包括:
對所述目標子進程的執行狀態進行監控;
判斷是否存在所述目標子進程的任務完成標志;
若存在,則進一步啟動并執行所述關聯子進程中的預先加載的程序模塊。
7.根據權利要求1所述的方法,其特征在于,所述釋放所述所有的子進程在執行任務的過程中所占用的系統資源,包括:
獲取所有子進程在執行任務過程中所占用的內存地址空間;
對所述內存地址空間中的數據執行釋放操作。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于北京字節跳動網絡技術有限公司,未經北京字節跳動網絡技術有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/202010401618.4/1.html,轉載請聲明來源鉆瓜專利網。





