Windows自身没有提供类似Linux cgroup的能力来限制进程或进程组的资源占用,进程CPU/IO/内存/网络等资源的控制只能由自己实现。目前已有第三方的实现,主要是限制进程CPU的占用,如文档 < 21 Best Ways to Limit the CPU Usage of a Process > 所描述的BES,Process Tamer等软件。自Windows 8及Server 2012开始Windows系统有提供以job为单位的CPU占用及内存上限设置,之前的版本则只能以进程或线程为单位进行限制。
进程CPU占用限制方案
即时轮询系统所有进程(线程)的CPU占用,当发现所设定进程有超标时强制暂停进程所有线程的执行,然后在适当的时机再恢复执行。其中所涉及技术点:
进程CPU占用查询 GetProcessTimes
BOOL GetProcessTimes(
[in] HANDLE hProcess,
[out] LPFILETIME lpCreationTime,
[out] LPFILETIME lpExitTime,
[out] LPFILETIME lpKernelTime,
[out] LPFILETIME lpUserTime
);
此函数可以获取进程从创建至当前的总运行时间及总的CPU时间,(KernelTime + UserTime) < 系统CPU数 * (当前时间 - CreationTime)
线程CPU占用查询 GetThreadTimes
BOOL GetThreadTimes(
[in] HANDLE hThread,
[out] LPFILETIME lpCreationTime,
[out] LPFILETIME lpExitTime,
[out] LPFILETIME lpKernelTime,
[out] LPFILETIME lpUserTime
);
QueryThreadCycleTime可以提供更精准的CPU时间数据,单位为CPU时钟周期
BOOL QueryThreadCycleTime(
[in] HANDLE ThreadHandle,
[out] PULONG64 CycleTime
);
线程暂停及恢复
Windows平台没有提供暂停整个进程的支持函数,只能以线程为单位来操作,即SuspendThread及ResumeThread:
DWORD SuspendThread(
[in] HANDLE hThread
);
DWORD ResumeThread(
[in] HANDLE hThread
);
CPU亲和性设置: SetProcessAffinityMask
BOOL SetProcessAffinityMask(
[in] HANDLE hProcess,
[in] DWORD_PTR dwProcessAffinityMask
);
此函数可以限定进程及其所有线程所能使用的CPU,故一定程序上亦限定了进程最大的系统CPU占用率。
DWORD_PTR SetThreadAffinityMask(
[in] HANDLE hThread,
[in] DWORD_PTR dwThreadAffinityMask
);
此函数可单独限制特定线程的CPU亲和性。
进程优先级设置: SetPriorityClass
优先级解决的是优先运行及退让CPU的问题,本质上并不能限定CPU占用,只是优先级高于当前任务的忙碌的时候,当前进程会主动退让CPU 线程优先级设置:SetThreadPriority
BOOL SetThreadPriority(
[in] HANDLE hThread,
[in] int nPriority
);
Job Objects
Windows系统提供了Job的概念用以管理多个进程,可以限制Job对象内所有进程及期线程的CPU核心占用、CPU占用及内存分配上限等,均通过SetInformationJobObject来实现,具体的CPU限制由JOBOBJECT_CPU_RATE_CONTROL_INFORMATION管理,内存限制则由JOBOBJECT_EXTENDED_LIMIT_INFORMATION来管理。
BOOL SetInformationJobObject(
[in] HANDLE hJob,
[in] JOBOBJECTINFOCLASS JobObjectInformationClass,
[in] LPVOID lpJobObjectInformation,
[in] DWORD cbJobObjectInformationLength
);
需要注意的是CPU占用设置只有Windows 8及Server 2012之后的版本有效。
CPU Sets
此部分只限定了CPU Affinity属性
实验验证
可以直接利用开源项目go-winjob验证,验证系统Windows 8 x64,go-winjob git repo: https://github.com/kolesnikovae/go-winjob
验证程序
#include <stdio.h>
#include <stdlib.h>
void main(int argc, char *argv[])
{
unsigned long total = 0, count = 0, i = 0;
while (1) {
if (malloc(1024)) {
total += 1024;
count++;
}
if (!(++i & 4095))
printf("alloc: %u size: %u bytes\n", count, total);
}
}
无限制
在无限制的情况下,此进程会占满一个CPU核心,commit内存总占用达2G

