JP7188472B2 - コンピュータ、スケジューリング方法、及び、プログラム - Google Patents
コンピュータ、スケジューリング方法、及び、プログラム Download PDFInfo
- Publication number
- JP7188472B2 JP7188472B2 JP2021015377A JP2021015377A JP7188472B2 JP 7188472 B2 JP7188472 B2 JP 7188472B2 JP 2021015377 A JP2021015377 A JP 2021015377A JP 2021015377 A JP2021015377 A JP 2021015377A JP 7188472 B2 JP7188472 B2 JP 7188472B2
- Authority
- JP
- Japan
- Prior art keywords
- thread
- core
- worker
- threads
- queue
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
Description
第1の実施形態の一態様であるスケジューラについて図面を用いて説明する。
実装の簡易化のため、実行可能キュー31と待機キュー32の2つのキューの代わりに1つのタスクリストとして管理してもよい。その場合は、タスクリストに登録されているスレッドを、実行可能キュー31につながっているスレッドとみなすと、本実施形態を適用できる。この場合、待機キュー32はないため、図4に示すスレッドを待機状態から実行可能状態へ遷移させる場合のスケジューラ1の動作は無くなる。
次に、第2の実施形態に係るスケジューラ1について図面を用いて説明する。第2の実施形態のスケジューラ1は、第1の実施形態と同様に複数のコアに対してスレッドをスケジューリングして割り当てる例とする。また、第2の実施形態のスケジューラ1も、第1の実施形態の図1に示すスレッド管理データ2を利用して、スレッドをスケジューリングする。第2の実施形態において、スレッド管理データ2の内容は第1の実施形態と同様である。また、第2の実施形態でも各コアに関連付けられたスレッドのスケジューリングを表現するキューとして、実行可能キュー31、待機キュー32があるとする。スレッドのスレッド管理データ2がコアの実行可能キュー31もしくは待機キュー32のいずれかに存在する場合、スレッドがコアに割り当てられているという事にする。
前述したスケジューラ1は、プログラム(ソフトウェアプログラム,コンピュータプログラム)が図8に示すコンピュータ90のCPU91(Central Processing Unit)において実行されることにより実現される。具体的には、第1、2の実施形態に係るスケジューラ1における各構成要素の機能、又は、スケジューラ1の動作としてプログラムを実行することにより実現できる。これらの構成要素、又は、動作は、CPU91がROM(Read Only Memory)93あるいは記憶装置95からプログラム94を読み込み、読み込んだプログラムを、例えば図3から図5、図7に示したフローチャートの手順の如くCPU91、及び、RAM(Random Access Memory)92を用いて実行することにより実現されてもよい。そして、このような場合において、上述した実施形態を例に説明した本開示は、係るコンピュータプログラムを表すコードあるいはそのコンピュータプログラムを表すコードが格納されたコンピュータ読み取り可能な記憶媒体によって構成されると捉えることができる。コンピュータ読み取り可能な記憶媒体は、例えば記憶装置95、不図示の着脱可能な磁気ディスク媒体,光学ディスク媒体やメモリカードなどである。なお、各実施形態の構成要素は、集積回路による専用のハードウエアであってもよい。
2 スレッド管理データ
11 確認部
12 選択部
13 決定部
14 移送部
15 計数部
16 設定部
21 スレッド識別子
22 スレッドグループ識別子
23 優先度
24 ワーカーフラグ
31 実行可能キュー
32 待機キュー
Claims (6)
- 各コアにスレッドが割り当てられて、空きコアが存在しない場合、
前記スレッドがユーザスレッド又はワーカースレッドであるか確認する確認手段と、
前記各コアのうち、前記各コアの実行可能キュー又は待機キューに、生成するワーカースレッドと同一のスレッドグループのスレッドが存在するコアを選択する選択手段と、
選択した前記コアに、前記生成するワーカースレッドを割り当てることを決定する決定手段と、を備え、
前記確認手段は、前記生成するワーカースレッドと同一のスレッドグループのスレッドが他に存在していない孤立したワーカースレッドが、前記各コアの前記実行可能キューに存在するか確認する、
コンピュータ。 - 前記選択手段は、前記各コアのうち、前記実行可能キューに同一のスレッドグループのスレッドが存在するコアを優先して選択する、
請求項1に記載のコンピュータ。 - 前記生成するワーカースレッドに対して、同一のスレッドグループにおけるスレッド間の優先の度合を示す優先度を他のスレッドよりも高く設定する設定手段を、更に備える、
請求項1又は2に記載のコンピュータ。 - 前記確認手段は、前記各コアにおいて前記実行可能キューが空いているコアが存在するか確認する、
請求項1乃至3のいずれか1つに記載のコンピュータ。 - 各コアにスレッドが割り当てられて、空きコアが存在しない場合、
前記スレッドがユーザスレッド又はワーカースレッドであるか確認し、
前記各コアのうち、前記各コアの実行可能キュー又は待機キューに、生成するワーカースレッドと同一のスレッドグループのスレッドが存在するコアを選択し、
選択した前記コアに、前記生成するワーカースレッドを割り当てることを決定し、
前記確認するステップにおいて、前記生成するワーカースレッドと同一のスレッドグループのスレッドが他に存在していない孤立したワーカースレッドが、前記各コアの前記実行可能キューに存在するか確認する、
スケジューリング方法。 - コンピュータに、
各コアにスレッドが割り当てられて、空きコアが存在しない場合、
前記スレッドがユーザスレッド又はワーカースレッドであるか確認する処理と、
前記各コアのうち、前記各コアの実行可能キュー又は待機キューに、生成するワーカースレッドと同一のスレッドグループのスレッドが存在するコアを選択する処理と、
選択した前記コアに、前記生成するワーカースレッドを割り当てることを決定する処理と、を実行させ、
前記確認する処理において、前記生成するワーカースレッドと同一のスレッドグループのスレッドが他に存在していない孤立したワーカースレッドが、前記各コアの前記実行可能キューに存在するか確認する、
プログラム。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2021015377A JP7188472B2 (ja) | 2021-02-03 | 2021-02-03 | コンピュータ、スケジューリング方法、及び、プログラム |
PCT/JP2022/002541 WO2022168661A1 (ja) | 2021-02-03 | 2022-01-25 | スケジューラ、スケジューリング方法、及び、コンピュータ読み取り可能な記憶媒体 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2021015377A JP7188472B2 (ja) | 2021-02-03 | 2021-02-03 | コンピュータ、スケジューリング方法、及び、プログラム |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2022118736A JP2022118736A (ja) | 2022-08-16 |
JP7188472B2 true JP7188472B2 (ja) | 2022-12-13 |
Family
ID=82741156
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2021015377A Active JP7188472B2 (ja) | 2021-02-03 | 2021-02-03 | コンピュータ、スケジューリング方法、及び、プログラム |
Country Status (2)
Country | Link |
---|---|
JP (1) | JP7188472B2 (ja) |
WO (1) | WO2022168661A1 (ja) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2003029984A (ja) | 2001-07-12 | 2003-01-31 | Nec Corp | マルチスレッド実行方法及び並列プロセッサシステム |
JP2006024180A (ja) | 2004-06-10 | 2006-01-26 | Hitachi Ltd | 計算機システム及びその資源割当て方法 |
JP2007257097A (ja) | 2006-03-22 | 2007-10-04 | Nec Corp | 仮想計算機システム及びその物理リソース再構成方法並びにプログラム |
JP2010287172A (ja) | 2009-06-15 | 2010-12-24 | Nec Corp | 計算機ノード、計算機システム、プロセス生成方法およびプロセス生成プログラム |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4809157A (en) * | 1985-09-30 | 1989-02-28 | International Business Machines Corp. | Dynamic assignment of affinity for vector tasks |
US5063500A (en) * | 1988-09-29 | 1991-11-05 | Ibm Corp. | System for executing segments of application program concurrently/serially on different/same virtual machine |
JPH02122365A (ja) * | 1988-10-31 | 1990-05-10 | Hitachi Ltd | プロセッサ割当て方式 |
JP2769367B2 (ja) * | 1989-09-28 | 1998-06-25 | 株式会社日立製作所 | マルチプロセッサスケジューリング方法 |
-
2021
- 2021-02-03 JP JP2021015377A patent/JP7188472B2/ja active Active
-
2022
- 2022-01-25 WO PCT/JP2022/002541 patent/WO2022168661A1/ja active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2003029984A (ja) | 2001-07-12 | 2003-01-31 | Nec Corp | マルチスレッド実行方法及び並列プロセッサシステム |
JP2006024180A (ja) | 2004-06-10 | 2006-01-26 | Hitachi Ltd | 計算機システム及びその資源割当て方法 |
JP2007257097A (ja) | 2006-03-22 | 2007-10-04 | Nec Corp | 仮想計算機システム及びその物理リソース再構成方法並びにプログラム |
JP2010287172A (ja) | 2009-06-15 | 2010-12-24 | Nec Corp | 計算機ノード、計算機システム、プロセス生成方法およびプロセス生成プログラム |
Non-Patent Citations (1)
Title |
---|
合田 憲人,グリッドコンピューティングを用いた分枝限定法による最適化問題計算,経営の科学 オペレーションズ・リサーチ,社団法人日本オペレーションズ・リサーチ学会,2007年10月01日,第52巻 第10号,第639頁-第644頁,ISSN:0030-3674 |
Also Published As
Publication number | Publication date |
---|---|
JP2022118736A (ja) | 2022-08-16 |
WO2022168661A1 (ja) | 2022-08-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3425502B1 (en) | Task scheduling method and device | |
EP2300910B1 (en) | Scheduler instances in a process | |
RU2454704C2 (ru) | Способ и система для выполнения программных приложений и машиночитаемый носитель | |
US8615765B2 (en) | Dividing a computer job into micro-jobs | |
EP2388699A1 (en) | Information processing device and information processing method | |
KR100791296B1 (ko) | 멀티 코어 시스템에서 협력적 스케줄링을 제공하는 장치 및방법 | |
WO2023246044A1 (zh) | 调度方法及装置、芯片、电子设备及存储介质 | |
CN107203428B (zh) | 一种基于Xen的VCPU多核实时调度算法 | |
CN115167996A (zh) | 调度方法及装置、芯片、电子设备及存储介质 | |
EP1892625B1 (en) | Finer grained operating system scheduling | |
CN111625339A (zh) | 集群资源调度方法、装置、介质和计算设备 | |
CN114461365A (zh) | 一种进程调度处理方法、装置、设备和存储介质 | |
CN113254179A (zh) | 基于高响应比的作业调度方法、系统、终端、存储介质 | |
JP7188472B2 (ja) | コンピュータ、スケジューリング方法、及び、プログラム | |
KR101271211B1 (ko) | 다중 쓰레드의 비동기 입출력 처리 장치 및 그 방법 | |
JP5299869B2 (ja) | コンピュータマイクロジョブ | |
JP2000020323A (ja) | スケジュ―リング装置及び方法並びに記録媒体 | |
JP2008225641A (ja) | コンピュータシステム、割り込み制御方法及びプログラム | |
CA2316643C (en) | Fair assignment of processing resources to queued requests | |
WO2007049543A1 (ja) | 演算装置 | |
JP4872942B2 (ja) | ストレージシステム、ストレージ装置、優先度制御装置および優先度制御方法 | |
US8566829B1 (en) | Cooperative multi-level scheduler for virtual engines | |
JP2003186686A (ja) | リソース制御装置、方法及び記憶媒体 | |
JP5867215B2 (ja) | 情報処理装置、情報処理方法及び情報処理プログラム | |
US20230236906A1 (en) | Information processing device, information processing method, and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20210203 |
|
RD01 | Notification of change of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7421 Effective date: 20211020 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20220201 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220331 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20220802 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220929 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20221101 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20221114 |
|
R151 | Written notification of patent or utility model registration |
Ref document number: 7188472 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R151 |