From: | Andrew Dunstan <andrew(at)dunslane(dot)net> |
---|---|
To: | pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: Can't find thread on Linux memory overcommit |
Date: | 2003-08-21 13:19:24 |
Message-ID: | 3F44C6DC.4060105@dunslane.net |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-docs pgsql-hackers |
I see btw that no change has been made to the docs. That's bad IMNSHO.
The situation with RH is unchanged with today's kernel errata patch,
too. I propose to submit a doc patch with the following wording, unless
someone objects or improves it:
-----------------------
Linux kernel version 2.4.* has poor default memory overcommit behavior,
which can result in the postmaster being killed by the kernel due to
memory demands by another process if the system runs out of memory. To
avoid this situation, run postgres on a machine where you can be sure
that other processes will not run the machine out of memory. If your
kernel supports strict and/or parnoid modes of overcommit handling, you
can also relieve this problem by altering the system's default
behaviour. This can be determined by examining the function
vm_enough_memory in the file mm/mmap.c in the kernel source. If this
file reveals that strict and/or paranoid modes are supported by your
kernel, turn one of these modes on by using
sysctl -w vm.overcommit_memory=2
for strict mode or
sysctl -w vm.overcommit_memory=3
for paranoid mode.
Warning: using these settings in a kernel which does not support these
modes will almost certainly increase the danger of the kernel killing
the postmaster, rather than reducing it. If in any doubt, consult a
kernel expert or your kernel vendor.
These modes are expected to be supported in all 2.6 and later kernels.
Some vendor 2.4 kernels may also support these modes. However, it is
known that some vendor documents suggest that they support them while
examination of the kernel source reveals that they do not.
-----------------
The kernel docs on these modes state this:
Gotchas
-------
The C language stack growth does an implicit mremap. If you want absolute
guarantees and run close to the edge you MUST mmap your stack for the
largest size you think you will need. For typical stack usage is does
not matter much but its a corner case if you really really care
Does this affect Pg?
andrew
Andrew Dunstan wrote:
>
> http://archives.postgresql.org/pgsql-hackers/2003-07/msg00608.php
>
> Subject is "reprise on Linux overcommit handling" - is that too
> deceptive? :-)
>
> andrew
>
> Josh Berkus wrote:
>
>> Hackers,
>>
>> I've been searching the archives, but I can't find the thread from
>> last month where we discussed the problem with Linux memory
>> overcommits in kernel 2.4.x.
>>
>> Can someone point me to the right thread? I think maybe the subject
>> line was something deceptive ....
>>
>>
>>
>
>
>
> ---------------------------(end of broadcast)---------------------------
> TIP 7: don't forget to increase your free space map settings
>
From | Date | Subject | |
---|---|---|---|
Next Message | Jon Jensen | 2003-08-21 14:03:27 | Re: Can't find thread on Linux memory overcommit |
Previous Message | Shridhar Daithankar | 2003-08-21 07:39:25 | Re: Can't find thread on Linux memory overcommit |
From | Date | Subject | |
---|---|---|---|
Next Message | Greg Stark | 2003-08-21 13:21:01 | Re: [pgsql-advocacy] Need concrete "Why Postgres not MySQL" |
Previous Message | Manfred Koizar | 2003-08-21 13:05:52 | Re: [HACKERS] Need concrete "Why Postgres not MySQL" bullet list |