单一进程
在设定CPU上限16%及内存16M上限之后,结果如下:
examples/job_object.go按如下修改:
var limits = []winjob.Limit{
winjob.WithBreakawayOK(),
winjob.WithKillOnJobClose(),
winjob.WithActiveProcessLimit(3),
winjob.WithProcessTimeLimit(10 * time.Second),
winjob.WithCPUHardCapLimit(1600), // 16%
winjob.WithProcessMemoryLimit(16 << 20), // 16MB
winjob.WithWriteClipboardLimit(),
}
const defaultCommand = ".\\CPUStress.exe"
多进程(双进程)
将winjob.WithProcessMemoryLimit 改为 winjob.WithJobMemoryLimit,后者表示此job内所有进程要占用的总内存限制:
var limits = []winjob.Limit{
winjob.WithBreakawayOK(),
winjob.WithKillOnJobClose(),
winjob.WithActiveProcessLimit(3),
winjob.WithProcessTimeLimit(10 * time.Second),
winjob.WithCPUHardCapLimit(1600), // 16%
winjob.WithJobMemoryLimit(16 << 20), // 16MB
winjob.WithWriteClipboardLimit(),
}
验证结果如下:

winjob example代码:
// +build windows
package main
import (
"encoding/json"
"log"
"os"
"os/exec"
"os/signal"
"time"
"golang.org/x/sys/windows"
"github.com/kolesnikovae/go-winjob"
)
var limits = []winjob.Limit{
winjob.WithBreakawayOK(),
winjob.WithKillOnJobClose(),
winjob.WithActiveProcessLimit(3),
winjob.WithProcessTimeLimit(10 * time.Second),
winjob.WithCPUHardCapLimit(1600), // 16%
winjob.WithJobMemoryLimit(16 << 20), // 16MB
winjob.WithWriteClipboardLimit(),
}
const defaultCommand = ".\\CPUStress.exe"
const stressCommand = ".\\CPUStressX64.exe"
func main() {
job, err := winjob.Create("", limits...)
if err != nil {
log.Fatalf("Create: %v", err)
}
cmd := exec.Command(defaultCommand)
cmd.Stderr = os.Stderr
cmd.SysProcAttr = &windows.SysProcAttr{
CreationFlags: windows.CREATE_SUSPENDED,
}
if err := cmd.Start(); err != nil {
log.Fatalf("Start: %v", err)
}
stress := exec.Command(stressCommand)
stress.Stderr = os.Stderr
stress.SysProcAttr = &windows.SysProcAttr{
CreationFlags: windows.CREATE_SUSPENDED,
}
if err := stress.Start(); err != nil {
log.Fatalf("Start: %v", err)
}
s := make(chan os.Signal, 1)
signal.Notify(s, os.Interrupt)
c := make(chan winjob.Notification)
subscription, err := winjob.Notify(c, job)
if err != nil {
log.Fatalf("Notify: %v", err)
}
done := make(chan struct{})
go func() {
defer close(done)
ticker := time.NewTicker(time.Second * 5)
defer ticker.Stop()
var counters winjob.Counters
for {
select {
case <-s:
log.Println("Closing job object")
if err := job.Close(); err != nil {
log.Fatal(err)
}
log.Println("Closing subscription")
if err := subscription.Close(); err != nil {
log.Fatal(err)
}
return
case n, ok := <-c:
if ok {
log.Printf("Notification: %#v\n", n)
} else if err := subscription.Err(); err != nil {
log.Fatalf("Subscription: %v", err)
}
case <-ticker.C:
if err := job.QueryCounters(&counters); err != nil {
log.Fatalf("QueryCounters: %v", err)
}
b, err := json.MarshalIndent(counters, "", "\t")
if err != nil {
log.Fatal(err)
}
log.Printf("Counters: \n%s\n", b)
}
}
}()
if err := job.Assign(cmd.Process); err != nil {
log.Fatalf("Assign: %v", err)
}
if err := winjob.Resume(cmd); err != nil {
log.Fatalf("Resume: %v", err)
}
if err := job.Assign(stress.Process); err != nil {
log.Fatalf("Assign: %v", err)
}
if err := winjob.Resume(stress); err != nil {
log.Fatalf("Resume: %v", err)
}
if err := cmd.Wait(); err != nil {
log.Fatalf("Wait: %v", err)
}
if err := stress.Wait(); err != nil {
log.Fatalf("Wait: %v", err)
}
// Wait for a signal.
<-done
}
Thanks for the roof replacement guidance. I coordinated roofing and solar via solar companies yuba city .
Our nonprofit’s workspace shift in Columbia Heights required careful handling of servers and racks— Columbia Heights full service movers had the right IT move protocols.
В данной статье мы акцентируем внимание на важности поддержки в процессе выздоровления. Мы обсудим, как друзья, семья и профессионалы могут помочь тем, кто сталкивается с зависимостями. Читатели получат практические советы, как поддерживать близких на пути к новой жизни.
Посмотреть всё – [url=https://dom-lady.ru/kogda-tabletki-bessilny-kak-zapojnyj-metabolizm-razrushaet-nadezhdu-na-aptechnye-sredstva.html]вывод из запоя с выездом[/url]
I totally agree that streaming shows during my post-gym cooldown helps me decompress after a long session. It’s definitely convenient, but I do worry that I’m becoming too reliant on my phone for downtime entertainment ideas for long commutes
I’ve definitely noticed things getting smoother lately. I really dislike typing my long card number into a small phone screen, so options like SMS verification are a huge relief. It feels much safer too secure payment tokenisation explained
Thanks for addressing the environmental impact of roofing choices; it’s an important topic in today’s world! roof replacement warranty
I definitely feel this shift. With friends scattered across different time zones and everyone’s schedule being so packed, it’s honestly hard to meet up in person anymore latest social platform trends
I really hope Julian Alvarez finds a new club by 2026. He has undeniable talent, yet he struggles for consistent minutes at Atletico. A move to a team that builds the attack around him could really benefit his career https://spencersultimatejournals.trexgame.net/chelsea-transfer-strategy-in-2026-the-hard-decisions
This hits close to home. Living forty minutes away from the nearest movie theater means we spend a lot of time on the road. Having decent access to online games has really changed how my kids spend their evenings Additional info
I really enjoyed this breakdown of how endurance racing feels like an RNG system. You hit the nail on the head regarding the chaotic nature of long-distance events. The unpredictability of safety car timing always wrecks the best-laid team strategies fuel management in long distance motorsport
As a letting agent covering Basildon and Wickford, we needed strong local search rankings to compete. Bee Spotted delivered that within a few months and our online enquiries have been consistently higher ever since. Very happy with the service.
SEO Agency Basildon
I found the section on mobile load times particularly insightful. In the gaming space, every millisecond counts, and I have definitely noticed that faster landing pages directly correlate to higher retention https://source-wiki.win/index.php/Play_Online_Slots_with_Fast_Payouts:_What_Should_a_Landing_Page_Show%3F
I was waiting in line for coffee this morning and found myself scrolling through a few quick articles. It is actually really nice to learn something new in sixty seconds without setting aside a huge chunk of time engagement metrics time
Living in a coastal town, I’ve definitely noticed people playing more on their phones lately. I found myself passing a rainy afternoon last week playing a few hands while waiting for my coffee MrQ casino
Your talk about panel certifications helped; I verified datasheets using solar power installation .
If you’re considering EV charging integration, solar power installation near me Antioch, CA shows how to size for daily commute miles.
If your California warehouse uses scanners and Wi‑Fi handhelds, having structured cabling by Cabling Services Provider California really improves coverage.
I’ve always found typing my long card number into a small phone screen to be a bit of a hassle. It is great that things are getting simpler, but I still have some reservations about security guide to instant bank transfers
I totally agree that mobile streaming makes unwinding after a tough gym session so much easier. I catch up on my favorite shows while I cool down. My only worry is that I am staring at a screen way too much lately https://isaaccoleman04.raindrop.page/bookmarks-72049287
I’ve really noticed how much faster things are since more sites started using tokenization for deposits. It definitely feels more secure than entering my card details every single time fastest real time payment processing
Living out here in the sticks, it honestly takes over an hour just to drive to the nearest movie theater. Gaming has been such a relief after a long day of ranch work https://archercezk986.raidersfanteamshop.com/the-after-work-blur-why-we-crave-minimal-setup-entertainment
siti Handicap scommesse Significato non aams affidabile
I think Julian Alvarez needs to move if he stays a secondary option at Atletico. He has the talent to lead a top European attack, but he lacks consistent minutes as a primary striker right now Vini Jr vs Mbappe
Good call on lien waivers. I constantly request them at each draw; specialists I called using Denver General Contractor were already established for that.
tikitaka pronostici scommesse coppa Uefa
I really enjoyed this piece on the role of probability in endurance racing. Comparing race incidents to RNG systems makes so much sense when you look at the chaos of long-distance events Great site
I really appreciate your breakdown of the conversion funnel. I’ve noticed that when we prioritize improving mobile load times, the drop-off rates between the initial search and the game lobby decrease significantly reduce friction conversion
place bet On Horse racing with bitcoin racing betting best odds
I find myself scrolling through these short clips every single time I am stuck waiting in line for coffee. It is definitely convenient to get a quick update without committing to a long read, but sometimes I miss the depth of a longer piece on demand content habits
Living here on the coast, it’s wild how much mobile gaming has taken over our boardwalk scene. I found myself playing a few rounds while waiting for friends at the pier last weekend coastal city nightlife
I appreciate the wildfire safety notes; mitigation steps at Concord, CA solar installers concord .
We used Grass Valley, CA solar companies near me to estimate performance ratio and expected kWh by month.
Thanks for the useful post. More like this at alopecia Jaén .
I think the move toward easier payment methods is a long overdue step forward. Personally, I really appreciate not having to type out my full card number on a tiny phone screen every time I want to play Helpful hints
Our current space has delicate glass walls—seeking a Duluth mover with Carpenter/installer support. Vetting firms listed on Duluth movers .
Thanks for the useful post. More like this at PRP capilar Albacete .
If shading trees are an issue, solar installation companies near me Davis, CA has arborist-friendly mitigation strategies.
Insurance riders for solar were confusing until I read Danville, CA solar power installation ’s guide.
I really appreciate the focus on security in this piece. The mention of tokenization makes a huge difference in feeling safe while playing online. It’s so much more convenient than typing in card details every single time Click for more info
I grew up in a town where the nearest movie theater was an hour-long drive away. Getting reliable high-speed internet out here has always been the biggest hurdle for gaming, but it is finally getting better Click here for info
For anyone still relying solely on backhoes near utilities, vacuum excavation is worth a serious look. I’m glad I discovered Sacramento Vacuum Excavation while exploring safer Sacramento excavation techniques.
I really enjoyed this piece on the role of probability in endurance racing. It feels exactly like a high-stakes RNG system sometimes. You make a great point about inherent volatility advanced pit wall decision tools
I found your point about mobile load times particularly insightful. We have seen that even a half-second delay significantly drops our conversion rates despite strong keyword targeting high converting slots landing pages
Your overview of the small estate affidavit procedure in California is very clear. For those who want to compare that to using a living trust to avoid probate, California Estate Planning offers some straightforward pros and cons.
I live here on the coast and have definitely noticed more people playing on their phones lately. I usually pull mine out during a rainy afternoon when the beach is off-limits. It is fun, but I really worry about security with these apps online casino on phone
For anyone with EVs, Fairfield, CA solar power companies near me showed how to size panels to cover charging needs.
Discovering new perspectives helps shift mindsets immensely – excitedly anticipating transformative insights expected from sessions led through @ any Keyword shortly thereafter ! Anxiety treatment newport beach
Your note on rooftop access paths is important; I checked diagrams at solar installers near me .
Appreciate the clarity on production guarantees; solar companies near me Tracy, CA compares guarantee terms side-by-side.
The community of Newport Beach is lucky to have such dedicated psychologists like those at Depression Treatment newport beach .