views:

898

answers:

5

Problem: I have a developers machine (read: fast, lots of memory), but the user has a users machine (read: slow, not very much memory).

I can simulate a slow network using Fiddler (http://www.fiddler2.com/fiddler2/) I can look at how CPU is used over time for a process using Process Explorer (http://technet.microsoft.com/en-us/sysinternals/bb896653.aspx).

Is there any way I can restrict the amount of CPU a process can have, or the amount of memory a process can have in order to simulate a users machine more effectively? (In order to isolate performance problems for instance)

I suppose I could use a VM, but I'm looking for something a bit lighter.

I'm using Windows XP, but a solution for any Windows machine would be welcome. Thanks.

+3  A: 

The platform SDK used to come with stress tools for doing just this back in the good old days (STRESS.EXE, CPUSTRESS.EXE in the SDK), but they might still be there (check your platform SDK and/or Visual Studio installation for these two files -- unfortunately I have niether the PSDK nor VS installed on the machine I'm typing from.)

Other tools:

  • memory: performance & reliability (e.g. handling failed memory allocation): can use EatMem
  • CPU: performance & reliability (e.g. race conditions): can use CPU Burn, Prime95, etc
  • handles (GDI, User): reliability (e.g. handling failed GDI resource allocation): ??? may have to write your own, but running out of GDI handles (buggy GTK apps would usually eat them all away until all other apps on the system would start falling dead like flies) is a real test for any Windows app
  • disk: performance & reliability (e.g. handling disk full): DiskFiller, etc.

Also see this existing thread.

V.

vladr
I've tried CPU burn, it seems to work well. It is a bit like a sledgehammer though. I haven't tried the eatmem though. Marked as the accepted answer.
MatthieuF
A: 

You can run MemAlloc to chew up RAM, possibly a few copies at once.

Stephen Denne
A: 

I found a related question:

Set Windows process (or user) memory limit

The accepted answer for the question has a link to the Windows API's SetProcessWorkingSetSize, so it's not exactly a tool that can limit the amount of memory that a process can use.

In terms of changing the amount of CPU resources a process can use, if you don't mind the granularity of per-core limiting of resources, Task Manager can change the processor affinity of a process.

In Task Manager, right-click a process and select "Set Affinity...", then select the processor cores that the process can be assigned to.

If the development machine has many cores but the user machine only has one, then, rather than allowing the process to run on all the available cores, set the process' processor affinity to only one core.

coobird
+2  A: 

AppVerifier has a low-resource simulation feature.

You could also try setting the priority of your process to be very low.

George V. Reilly
A: 

It has nothing to do with SetProcessWorkingSetSize

Just use internal Win32 kernel apis to restrict CPU Usage