Commit c8be915a authored by Thomas Munro's avatar Thomas Munro

Doc: Clean up references to obsolete OS versions.

Remove obsolete instructions for old operating system versions, and
update the text to reflect the defaults on modern systems.
Reviewed-by: default avatarTom Lane <tgl@sss.pgh.pa.us>
Reviewed-by: default avatarPeter Eisentraut <peter.eisentraut@2ndquadrant.com>
Reviewed-by: default avatarMagnus Hagander <magnus@hagander.net>
Discussion: https://postgr.es/m/CA%2BhUKGLmJUSwybaPQv39rB8ABpqJq84im2UjZvyUY4feYhpWMw%40mail.gmail.com
parent c14a9803
...@@ -538,12 +538,12 @@ DETAIL: Failed system call was shmget(key=5440001, size=4011376640, 03600). ...@@ -538,12 +538,12 @@ DETAIL: Failed system call was shmget(key=5440001, size=4011376640, 03600).
</screen> </screen>
probably means your kernel's limit on the size of shared memory is probably means your kernel's limit on the size of shared memory is
smaller than the work area <productname>PostgreSQL</productname> smaller than the work area <productname>PostgreSQL</productname>
is trying to create (4011376640 bytes in this example). Or it could is trying to create (4011376640 bytes in this example).
mean that you do not have System-V-style shared memory support This is only likely to happen if you have set <literal>shared_memory_type</literal>
configured into your kernel at all. As a temporary workaround, you to <literal>sysv</literal>. In that case, you
can try starting the server with a smaller-than-normal number of can try starting the server with a smaller-than-normal number of
buffers (<xref linkend="guc-shared-buffers"/>). You will eventually want buffers (<xref linkend="guc-shared-buffers"/>), or
to reconfigure your kernel to increase the allowed shared memory reconfigure your kernel to increase the allowed shared memory
size. You might also see this message when trying to start multiple size. You might also see this message when trying to start multiple
servers on the same machine, if their total space requested servers on the same machine, if their total space requested
exceeds the kernel limit. exceeds the kernel limit.
...@@ -565,13 +565,6 @@ DETAIL: Failed system call was semget(5440126, 17, 03600). ...@@ -565,13 +565,6 @@ DETAIL: Failed system call was semget(5440126, 17, 03600).
increase the kernel limit. increase the kernel limit.
</para> </para>
<para>
If you get an <quote>illegal system call</quote> error, it is likely that
shared memory or semaphores are not supported in your kernel at
all. In that case your only option is to reconfigure the kernel to
enable these features.
</para>
<para> <para>
Details about configuring <systemitem class="osname">System V</systemitem> Details about configuring <systemitem class="osname">System V</systemitem>
<acronym>IPC</acronym> facilities are given in <xref linkend="sysvipc"/>. <acronym>IPC</acronym> facilities are given in <xref linkend="sysvipc"/>.
...@@ -662,14 +655,6 @@ psql: could not connect to server: No such file or directory ...@@ -662,14 +655,6 @@ psql: could not connect to server: No such file or directory
these features and is not discussed here. these features and is not discussed here.
</para> </para>
<para>
The complete lack of these facilities is usually manifested by an
<quote><errorname>Illegal system call</errorname></quote> error upon server
start. In that case there is no alternative but to reconfigure your
kernel. <productname>PostgreSQL</productname> won't work without them.
This situation is rare, however, among modern operating systems.
</para>
<para> <para>
By default, <productname>PostgreSQL</productname> allocates By default, <productname>PostgreSQL</productname> allocates
a very small amount of System V shared memory, as well as a much larger a very small amount of System V shared memory, as well as a much larger
...@@ -683,15 +668,6 @@ psql: could not connect to server: No such file or directory ...@@ -683,15 +668,6 @@ psql: could not connect to server: No such file or directory
platforms use System V semaphores. platforms use System V semaphores.
</para> </para>
<note>
<para>
Prior to <productname>PostgreSQL</productname> 9.3, only System V shared memory
was used, so the amount of System V shared memory required to start the
server was much larger. If you are running an older version of the
server, please consult the documentation for your server version.
</para>
</note>
<para> <para>
System V <acronym>IPC</acronym> features are typically constrained by System V <acronym>IPC</acronym> features are typically constrained by
system-wide allocation limits. system-wide allocation limits.
...@@ -872,7 +848,7 @@ psql: could not connect to server: No such file or directory ...@@ -872,7 +848,7 @@ psql: could not connect to server: No such file or directory
</term> </term>
<listitem> <listitem>
<para> <para>
At least as of version 5.1, it should not be necessary to do It should not be necessary to do
any special configuration for such parameters as any special configuration for such parameters as
<varname>SHMMAX</varname>, as it appears this is configured to <varname>SHMMAX</varname>, as it appears this is configured to
allow all memory to be used as shared memory. That is the allow all memory to be used as shared memory. That is the
...@@ -894,6 +870,12 @@ psql: could not connect to server: No such file or directory ...@@ -894,6 +870,12 @@ psql: could not connect to server: No such file or directory
<indexterm><primary>FreeBSD</primary><secondary>IPC configuration</secondary></indexterm> <indexterm><primary>FreeBSD</primary><secondary>IPC configuration</secondary></indexterm>
</term> </term>
<listitem> <listitem>
<para>
The default shared memory settings are usually good enough, unless
you have set <literal>shared_memory_type</literal> to <literal>sysv</literal>.
System V semaphores are not used on this platform.
</para>
<para> <para>
The default IPC settings can be changed using The default IPC settings can be changed using
the <command>sysctl</command> or the <command>sysctl</command> or
...@@ -908,40 +890,22 @@ psql: could not connect to server: No such file or directory ...@@ -908,40 +890,22 @@ psql: could not connect to server: No such file or directory
</para> </para>
<para> <para>
These semaphore-related settings are read-only as far as If you have set <literal>shared_memory_type</literal> to
<command>sysctl</command> is concerned, but can be set in <literal>sysv</literal>, you might also want to configure your kernel
<filename>/boot/loader.conf</filename>: to lock System V shared memory into RAM and prevent it from being paged
<programlisting> out to swap. This can be accomplished using the <command>sysctl</command>
kern.ipc.semmni=256
kern.ipc.semmns=512
</programlisting>
After modifying that file, a reboot is required for the new
settings to take effect.
</para>
<para>
You might also want to configure your kernel to lock System V shared
memory into RAM and prevent it from being paged out to swap.
This can be accomplished using the <command>sysctl</command>
setting <literal>kern.ipc.shm_use_phys</literal>. setting <literal>kern.ipc.shm_use_phys</literal>.
</para> </para>
<para> <para>
If running in FreeBSD jails by enabling <application>sysctl</application>'s If running in a FreeBSD jail, you should set its
<literal>security.jail.sysvipc_allowed</literal>, <application>postmaster</application>s <literal>sysvshm</literal> parameter to <literal>new</literal>, so that
running in different jails should be run by different operating system it has its own separate System V shared memory namespace.
users. This improves security because it prevents non-root users (Before FreeBSD 11.0, it was necessary to enable shared access to
from interfering with shared memory or semaphores in different jails, the host's IPC namespace from jails, and take measures to avoid
and it allows the PostgreSQL IPC cleanup code to function properly. collisions.)
(In FreeBSD 6.0 and later the IPC cleanup code does not properly detect
processes in other jails, preventing the running of postmasters on the
same port in different jails.)
</para> </para>
<para>
<systemitem class="osname">FreeBSD</systemitem> versions before 4.0 work like
old <systemitem class="osname">OpenBSD</systemitem> (see below).
</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
...@@ -951,7 +915,15 @@ kern.ipc.semmns=512 ...@@ -951,7 +915,15 @@ kern.ipc.semmns=512
</term> </term>
<listitem> <listitem>
<para> <para>
In <systemitem class="osname">NetBSD</systemitem> 5.0 and later, The default shared memory settings are usually good enough, unless
you have set <literal>shared_memory_type</literal> to <literal>sysv</literal>.
You will usually want to increase <literal>kern.ipc.semmni</literal>
and <literal>kern.ipc.semmns</literal>,
as <systemitem class="osname">NetBSD</systemitem>'s default settings
for these are uncomfortably small.
</para>
<para>
IPC parameters can be adjusted using <command>sysctl</command>, IPC parameters can be adjusted using <command>sysctl</command>,
for example: for example:
<screen> <screen>
...@@ -962,25 +934,12 @@ kern.ipc.semmns=512 ...@@ -962,25 +934,12 @@ kern.ipc.semmns=512
</para> </para>
<para> <para>
You will usually want to increase <literal>kern.ipc.semmni</literal> If you have set <literal>shared_memory_type</literal> to
and <literal>kern.ipc.semmns</literal>, <literal>sysv</literal>, you might also want to configure your kernel
as <systemitem class="osname">NetBSD</systemitem>'s default settings to lock System V shared memory into RAM and prevent it from being paged
for these are uncomfortably small. out to swap. This can be accomplished using the <command>sysctl</command>
</para>
<para>
You might also want to configure your kernel to lock System V shared
memory into RAM and prevent it from being paged out to swap.
This can be accomplished using the <command>sysctl</command>
setting <literal>kern.ipc.shm_use_phys</literal>. setting <literal>kern.ipc.shm_use_phys</literal>.
</para> </para>
<para>
<systemitem class="osname">NetBSD</systemitem> versions before 5.0
work like old <systemitem class="osname">OpenBSD</systemitem>
(see below), except that kernel parameters should be set with the
keyword <literal>options</literal> not <literal>option</literal>.
</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
...@@ -990,17 +949,8 @@ kern.ipc.semmns=512 ...@@ -990,17 +949,8 @@ kern.ipc.semmns=512
</term> </term>
<listitem> <listitem>
<para> <para>
In <systemitem class="osname">OpenBSD</systemitem> 3.3 and later, The default shared memory settings are usually good enough, unless
IPC parameters can be adjusted using <command>sysctl</command>, you have set <literal>shared_memory_type</literal> to <literal>sysv</literal>.
for example:
<screen>
<prompt>#</prompt> <userinput>sysctl kern.seminfo.semmni=100</userinput>
</screen>
To make these settings persist over reboots, modify
<filename>/etc/sysctl.conf</filename>.
</para>
<para>
You will usually want to You will usually want to
increase <literal>kern.seminfo.semmni</literal> increase <literal>kern.seminfo.semmni</literal>
and <literal>kern.seminfo.semmns</literal>, and <literal>kern.seminfo.semmns</literal>,
...@@ -1009,22 +959,13 @@ kern.ipc.semmns=512 ...@@ -1009,22 +959,13 @@ kern.ipc.semmns=512
</para> </para>
<para> <para>
In older <systemitem class="osname">OpenBSD</systemitem> versions, IPC parameters can be adjusted using <command>sysctl</command>,
you will need to build a custom kernel to change the IPC parameters. for example:
Make sure that the options <varname>SYSVSHM</varname> <screen>
and <varname>SYSVSEM</varname> are enabled, too. (They are by <prompt>#</prompt> <userinput>sysctl kern.seminfo.semmni=100</userinput>
default.) The following shows an example of how to set the various </screen>
parameters in the kernel configuration file: To make these settings persist over reboots, modify
<programlisting> <filename>/etc/sysctl.conf</filename>.
option SYSVSHM
option SHMMAXPGS=4096
option SHMSEG=256
option SYSVSEM
option SEMMNI=256
option SEMMNS=512
option SEMMNU=256
</programlisting>
</para> </para>
</listitem> </listitem>
...@@ -1037,9 +978,6 @@ option SEMMNU=256 ...@@ -1037,9 +978,6 @@ option SEMMNU=256
<listitem> <listitem>
<para> <para>
The default settings tend to suffice for normal installations. The default settings tend to suffice for normal installations.
On <productname>HP-UX</productname> 10, the factory default for
<varname>SEMMNS</varname> is 128, which might be too low for larger
database sites.
</para> </para>
<para> <para>
<acronym>IPC</acronym> parameters can be set in the <application>System <acronym>IPC</acronym> parameters can be set in the <application>System
...@@ -1058,11 +996,10 @@ option SEMMNU=256 ...@@ -1058,11 +996,10 @@ option SEMMNU=256
</term> </term>
<listitem> <listitem>
<para> <para>
The default maximum segment size is 32 MB, and the The default shared memory settings are usually good enough, unless
default maximum total size is 2097152 you have set <literal>shared_memory_type</literal> to <literal>sysv</literal>,
pages. A page is almost always 4096 bytes except in unusual and even then only on older kernel versions that shipped with low defaults.
kernel configurations with <quote>huge pages</quote> System V semaphores are not used on this platform.
(use <literal>getconf PAGE_SIZE</literal> to verify).
</para> </para>
<para> <para>
...@@ -1072,25 +1009,10 @@ option SEMMNU=256 ...@@ -1072,25 +1009,10 @@ option SEMMNU=256
<prompt>$</prompt> <userinput>sysctl -w kernel.shmmax=17179869184</userinput> <prompt>$</prompt> <userinput>sysctl -w kernel.shmmax=17179869184</userinput>
<prompt>$</prompt> <userinput>sysctl -w kernel.shmall=4194304</userinput> <prompt>$</prompt> <userinput>sysctl -w kernel.shmall=4194304</userinput>
</screen> </screen>
In addition these settings can be preserved between reboots in To make these settings persist over reboots, see
the file <filename>/etc/sysctl.conf</filename>. Doing that is <filename>/etc/sysctl.conf</filename>.
highly recommended.
</para>
<para>
Ancient distributions might not have the <command>sysctl</command> program,
but equivalent changes can be made by manipulating the
<filename>/proc</filename> file system:
<screen>
<prompt>$</prompt> <userinput>echo 17179869184 &gt;/proc/sys/kernel/shmmax</userinput>
<prompt>$</prompt> <userinput>echo 4194304 &gt;/proc/sys/kernel/shmall</userinput>
</screen>
</para> </para>
<para>
The remaining defaults are quite generously sized, and usually
do not require changes.
</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
...@@ -1100,6 +1022,10 @@ option SEMMNU=256 ...@@ -1100,6 +1022,10 @@ option SEMMNU=256
<indexterm><primary>macOS</primary><secondary>IPC configuration</secondary></indexterm> <indexterm><primary>macOS</primary><secondary>IPC configuration</secondary></indexterm>
</term> </term>
<listitem> <listitem>
<para>
The default shared memory and semaphore settings are usually good enough, unless
you have set <literal>shared_memory_type</literal> to <literal>sysv</literal>.
</para>
<para> <para>
The recommended method for configuring shared memory in macOS The recommended method for configuring shared memory in macOS
is to create a file named <filename>/etc/sysctl.conf</filename>, is to create a file named <filename>/etc/sysctl.conf</filename>,
...@@ -1117,8 +1043,7 @@ kern.sysv.shmall=1024 ...@@ -1117,8 +1043,7 @@ kern.sysv.shmall=1024
</para> </para>
<para> <para>
Beware that recent releases of macOS ignore attempts to set <varname>SHMMAX</varname> can only be set to a multiple of 4096.
<varname>SHMMAX</varname> to a value that isn't an exact multiple of 4096.
</para> </para>
<para> <para>
...@@ -1126,75 +1051,22 @@ kern.sysv.shmall=1024 ...@@ -1126,75 +1051,22 @@ kern.sysv.shmall=1024
</para> </para>
<para> <para>
In older macOS versions, you will need to reboot to have changes in the It is possible to change all but <varname>SHMMNI</varname> on the fly, using
shared memory parameters take effect. As of 10.5 it is possible to
change all but <varname>SHMMNI</varname> on the fly, using
<application>sysctl</application>. But it's still best to set up your preferred <application>sysctl</application>. But it's still best to set up your preferred
values via <filename>/etc/sysctl.conf</filename>, so that the values will be values via <filename>/etc/sysctl.conf</filename>, so that the values will be
kept across reboots. kept across reboots.
</para> </para>
<para>
The file <filename>/etc/sysctl.conf</filename> is only honored in macOS
10.3.9 and later. If you are running a previous 10.3.x release,
you must edit the file <filename>/etc/rc</filename>
and change the values in the following commands:
<programlisting>
sysctl -w kern.sysv.shmmax
sysctl -w kern.sysv.shmmin
sysctl -w kern.sysv.shmmni
sysctl -w kern.sysv.shmseg
sysctl -w kern.sysv.shmall
</programlisting>
Note that
<filename>/etc/rc</filename> is usually overwritten by macOS system updates,
so you should expect to have to redo these edits after each update.
</para>
<para>
In macOS 10.2 and earlier, instead edit these commands in the file
<filename>/System/Library/StartupItems/SystemTuning/SystemTuning</filename>.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><systemitem class="osname">Solaris</systemitem> 2.6 to 2.9 (Solaris
6 to Solaris 9)
<indexterm><primary>Solaris</primary><secondary>IPC configuration</secondary></indexterm>
</term>
<listitem>
<para>
The relevant settings can be changed in
<filename>/etc/system</filename>, for example:
<programlisting>
set shmsys:shminfo_shmmax=0x2000000
set shmsys:shminfo_shmmin=1
set shmsys:shminfo_shmmni=256
set shmsys:shminfo_shmseg=256
set semsys:seminfo_semmap=256
set semsys:seminfo_semmni=512
set semsys:seminfo_semmns=512
set semsys:seminfo_semmsl=32
</programlisting>
You need to reboot for the changes to take effect. See also
<ulink url="http://sunsite.uakom.sk/sunworldonline/swol-09-1997/swol-09-insidesolaris.html"></ulink>
for information on shared memory under older versions of Solaris.
</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry> <varlistentry>
<term><systemitem class="osname">Solaris</systemitem> 2.10 (Solaris <term><systemitem class="osname">Solaris</systemitem></term>
10) and later</term> <term><systemitem class="osname">illumos</systemitem></term>
<term><systemitem class="osname">OpenSolaris</systemitem></term>
<listitem> <listitem>
<para> <para>
In Solaris 10 and later, and OpenSolaris, the default shared memory and The default shared memory and semaphore settings are usually good enough for most
semaphore settings are good enough for most <productname>PostgreSQL</productname> applications. Solaris defaults
<productname>PostgreSQL</productname> applications. Solaris now defaults
to a <varname>SHMMAX</varname> of one-quarter of system <acronym>RAM</acronym>. to a <varname>SHMMAX</varname> of one-quarter of system <acronym>RAM</acronym>.
To further adjust this setting, use a project setting associated To further adjust this setting, use a project setting associated
with the <literal>postgres</literal> user. For example, run the with the <literal>postgres</literal> user. For example, run the
...@@ -1415,7 +1287,7 @@ default:\ ...@@ -1415,7 +1287,7 @@ default:\
</indexterm> </indexterm>
<para> <para>
In Linux 2.4 and later, the default virtual memory behavior is not The default virtual memory behavior on Linux is not
optimal for <productname>PostgreSQL</productname>. Because of the optimal for <productname>PostgreSQL</productname>. Because of the
way that the kernel implements memory overcommit, the kernel might way that the kernel implements memory overcommit, the kernel might
terminate the <productname>PostgreSQL</productname> postmaster (the terminate the <productname>PostgreSQL</productname> postmaster (the
...@@ -1462,7 +1334,7 @@ Out of Memory: Killed process 12345 (postgres). ...@@ -1462,7 +1334,7 @@ Out of Memory: Killed process 12345 (postgres).
</para> </para>
<para> <para>
On Linux 2.6 and later, it is possible to modify the It is possible to modify the
kernel's behavior so that it will not <quote>overcommit</quote> memory. kernel's behavior so that it will not <quote>overcommit</quote> memory.
Although this setting will not prevent the <ulink Although this setting will not prevent the <ulink
url="https://lwn.net/Articles/104179/">OOM killer</ulink> from being invoked url="https://lwn.net/Articles/104179/">OOM killer</ulink> from being invoked
...@@ -1507,29 +1379,6 @@ export PG_OOM_ADJUST_VALUE=0 ...@@ -1507,29 +1379,6 @@ export PG_OOM_ADJUST_VALUE=0
whole point is to ensure that the postmaster has a preferential setting. whole point is to ensure that the postmaster has a preferential setting.
</para> </para>
<para>
Older Linux kernels do not offer <filename>/proc/self/oom_score_adj</filename>,
but may have a previous version of the same functionality called
<filename>/proc/self/oom_adj</filename>. This works the same except the disable
value is <literal>-17</literal> not <literal>-1000</literal>.
</para>
<note>
<para>
Some vendors' Linux 2.4 kernels are reported to have early versions
of the 2.6 overcommit <command>sysctl</command> parameter. However, setting
<literal>vm.overcommit_memory</literal> to 2
on a 2.4 kernel that does not have the relevant code will make
things worse, not better. It is recommended that you inspect
the actual kernel source code (see the function
<function>vm_enough_memory</function> in the file <filename>mm/mmap.c</filename>)
to verify what is supported in your kernel before you try this in a 2.4
installation. The presence of the <filename>overcommit-accounting</filename>
documentation file should <emphasis>not</emphasis> be taken as evidence that the
feature is there. If in any doubt, consult a kernel expert or your
kernel vendor.
</para>
</note>
</sect2> </sect2>
<sect2 id="linux-huge-pages"> <sect2 id="linux-huge-pages">
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment