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 great content. More at albergue privado Palas de Rei .
Do you have a spam problem on this website; I also
am a blogger, and I was wanting to know your situation; many of us have developed some nice
procedures and we are looking to exchange techniques with other folks, be sure to shoot me an e-mail if interested.
I was confused about the requirements until I read the guide on white card Adelaide for the Whate Card Course.
Need flexible scheduling for your Whate Card Course? I found multiple time slots via prepare to work safely in the construction industry .
See persona profiles of Maine Coon kittens at british shorthair kitten adoption .
Лечение зависимости требует не только физической детоксикации, но и работы с психоэмоциональным состоянием пациента. Психотерапевтическая поддержка помогает выявить глубинные причины зависимости, снизить уровень стресса и сформировать устойчивые навыки самоконтроля, что существенно снижает риск рецидивов.
Узнать больше – [url=https://narcolog-na-dom-ufa000.ru/]нарколог капельница на дом уфа[/url]
Love the concentrate on danger control hierarchy. My White Card prep through construction induction white card emphasized that too.
В этой статье мы подробно рассматриваем проверенные методы борьбы с зависимостями, включая психотерапию, медикаментозное лечение и поддержку со стороны общества. Мы акцентируем внимание на важности комплексного подхода и возможности успешного восстановления для людей, столкнувшихся с этой проблемой.
Доступ к полной версии – [url=https://www.rantac.ru/chto-vklyuchaet-v-sebya-kapelnica-ot-zapoya/]Наркологическая клиника «Похмельная служба» в Севастополе.[/url]
OK9 là nền tảng giải trí trực tuyến được định hướng theo phong cách hiện đại, tập trung vào tốc độ truy cập, sự ổn định và trải nghiệm dễ sử dụng cho người dùng bbc
Thanks for detailing threat classifications– White Card Course Adelaide ties them into control steps actually well.
ZO789 là nền tảng giải trí trực tuyến được định hướng theo phong cách năng động, dễ sử dụng và phù hợp với người dùng yêu thích sự nhanh gọn. Website chú trọng giao diện rõ ràng, tốc độ truy cập ổn định và khả năng thao tác mượt mà trên nhiều thiết bị bbc
I liked how clear the safety modules were in the Whate Card Course. Extra guidance is available at construction white card .
A great resource for any homeowner is having a reliable drain cleaning plumber Sandpoint like those in Sandpoint.
If you need a fast, trustworthy garage door company in Mesa AZ, contact garage door maintenance Mesa .
Good explanation. Garage Door Repair Tucson can quiet rattles with proper hardware upgrades. professional garage opener repair
London — Two Jewish people were stabbed in north London on Wednesday, witnesses told CNN, in an incident that comes against the backdrop of a series of antisemitic attacks in the UK capital.
A 45-year-old man, who is also accused of trying to stab police officers, was arrested on suspicion of attempted murder, the Metropolitan Police said in a statement.
[url=https://a-slon4cc.ru]slon2.to[/url]
Counter-terrorism officers are leading the investigation and working to establish the suspect’s nationality, background and any terrorist links, police said.
Two men – one in his 70s and one in his 30s – were injured in the attack in Golders Green and are in a stable condition in hospital, police added. No officers were injured in the attack, which police responded to at 11:16 a.m.
[url=https://a-slon10to.ru]slon2.to[/url]
A man armed with a knife was seen running and “attempting to stab Jewish members of the public,” according to Shomrim, which provides local neighborhood watch and emergency responses. The group added that it responded immediately, and that police deployed a taser once they arrived.
Large swathes of the road had been cordoned off by police by the time CNN reached the area, and several emergency service vehicles, including an ambulance and police helicopter, were in attendance.
Police put up crime scene tape near the scene of a stabbing in London on Wednesday, April 29, 2026.
Police put up crime scene tape near the scene of a stabbing in London on Wednesday, April 29, 2026.
[url=https://a-slon10to.ru]slon2.to[/url]
Police cordon in north London after two people stabbed, according to Jewish neigborhood watch group
1:18
And video circulating on social media appeared to show a man being detained by several police officers as well as two men in plain clothes.
[url=https://a-slon3.ru]slon7.cc[/url]
London’s Jewish community has been targeted by a wave of antisemitic attacks in recent weeks.
Last month, arsonists set fire to four ambulances belonging to a Jewish charity in Golders Green, north London. Four people were subsequently charged by police.
Then, weeks later, a synagogue and the former premises of a Jewish charity, both in north London, were attacked.
slon7.cc
https://a-slon7.cc
UK Prime Minister Keir Starmer described the “antisemitic attack” as “utterly appalling.”
“We all need to… be absolutely clear in our determination to deal with any of these offenses, the like of which we’ve seen too much recently,” he told parliament.
Russia on Tuesday test-fired a new intercontinental ballistic missile as part of efforts to modernize the country’s nuclear forces, a launch hailed by President Vladimir Putin just days after his claim that the fighting in Ukraine is nearing an end.
[url=https://slon5-at.com]slon5.cc[/url]
Putin said that the nuclear-armed Sarmat missile would enter combat service at the end of the year. It was built to replace the aging Soviet-built Voyevoda.
“This is the most powerful missile in the world,” Putin declared, claiming that the combined power of the Sarmat’s individually targeted warheads is more than four times higher than that of any Western counterpart.
The Russian leader has repeatedly brandished the nuclear sword after sending troops into Ukraine in February 2022 to try to deter the West from ramping up support for Ukraine.
[url=https://at-slon2.cc]slon3[/url]
Russia New Missile
In this image made from video provided by Russian Defense Ministry Press Service on May 12, 2026, Russia’s new Sarmat intercontinental ballistic missile is test launched at an unspecified location in Russia.
AP
After overseeing a military parade on Red Square on Saturday commemorating the defeat of Nazi Germany in World War II, which for the first time in nearly two decades didn’t include heavy weapons, Putin declared the conflict in Ukraine is coming to an end.
[url=https://slon10to.com]slon2.at[/url]
Since coming to power in 2000, Putin has overseen efforts to upgrade the Soviet-built components of the Russian nuclear triad – deploying hundreds of new, land-based intercontinental ballistic missiles, commissioning new nuclear submarines and modernizing nuclear-capable bombers.
Russia’s effort to revamp its nuclear forces pushed the United States to launch a costly modernization of its arsenal.
Nuclear arms pact expired
The last remaining nuclear arms pact between Russia and the U.S. expired in February, leaving no caps on the world’s two largest atomic arsenals for the first time in more than a half-century and fueling fears of an unconstrained nuclear arms race.
slon9
https://a-slon4to.ru/
That same month, the U.S. and Russia agreed to reestablish formal, high-level military communications that were suspended in late 2021, prior to Russia’s full-scale invasion of Ukraine.
The Sarmat — designated “Satan II” by NATO — is meant to replace about 40 Soviet-built Voyevoda missiles. Its development began in 2011 and before now, the missile had only one known successful test and reportedly suffered a massive explosion during an abortive test in 2024. A satellite image analyzed by CBS News at the time showed a large crater and remnants of a possible explosion on a launchpad at Plesetsk Cosmodrome in northern Russia.
The Sarmat is classified as a “heavy” ICBM and is capable of carrying up to 10 tons in payload, according to the Center for Strategic and International Studies’ Missile Defense Project.
Russia on Tuesday test-fired a new intercontinental ballistic missile as part of efforts to modernize the country’s nuclear forces, a launch hailed by President Vladimir Putin just days after his claim that the fighting in Ukraine is nearing an end.
[url=https://a-slon2.net/]slon7.to[/url]
Putin said that the nuclear-armed Sarmat missile would enter combat service at the end of the year. It was built to replace the aging Soviet-built Voyevoda.
“This is the most powerful missile in the world,” Putin declared, claiming that the combined power of the Sarmat’s individually targeted warheads is more than four times higher than that of any Western counterpart.
The Russian leader has repeatedly brandished the nuclear sword after sending troops into Ukraine in February 2022 to try to deter the West from ramping up support for Ukraine.
[url=https://a-slon4at.ru/]slon8 cc[/url]
Russia New Missile
In this image made from video provided by Russian Defense Ministry Press Service on May 12, 2026, Russia’s new Sarmat intercontinental ballistic missile is test launched at an unspecified location in Russia.
AP
After overseeing a military parade on Red Square on Saturday commemorating the defeat of Nazi Germany in World War II, which for the first time in nearly two decades didn’t include heavy weapons, Putin declared the conflict in Ukraine is coming to an end.
[url=https://slon8.to-slon5.cc]slon9.cc[/url]
Since coming to power in 2000, Putin has overseen efforts to upgrade the Soviet-built components of the Russian nuclear triad – deploying hundreds of new, land-based intercontinental ballistic missiles, commissioning new nuclear submarines and modernizing nuclear-capable bombers.
Russia’s effort to revamp its nuclear forces pushed the United States to launch a costly modernization of its arsenal.
Nuclear arms pact expired
The last remaining nuclear arms pact between Russia and the U.S. expired in February, leaving no caps on the world’s two largest atomic arsenals for the first time in more than a half-century and fueling fears of an unconstrained nuclear arms race.
slon3.at
https://at-slon6.cc
That same month, the U.S. and Russia agreed to reestablish formal, high-level military communications that were suspended in late 2021, prior to Russia’s full-scale invasion of Ukraine.
The Sarmat — designated “Satan II” by NATO — is meant to replace about 40 Soviet-built Voyevoda missiles. Its development began in 2011 and before now, the missile had only one known successful test and reportedly suffered a massive explosion during an abortive test in 2024. A satellite image analyzed by CBS News at the time showed a large crater and remnants of a possible explosion on a launchpad at Plesetsk Cosmodrome in northern Russia.
The Sarmat is classified as a “heavy” ICBM and is capable of carrying up to 10 tons in payload, according to the Center for Strategic and International Studies’ Missile Defense Project.
Russia on Tuesday test-fired a new intercontinental ballistic missile as part of efforts to modernize the country’s nuclear forces, a launch hailed by President Vladimir Putin just days after his claim that the fighting in Ukraine is nearing an end.
[url=https://slon6cc.com]slon6[/url]
Putin said that the nuclear-armed Sarmat missile would enter combat service at the end of the year. It was built to replace the aging Soviet-built Voyevoda.
“This is the most powerful missile in the world,” Putin declared, claiming that the combined power of the Sarmat’s individually targeted warheads is more than four times higher than that of any Western counterpart.
The Russian leader has repeatedly brandished the nuclear sword after sending troops into Ukraine in February 2022 to try to deter the West from ramping up support for Ukraine.
[url=https://slon13to.com]slon3 cc[/url]
Russia New Missile
In this image made from video provided by Russian Defense Ministry Press Service on May 12, 2026, Russia’s new Sarmat intercontinental ballistic missile is test launched at an unspecified location in Russia.
AP
After overseeing a military parade on Red Square on Saturday commemorating the defeat of Nazi Germany in World War II, which for the first time in nearly two decades didn’t include heavy weapons, Putin declared the conflict in Ukraine is coming to an end.
[url=https://at-slon1.cc]slon2 to[/url]
Since coming to power in 2000, Putin has overseen efforts to upgrade the Soviet-built components of the Russian nuclear triad – deploying hundreds of new, land-based intercontinental ballistic missiles, commissioning new nuclear submarines and modernizing nuclear-capable bombers.
Russia’s effort to revamp its nuclear forces pushed the United States to launch a costly modernization of its arsenal.
Nuclear arms pact expired
The last remaining nuclear arms pact between Russia and the U.S. expired in February, leaving no caps on the world’s two largest atomic arsenals for the first time in more than a half-century and fueling fears of an unconstrained nuclear arms race.
slon8.to
https://a-slon3at.ru/
That same month, the U.S. and Russia agreed to reestablish formal, high-level military communications that were suspended in late 2021, prior to Russia’s full-scale invasion of Ukraine.
The Sarmat — designated “Satan II” by NATO — is meant to replace about 40 Soviet-built Voyevoda missiles. Its development began in 2011 and before now, the missile had only one known successful test and reportedly suffered a massive explosion during an abortive test in 2024. A satellite image analyzed by CBS News at the time showed a large crater and remnants of a possible explosion on a launchpad at Plesetsk Cosmodrome in northern Russia.
The Sarmat is classified as a “heavy” ICBM and is capable of carrying up to 10 tons in payload, according to the Center for Strategic and International Studies’ Missile Defense Project.
Helpful for planning. bulldog movers maryland furnished assurance thoughts and clean policy.
So delighted I took the plunge and registered in the ## FirstAidCourseBrisbane ##– it’s genuinely empowering. nationally recognised construction safety course
HOA rules can be strict in some Irvine communities; Irvine Movers has a template you can send to your movers ahead of time.
Heldere garantievoorwaarden en nazorg na dakwerken; Dakwerken Gent levert betrouwbaar werk in Gent.
For apprenticeship beginners, white card Adelaide packages White Card with other entry-level courses.
Thanks for the thorough analysis. More info at albergue Palas de Rei .
If you’re new to construction, the Whate Card Course is a must. I used White Card Course Adelaide to get started quickly.
A enfermeira do plantão noturno fez um print da banca subindo no Lucky Neko e mandou no grupo. Galera aplaudiu.
Your checklist is excellent. We cross-referenced it with the guides on elderly care and felt confident choosing.
Location near family made all the difference. We filtered by zip code on memory care to narrow options.
Nutrition and dining matter so much. memory care helped us ask the right questions about meal plans and dietary needs.
The discussion on end-of-life preparation is essential. respite care aided us locate a neighborhood that partners with hospice.
This was quite informative. For more, visit assisted living .
Этот информативный текст сочетает в себе темы здоровья и зависимости. Мы обсудим, как хронические заболевания могут усугубить зависимости и наоборот, как зависимость может влиять на общее состояние здоровья. Читатели получат представление о комплексном подходе к лечению как физического, так и психического состояния.
Кликни, не пожалеешь – [url=https://medport.info/raznoe/chto-delayut-dlya-vyvoda-iz-zapoya.html]Наркологическая клиника «Похмельная служба» в Реутове.стоп алко[/url]
Пребывание в стационаре обеспечивает круглосуточный мониторинг состояния, своевременное введение лекарств и защиту пациента от внешних факторов, провоцирующих срыв. Все палаты оснащены необходимым оборудованием, соблюдаются санитарные нормы, а условия размещения соответствуют медицинским стандартам.
Получить дополнительные сведения – [url=https://narkologicheskaya-klinika-v-yaroslavle12.ru/]наркологическая клиника в ярославле[/url]
Helpful post — for local AC Repair in Fayetteville services, reach out to nearby emergency AC service .
Поддержка — ключевой элемент на пути к выздоровлению. Мы предлагаем программы, которые продолжаются даже после завершения основного курса лечения. Пациенты имеют возможность участвовать в регулярных встречах с психологами и наркологами, где они могут делиться своими успехами и получать необходимую помощь.
Получить дополнительную информацию – [url=https://kapelnica-ot-zapoya-irkutsk2.ru/]капельница от запоя наркология в иркутске[/url]
The best way to find an electrician in Phoenix is through word of mouth—ask your neighbors! licensed electrical contractors
For anybody inquiring about cost, White Card Course Adelaide lists current prices and any discounts for group bookings.
The support team I reached through book a white card course answered all my Whate Card Course questions quickly.
If you want a stress-free international move, start with a thorough quote and clear scope. Aurora international movers made ours easy; here’s the link: Aurora movers .
Appreciate the comprehensive advice. For more, visit plumber Knoxville .
The course content felt up-to-date with current site standards. See CPCWHS1001 white card training for the latest Whate Card info.
Публикация знакомит читателей с различными подходами к реабилитации. От традиционных методов до современных программ — вы узнаете, как выбрать оптимальный путь к выздоровлению и преодолеть препятствия на этом пути.
Ознакомьтесь с аналитикой – [url=http://www.rehelp.ru/vrednie-privichki/v-chem-sut-reabilitatsii-po-programme-12-shagov.html]Похмельная служба Севастополь[/url]
I enjoyed this article. Check out albergue Palas de Rei for more.
I’m new to building and construction– this White Card guide pairs nicely with the newbie FAQs on White Card Course Adelaide .
Moving to Schertz soon and comparing local movers—has anyone tried the team behind Schertz movers for a stress-free move?
Clear communication with families was a must. We checked family portal features on senior care .
Appreciate the great suggestions. For more, visit respite care .
This was very enlightening. More at respite care .
I just recently finished a ## FirstAidCourseBrisbane ## and it was extremely useful! Very recommend inspecting it out for any individual interested in finding out vital skills. white card near me