9

I'm using a background service that leaks memory from time to time. To prevent using the Alt+SysRq REISUB[1], I'd like to restrict the RAM usage for one process or a system user.

I really would like to say: User x may use the maximum amount of RAM of 1 GB.

Is this feasible? Do I need kind of virtual machine for this? I'm using Ubuntu 9.10.

Breakthrough
  • 34,227
  • 10
  • 105
  • 149
guerda
  • 1,513
  • 2
  • 15
  • 27

2 Answers2

11

ulimit is your friend. Check out the -m flag. I think you set this before you launch your process and it applies from then on (in the current shell).

basszero
  • 672
  • 8
  • 10
  • Thanks, nice hint! As I understand ulimit, it limits _all_ users memory/process/whatever consumption. I just like to limit it to one user/process & subprocesses. – guerda Nov 05 '09 at 21:52
  • 1
    ulimit is a shell command, and only affects processes started from the same shell after ulimit is executed. You startup the process in a shell script with a ulimit command to have it affect just that process. – KeithB Nov 06 '09 at 01:52
4

In addition to the shell commands ulimit (for bash) or limit (for csh), you can control this from inside your code with the ulimit() function.

KeithB
  • 9,976
  • 2
  • 23
  • 17
  • 1
    Obligatory manpages: http://linux.die.net/man/1/ulimit (shell command) and http://linux.die.net/man/3/ulimit (C function). – Stephan202 Nov 05 '09 at 21:34