mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 18:34:36 +08:00
Documentation cleanups for recent shared memory changes.
This commit is contained in:
parent
f358428280
commit
390bfc643d
@ -507,11 +507,11 @@ psql: could not connect to server: No such file or directory
|
|||||||
<title>Managing Kernel Resources</title>
|
<title>Managing Kernel Resources</title>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
A large <productname>PostgreSQL</> installation can quickly exhaust
|
<productname>PostgreSQL</> can sometimes exhaust various operating system
|
||||||
various operating system resource limits. (On some systems, the
|
resource limits, especially when multiple copies of the server are running
|
||||||
factory defaults are so low that you don't even need a really
|
on the same system, or in very large installations. This section explains
|
||||||
<quote>large</> installation.) If you have encountered this kind of
|
the kernel resources used by <productname>PostgreSQL</> and the steps you
|
||||||
problem, keep reading.
|
can take to resolve problems related to kernel resource consumption.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<sect2 id="sysvipc">
|
<sect2 id="sysvipc">
|
||||||
@ -529,14 +529,11 @@ psql: could not connect to server: No such file or directory
|
|||||||
Shared memory and semaphores are collectively referred to as
|
Shared memory and semaphores are collectively referred to as
|
||||||
<quote><systemitem class="osname">System V</>
|
<quote><systemitem class="osname">System V</>
|
||||||
<acronym>IPC</></quote> (together with message queues, which are not
|
<acronym>IPC</></quote> (together with message queues, which are not
|
||||||
relevant for <productname>PostgreSQL</>). Almost all modern
|
relevant for <productname>PostgreSQL</>). Except on
|
||||||
operating systems provide these features, but many of them don't have
|
<systemitem class="osname">Windows</>, where <productname>PostgreSQL</>
|
||||||
them turned on or sufficiently sized by default, especially as
|
provides its own replacement implementation of these facilities, these
|
||||||
available RAM and the demands of database applications grow.
|
facilities are required in order to run
|
||||||
(On <systemitem class="osname">Windows</>,
|
<productname>PostgreSQL</>.
|
||||||
<productname>PostgreSQL</> provides its own replacement
|
|
||||||
implementation of these facilities, so most of this section
|
|
||||||
can be disregarded.)
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
@ -558,6 +555,14 @@ psql: could not connect to server: No such file or directory
|
|||||||
them, however, vary. Suggestions for some platforms are given below.
|
them, however, vary. Suggestions for some platforms are given below.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
<note>
|
||||||
|
<para>
|
||||||
|
Prior to <productname>PostgreSQL</> 9.3, 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>
|
||||||
|
|
||||||
<table id="sysvipc-parameters">
|
<table id="sysvipc-parameters">
|
||||||
<title><systemitem class="osname">System V</> <acronym>IPC</> Parameters</title>
|
<title><systemitem class="osname">System V</> <acronym>IPC</> Parameters</title>
|
||||||
@ -575,7 +580,7 @@ psql: could not connect to server: No such file or directory
|
|||||||
<row>
|
<row>
|
||||||
<entry><varname>SHMMAX</></>
|
<entry><varname>SHMMAX</></>
|
||||||
<entry>Maximum size of shared memory segment (bytes)</>
|
<entry>Maximum size of shared memory segment (bytes)</>
|
||||||
<entry>at least several megabytes (see text)</entry>
|
<entry>at least 1kB (more if running many copies of the server)</entry>
|
||||||
</row>
|
</row>
|
||||||
|
|
||||||
<row>
|
<row>
|
||||||
@ -636,36 +641,22 @@ psql: could not connect to server: No such file or directory
|
|||||||
</tgroup>
|
</tgroup>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
<indexterm><primary>SHMMAX</primary></indexterm> The most important
|
<productname>PostgreSQL</> requires a few bytes of System V shared memory
|
||||||
shared memory parameter is <varname>SHMMAX</>, the maximum size, in
|
(typically 48 bytes, on 64-bit platforms) for each copy of the server.
|
||||||
bytes, of a shared memory segment. If you get an error message from
|
On most modern operating systems, this amount can easily be allocated.
|
||||||
<function>shmget</> like <quote>Invalid argument</>, it is
|
However, if you are running many copies of the server, or if other
|
||||||
likely that this limit has been exceeded. The size of the required
|
applications are also using System V shared memory, it may be necessary
|
||||||
shared memory segment varies depending on several
|
to increase <varname>SHMMAX</>, the maximum size in bytes of a shared
|
||||||
<productname>PostgreSQL</> configuration parameters, as shown in
|
memory segment, or <varname>SHMALL</>, the total amount of System V shared
|
||||||
<xref linkend="shared-memory-parameters">. (Any error message you might
|
memory system-wide. Note that <varname>SHMALL</> is measured in pages
|
||||||
get will include the exact size of the failed allocation request.)
|
rather than bytes on many systems.
|
||||||
You can, as a temporary solution, lower some of those settings to
|
|
||||||
avoid the failure. While it is possible to get
|
|
||||||
<productname>PostgreSQL</> to run with <varname>SHMMAX</> as small as
|
|
||||||
2 MB, you need considerably more for acceptable performance. Desirable
|
|
||||||
settings are in the hundreds of megabytes to a few gigabytes.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
<para>
|
|
||||||
Some systems also have a limit on the total amount of shared memory in
|
|
||||||
the system (<varname>SHMALL</>). Make sure this is large enough
|
|
||||||
for <productname>PostgreSQL</> plus any other applications that
|
|
||||||
are using shared memory segments. Note that <varname>SHMALL</>
|
|
||||||
is measured in pages rather than bytes on many systems.
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
Less likely to cause problems is the minimum size for shared
|
Less likely to cause problems is the minimum size for shared
|
||||||
memory segments (<varname>SHMMIN</>), which should be at most
|
memory segments (<varname>SHMMIN</>), which should be at most
|
||||||
approximately 500 kB for <productname>PostgreSQL</> (it is
|
approximately 32 bytes for <productname>PostgreSQL</> (it is
|
||||||
usually just 1). The maximum number of segments system-wide
|
usually just 1). The maximum number of segments system-wide
|
||||||
(<varname>SHMMNI</>) or per-process (<varname>SHMSEG</>) are unlikely
|
(<varname>SHMMNI</>) or per-process (<varname>SHMSEG</>) are unlikely
|
||||||
to cause a problem unless your system has them set to zero.
|
to cause a problem unless your system has them set to zero.
|
||||||
@ -747,9 +738,8 @@ psql: could not connect to server: No such file or directory
|
|||||||
<indexterm><primary>FreeBSD</><secondary>IPC configuration</></>
|
<indexterm><primary>FreeBSD</><secondary>IPC configuration</></>
|
||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
The default settings are only suitable for small installations
|
The default settings can be changed using
|
||||||
(for example, default <varname>SHMMAX</varname> is 32
|
the <command>sysctl</command> or
|
||||||
MB). Changes can be made via the <command>sysctl</command> or
|
|
||||||
<command>loader</command> interfaces. The following
|
<command>loader</command> interfaces. The following
|
||||||
parameters can be set using <command>sysctl</command>:
|
parameters can be set using <command>sysctl</command>:
|
||||||
<screen>
|
<screen>
|
||||||
@ -889,14 +879,11 @@ option SEMMAP=256
|
|||||||
<indexterm><primary>Linux</><secondary>IPC configuration</></>
|
<indexterm><primary>Linux</><secondary>IPC configuration</></>
|
||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
The default maximum segment size is 32 MB, which is only adequate
|
The default maximum segment size is 32 MB, and the
|
||||||
for very small <productname>PostgreSQL</productname>
|
default maximum total size is 2097152
|
||||||
installations. The default maximum total size is 2097152
|
|
||||||
pages. A page is almost always 4096 bytes except in unusual
|
pages. A page is almost always 4096 bytes except in unusual
|
||||||
kernel configurations with <quote>huge pages</quote>
|
kernel configurations with <quote>huge pages</quote>
|
||||||
(use <literal>getconf PAGE_SIZE</literal> to verify). That
|
(use <literal>getconf PAGE_SIZE</literal> to verify).
|
||||||
makes a default limit of 8 GB, which is often enough, but not
|
|
||||||
always.
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
@ -1025,8 +1012,7 @@ sysctl -w kern.sysv.shmall
|
|||||||
<indexterm><primary>Solaris</><secondary>IPC configuration</></>
|
<indexterm><primary>Solaris</><secondary>IPC configuration</></>
|
||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
The default maximum size of a shared memory segment is too low for
|
The relevant settings can be changed in
|
||||||
<productname>PostgreSQL</>. The relevant settings can be changed in
|
|
||||||
<filename>/etc/system</>, for example:
|
<filename>/etc/system</>, for example:
|
||||||
<programlisting>
|
<programlisting>
|
||||||
set shmsys:shminfo_shmmax=0x2000000
|
set shmsys:shminfo_shmmax=0x2000000
|
||||||
@ -1055,9 +1041,8 @@ set semsys:seminfo_semmsl=32
|
|||||||
In Solaris 10 and OpenSolaris, the default shared memory and
|
In Solaris 10 and OpenSolaris, the default shared memory and
|
||||||
semaphore settings are good enough for most
|
semaphore settings are good enough for most
|
||||||
<productname>PostgreSQL</> applications. Solaris now defaults
|
<productname>PostgreSQL</> applications. Solaris now defaults
|
||||||
to a <varname>SHMMAX</> of one-quarter of system <acronym>RAM</>. If
|
to a <varname>SHMMAX</> of one-quarter of system <acronym>RAM</>.
|
||||||
you need to increase this in order to set shared memory settings
|
To further adjust this setting, use a project setting associated
|
||||||
slightly higher, you should use a project setting associated
|
|
||||||
with the <literal>postgres</> user. For example, run the
|
with the <literal>postgres</> user. For example, run the
|
||||||
following as <literal>root</>:
|
following as <literal>root</>:
|
||||||
<programlisting>
|
<programlisting>
|
||||||
@ -1067,7 +1052,7 @@ projadd -c "PostgreSQL DB User" -K "project.max-shm-memory=(privileged,8GB,deny)
|
|||||||
|
|
||||||
<para>
|
<para>
|
||||||
This command adds the <literal>user.postgres</> project and
|
This command adds the <literal>user.postgres</> project and
|
||||||
raises the shared memory maximum for the <literal>postgres</>
|
sets the shared memory maximum for the <literal>postgres</>
|
||||||
user to 8GB, and takes effect the next time that user logs
|
user to 8GB, and takes effect the next time that user logs
|
||||||
in, or when you restart <productname>PostgreSQL</> (not reload).
|
in, or when you restart <productname>PostgreSQL</> (not reload).
|
||||||
The above assumes that <productname>PostgreSQL</> is run by
|
The above assumes that <productname>PostgreSQL</> is run by
|
||||||
@ -1102,7 +1087,7 @@ project.max-msg-ids=(priv,4096,deny)
|
|||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
On <productname>UnixWare</> 7, the maximum size for shared
|
On <productname>UnixWare</> 7, the maximum size for shared
|
||||||
memory segments is only 512 kB in the default configuration.
|
memory segments is 512 kB in the default configuration.
|
||||||
To display the current value of <varname>SHMMAX</>, run:
|
To display the current value of <varname>SHMMAX</>, run:
|
||||||
<programlisting>
|
<programlisting>
|
||||||
/etc/conf/bin/idtune -g SHMMAX
|
/etc/conf/bin/idtune -g SHMMAX
|
||||||
@ -1126,57 +1111,6 @@ project.max-msg-ids=(priv,4096,deny)
|
|||||||
|
|
||||||
</variablelist>
|
</variablelist>
|
||||||
|
|
||||||
|
|
||||||
<table id="shared-memory-parameters">
|
|
||||||
<title><productname>PostgreSQL</productname> Shared Memory Usage</>
|
|
||||||
|
|
||||||
<tgroup cols="2">
|
|
||||||
<thead>
|
|
||||||
<row>
|
|
||||||
<entry>Usage</>
|
|
||||||
<entry>Approximate shared memory bytes required (as of 8.3)</>
|
|
||||||
</row>
|
|
||||||
</thead>
|
|
||||||
|
|
||||||
<tbody>
|
|
||||||
<row>
|
|
||||||
<entry>Connections</>
|
|
||||||
<entry>(1800 + 270 * <xref
|
|
||||||
linkend="guc-max-locks-per-transaction">) * <xref
|
|
||||||
linkend="guc-max-connections"></entry>
|
|
||||||
</row>
|
|
||||||
|
|
||||||
<row>
|
|
||||||
<entry>Autovacuum workers</>
|
|
||||||
<entry>(1800 + 270 * <xref
|
|
||||||
linkend="guc-max-locks-per-transaction">) * <xref
|
|
||||||
linkend="guc-autovacuum-max-workers"></entry>
|
|
||||||
</row>
|
|
||||||
|
|
||||||
<row>
|
|
||||||
<entry>Prepared transactions</>
|
|
||||||
<entry>(770 + 270 * <xref
|
|
||||||
linkend="guc-max-locks-per-transaction">) * <xref linkend="guc-max-prepared-transactions"></entry>
|
|
||||||
</row>
|
|
||||||
|
|
||||||
<row>
|
|
||||||
<entry>Shared disk buffers</>
|
|
||||||
<entry>(<xref linkend="guc-block-size"> + 208) * <xref linkend="guc-shared-buffers"></entry>
|
|
||||||
</row>
|
|
||||||
|
|
||||||
<row>
|
|
||||||
<entry>WAL buffers</>
|
|
||||||
<entry>(<xref linkend="guc-wal-block-size"> + 8) * <xref linkend="guc-wal-buffers"></entry>
|
|
||||||
</row>
|
|
||||||
|
|
||||||
<row>
|
|
||||||
<entry>Fixed space requirements</>
|
|
||||||
<entry>770 kB</entry>
|
|
||||||
</row>
|
|
||||||
</tbody>
|
|
||||||
</tgroup>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
</sect2>
|
</sect2>
|
||||||
|
|
||||||
<sect2>
|
<sect2>
|
||||||
|
Loading…
Reference in New Issue
Block a user