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
}
For gutter substitute paired with roofing in Manassas VA, Five Stars Roof Replacement is a invaluable location to begin.
Эта публикация раскрывает психологические механизмы зависимости и их роль в развитии расстройств. Читатель узнает о том, как психология влияет на формирование зависимостей и как профессиональная помощь может изменить ситуацию.
Детали по клику – [url=https://valenki-altai.ru/chastnyj-vyvod-iz-zapoya-kak-pomoch-blizkomu-cheloveku/]вывод из запоя на дому тверь[/url]
I had my mailbox rekeyed in Spring through mobile rekey service Houston —fast service and clear pricing.
Legal battles following an accident can be overwhelming; having a skilled Law Offices of Michael Dreishpoon makes everything more manageable.
I liked the text updates from commercial locksmith Conroe TX during my Houston car lockout.
This was quite enlightening. Check out consulta nutricionista Saltillo for more.
I appreciate how you connect brand strategy to interface design. web designer laval
I like how you defined the difference among a fix and a full substitute. We evaluation these similar thoughts with each owner of a house who contacts Gikas Roofers contractors for an estimate.
Great insights! Discover more at compañía de cuidadores mayores .
If your AC is blowing warm air, refrigerant might be low—get a licensed tech via heat pump london ontario .
Odours from sump discharge line? Check valve and vent tips at wet basement london ontario .
Этот документ охватывает важные аспекты медицинской науки, сосредотачиваясь на ключевых вопросах, касающихся здоровья населения. Мы рассматриваем свежие исследования, клинические рекомендации и лучшие практики, которые помогут улучшить качество лечения и профилактики заболеваний. Читатели получат возможность углубиться в различные медицинские дисциплины.
Получить профессиональную консультацию – [url=https://world-news.cyou/pars/v-ssha-vyskazalis-po-povody-poshlin-v-razmere-100-protiv-kitaia/]tver clinica plus[/url]
This is very insightful. Check out envío barato tienda online for more.
Этот краткий обзор предлагает сжатую информацию из области медицины, включая ключевые факты и последние новости. Мы стремимся сделать информацию доступной и понятной для широкой аудитории, что позволит читателям оставаться в курсе актуальных событий в здравоохранении.
Детали по клику – [url=https://agyha.ru/vyvod-iz-zapoya-v-klinike-kak-vernut-radost-zhizni-i-obresti-novuyu-svobodu.html]вывод из запоя тверь[/url]
I recommend checking your filtration system after any major plumbing work in San Dimas. Mine started acting up after a remodel, and a repair service arranged via Water Filtration Repair San Dimas found and fixed a kinked line and loose connection.
For algae-resistant shingles, roofing company manassas va shares brands that participate in properly in Manassas.
I absolutely like how fashion jewelry can transform an entire attire! It’s remarkable how a simple piece can add so much sophistication and personality sell gold denver
В этом обзоре мы обсудим современные методы борьбы с зависимостями, включая медикаментозную терапию и психотерапию. Мы представим последние исследования и их результаты, чтобы читатели могли быть в курсе наиболее эффективных подходов к лечению и поддержке.
Уточнить детали – [url=https://kalejdoscop.ru/lechenie-narkomanii-kompleksnyj-podhod-k-vyzdorovleniyu/]клиника плюс[/url]
Yard fences can really add to the overall aesthetic of your outdoor space. I like how different designs can complement various deck designs. It’s incredible what a little creativity can do! For more motivation, check out fence contractor near me .
I appreciated this article. For more, visit bufete abogados en Vigo .
The visual appeal of your post really caught my attention; kitchens deserve that kind of love—find your own style guide at Kitchen Remodeling Services In Los Angeles !
I’d love to determine extra on insurance plan options for dentists in Aventura. All-on-4 Dental Implants Aventura FL
Valuable information! Find more at Commercial Pressure Washing .
If you’re seeing rust-colored water or sediment even with a filtration system in San Dimas, the pre-filters or housings may need attention. I had mine serviced via Water Filtration Repair San Dimas and the difference was immediate.
Appreciate the great suggestions. For more, visit Pressure washing near me .
My ice maker in San Dimas started producing cloudy ice even though it was connected to a filtration system. A quick repair visit I booked through emergency water filter repair San Dimas revealed a clogged inline filter that needed replacing.
Здравствуйте!
Когда бизнес заказывает разработка сайтов, важно смотреть не только на визуальный дизайн. Сайт должен быстро загружаться, понятно вести пользователя к заявке и иметь структуру, пригодную для SEO. Поэтому для компаний, которым нужен не просто онлайн-буклет, а рабочий инструмент продаж, логично рассмотреть разработка лендинга: https://volt-site.ru/blog Для безопасного ссылочного профиля лучше чередовать брендовые, безанкорные и разбавленные анкоры.
seo продвижение цена стоимость, разработка сайта компании заказать, seo оптимизация сайта онлайн
корпоративный сайт цена, [url=https://volt-site.ru/uslugi/nashi-tekhnologii]разработку сайта по индивидуальному дизайну[/url], агентство разработки сайтов
Всего наилучшего и роста в топ!
This was very enlightening. More at Merrick’s #1 Exterior Power Washing | Roof & House Washing .
This was quite informative. More at Pressure Washing near me .
Universities launching health programs can outfit labs through CPR supplies Canada .
Love how you covered both aesthetics and functionality in this post; both are so important when remodeling a kitchen—visit Kitchen Remodeling Services In Los Angeles for details!
Very suitable content for all people seeking a brand new dentist in Aventura. All-on-4 Dental Implants Aventura FL
If your outside shower leaks behind siding, act fast. plumber near me opened the access panel, repaired a cracked mixing valve, and sealed penetrations.
We priced ridge caps and air flow enhancements with assist from roof replacement in Manassas.
Thanks for the insightful write-up. More like this at Residential Pressure Washing .
For quick coil cleaning tips and pro service, I rely on duct cleaning london ontario .
Gutter maintenance to prevent foundation saturation: seasonal reminders from drainage contractors london ontario .
Эта публикация раскрывает психологические механизмы зависимости и их роль в развитии расстройств. Читатель узнает о том, как психология влияет на формирование зависимостей и как профессиональная помощь может изменить ситуацию.
Подробнее можно узнать тут – [url=https://megamcpe.com/family/alkogolnaya-zavisimost-supruga-kak-ona-razrushaet-semejnyj-uyut-i-chto-delat-dalshe.html]выведения из запоя на дому круглосуточно[/url]
This was a great help. Check out contratar traslados Camino for more.
Moving into a Feasterville home? Schedule a plumbing inspection through plumber feasterville for peace of mind.
If you’ve been involved in an accident, contacting a Law Offices Of Michael Dreishpoon Queens Car Accident Lawyer should be one of your top priorities for protecting your rights.
Публикация посвящена жизненным историям людей, успешно справившихся с зависимостью. Мы покажем, что выход есть, и он начинается с первого шага — принятия проблемы и желания измениться.
Подробнее тут – [url=https://albooking.net/statti/kak-proishodit-proczess-vyvoda-iz-zapoya-i-pochemu-eto-vazhno-dlya-pobedy-nad-alkogolnoj-zavisimostyu/]Вывод из запоя на дому[/url]
Just sharing my experience: we had cloudy water coming from our filtered tap in San Dimas. Turned out the filters were way past due. I found a reliable repair tech through Water Filtration Repair San Dimas and now the water is crystal clear again.
I located a leak detection listing for Manassas citizens on roofing contractor very fabulous.
Nicely detailed. Discover more at Power Washing Pros of Mt. Sinai | Roof & House Washing .
I believe having a yard deck is important for amusing guests! It produces the perfect atmosphere for barbecues and gatherings deck builder
As a fellow web designer, I appreciate the emphasis on accessibility in this post. web designer
The photos shared here are stunning; they show how beautiful a remodeled kitchen can be—get inspired by even more designs at Kitchen Remodeling Services In Los Angeles !
This whole house redesigning article helped me see easy methods to sustain team spirit across spaces. See bathroom remodeling Phoenix
Читатели получат представление о том, как современные технологии влияют на развитие медицины. Обсуждаются новые методы лечения, персонализированный подход и роль цифровых решений в повышении качества медицинских услуг.
Ознакомьтесь с аналитикой – [url=https://russianshop.org/instrumenty/professionalnoe-lechenie-narkomanii-put-k-vyzdorovleniyu-i-novoj-zhizni.html]детоксикация наркозависимых цена[/url]