All parameter names are case-insensitive. Every parameter takes a value of one of five types: boolean, string, integer, floating point, or enumerated (enum). The type determines the syntax for setting the parameter: 全てのパラメータの名前は大文字と小文字を区別しません。 それぞれのパラメータは、論理値、整数、浮動小数点、文字列、またはenum(列挙型)の5つの型のいずれかの値を取ります。 型はパラメータをセットするための記法を定義します。
<emphasis>Boolean:</emphasis>
Values can be written as
<literal>on</literal>,
<literal>off</literal>,
<literal>true</literal>,
<literal>false</literal>,
<literal>yes</literal>,
<literal>no</literal>,
<literal>1</literal>,
<literal>0</literal>
(all case-insensitive) or any unambiguous prefix of one of these.
論理型:
値はon
、off
、true
、false
、yes
、no
、1
、0
(すべて大文字小文字の区別なし)、あるいは、曖昧でなければ、これらの先頭から数文字を省略形として使うこともできます。
<emphasis>String:</emphasis> In general, enclose the value in single quotes, doubling any single quotes within the value. Quotes can usually be omitted if the value is a simple number or identifier, however. (Values that match an SQL keyword require quoting in some contexts.) 文字列型: 一般に、単一引用符の中に値を入れます。 単一引用符を値に含める場合は単一引用符を2つ続けます。 なお、値が単純な数字や識別子である場合は、通常は引用符を省略できます。 (使用する場所によっては、SQLキーワードと一致する値に引用符が必要になることがあります。)
<emphasis>Numeric (integer and floating point):</emphasis>
Numeric parameters can be specified in the customary integer and
floating-point formats; fractional values are rounded to the nearest
integer if the parameter is of integer type. Integer parameters
additionally accept hexadecimal input (beginning
with <literal>0x</literal>) and octal input (beginning
with <literal>0</literal>), but these formats cannot have a fraction.
Do not use thousands separators.
Quotes are not required, except for hexadecimal input.
数値型(整数型と浮動小数点型):
数値パラメータには通常の整数と浮動小数点型が使用できます。
パラメータが整数型なら、小数値はもっとも近い整数に丸められます。
加えて整数型パラメータは16進数入力(0x
で始まります)と8進数入力(0
で始まります)を受け付けます。
しかし、これらの形式では小数点以下は使えません。
1000の位取りの区切り文字は使わないでください。
16進数入力を除き引用符は必要ありません。
<emphasis>Numeric with Unit:</emphasis>
Some numeric parameters have an implicit unit, because they describe
quantities of memory or time. The unit might be bytes, kilobytes, blocks
(typically eight kilobytes), milliseconds, seconds, or minutes.
An unadorned numeric value for one of these settings will use the
setting's default unit, which can be learned from
<structname>pg_settings</structname>.<structfield>unit</structfield>.
For convenience, settings can be given with a unit specified explicitly,
for example <literal>'120 ms'</literal> for a time value, and they will be
converted to whatever the parameter's actual unit is. Note that the
value must be written as a string (with quotes) to use this feature.
The unit name is case-sensitive, and there can be whitespace between
the numeric value and the unit.
単位付きの数値:
数値型のパラメータによっては暗黙的な単位を持つことがあります。
メモリの量や時間について記述するからです。
単位はバイト、キロバイト、ブロック(通常8キロバイト)、ミリ秒、秒、分などです。
修飾無しの数値によるこれらの設定においては、 pg_settings
.unit
からデフォルト値が採用されます。
使い勝手を考えて、たとえば'120 ms'
のように単位を明示的に指定することもできます。
この場合は、実際の単位に変換が行われます。
なお、この機能を使う場合は、引用符付きの文字列として値を指定しなければならないことに注意してください。
単位の名称は大文字小文字を区別します。
また、数値と単位の間に空白があっても構いません。
Valid memory units are <literal>B</literal> (bytes),
<literal>kB</literal> (kilobytes),
<literal>MB</literal> (megabytes), <literal>GB</literal>
(gigabytes), and <literal>TB</literal> (terabytes).
The multiplier for memory units is 1024, not 1000.
有効なメモリの単位はB
(バイト) kB
(キロバイト)、MB
(メガバイト)、 GB
(ギガバイト), TB
(テラバイト)です。
メモリ単位の乗数は1024です。1000ではありません。
Valid time units are
<literal>us</literal> (microseconds),
<literal>ms</literal> (milliseconds),
<literal>s</literal> (seconds), <literal>min</literal> (minutes),
<literal>h</literal> (hours), and <literal>d</literal> (days).
有効な時間の単位は us
(マイクロ秒)、ms
(ミリ秒)、s
(秒)、min
(分)、h
(時間)、d
(日数) です。
If a fractional value is specified with a unit, it will be rounded
to a multiple of the next smaller unit if there is one.
For example, <literal>30.1 GB</literal> will be converted
to <literal>30822 MB</literal> not <literal>32319628902 B</literal>.
If the parameter is of integer type, a final rounding to integer
occurs after any unit conversion.
単位に添えて小数点以下が指定された場合、より小さな単位が存在すれば、値はその小さな単位の積に丸められます。
たとえば、30.1 GB
は32319628902 B
ではなく30822 MB
に変換されます。
整数型のパラメータでは、単位変換の後で最終的な整数への丸めが行われます。
<emphasis>Enumerated:</emphasis>
Enumerated-type parameters are written in the same way as string
parameters, but are restricted to have one of a limited set of
values. The values allowable for such a parameter can be found from
<structname>pg_settings</structname>.<structfield>enumvals</structfield>.
Enum parameter values are case-insensitive.
列挙型:
列挙型のパラメータは文字列パラメータと同じように記述します。
ただ、使用できる文字列の種類が決まっているだけです。
使用できる文字列は pg_settings
.enumvals
で定義されています。
列挙型の値は大文字小文字を区別しません。
The most fundamental way to set these parameters is to edit the file
<filename>postgresql.conf</filename><indexterm><primary>postgresql.conf</primary></indexterm>,
which is normally kept in the data directory. A default copy is
installed when the database cluster directory is initialized.
An example of what this file might look like is:
これらのパラメータを設定する最も基本的な方法は、postgresql.conf
ファイルを編集することで、これは通常 data ディレクトリに格納されています。
デフォルトのコピーはデータベースクラスタディレクトリが初期化されるときそこにインストールされます。このファイルがどういったものかの例を示します。
# This is a comment log_connections = yes log_destination = 'syslog' search_path = '"$user", public' shared_buffers = 128MB
One parameter is specified per line. The equal sign between name and
value is optional. Whitespace is insignificant (except within a quoted
parameter value) and blank lines are
ignored. Hash marks (<literal>#</literal>) designate the remainder
of the line as a comment. Parameter values that are not simple
identifiers or numbers must be single-quoted. To embed a single
quote in a parameter value, write either two quotes (preferred)
or backslash-quote.
If the file contains multiple entries for the same parameter,
all but the last one are ignored.
1つの行毎に1つのパラメータが指定されます。
名前と値の間の等号は省略可能です。
(引用符付きのパラメータ値内を除き)空白は特に意味を持たず、何もない行は無視されます。
ハッシュ記号(#
)はその行の後の表記がコメントであることを意味します。
単純でない識別子、または数値でないパラメータ値は単一引用符で括られなければなりません。
パラメータ値の中に単一引用符を埋め込むには、引用符を2つ(推奨)もしくはバックスラッシュ-引用符を使います。
ファイル中、同じパラメータに対して複数のエントリが指定されている場合は、最後のエントリ以外は無視されます。
Parameters set in this way provide default values for the cluster. The settings seen by active sessions will be these values unless they are overridden. The following sections describe ways in which the administrator or user can override these defaults. この方法によりクラスタに対してデフォルト値が設定されます。 上書きされない限り、アクティブなセッションが見るのはこの値です。 次節以降では、管理者やユーザがこれらのデフォルト値を上書きする方法を説明します。
The configuration file is reread whenever the main server process
receives a <systemitem>SIGHUP</systemitem> signal; this signal is most easily
sent by running <literal>pg_ctl reload</literal> from the command line or by
calling the SQL function <function>pg_reload_conf()</function>. The main
server process also propagates this signal to all currently running
server processes, so that existing sessions also adopt the new values
(this will happen after they complete any currently-executing client
command). Alternatively, you can
send the signal to a single server process directly. Some parameters
can only be set at server start; any changes to their entries in the
configuration file will be ignored until the server is restarted.
Invalid parameter settings in the configuration file are likewise
ignored (but logged) during <systemitem>SIGHUP</systemitem> processing.
設定ファイルは、メインサーバプロセスがSIGHUPシグナルを受け取るたびに再読み込みされます。
このシグナルを手っ取り早く送信するには、コマンドラインからpg_ctl reload
を実行するか、SQL関数のpg_reload_conf()
を呼び出します。
メインサーバプロセスは同時にこのシグナルを、現存のセッションが同様に新しい値を入手できるように、全ての現在実行しているサーバプロセスに伝播します(これは現在実行中のクライアントコマンドの処理を完了してから行われます)。
他の手段として、直接単一のサーバプロセスにシグナルを送ることも可能です。
一部のパラメータはサーバの起動時のみ設定されまするので、設定ファイル中のそれらのエントリの変更はすべて、サーバが再起動されるまで無視されます。
設定ファイル内で無効なパラメータが設定された場合も、同じように(ログには残りますが)SIGHUP 処理中は無視されます。
In addition to <filename>postgresql.conf</filename>,
a <productname>PostgreSQL</productname> data directory contains a file
<filename>postgresql.auto.conf</filename><indexterm><primary>postgresql.auto.conf</primary></indexterm>,
which has the same format as <filename>postgresql.conf</filename> but
is intended to be edited automatically, not manually. This file holds
settings provided through the <link linkend="sql-altersystem"><command>ALTER SYSTEM</command></link> command.
This file is read whenever <filename>postgresql.conf</filename> is,
and its settings take effect in the same way. Settings
in <filename>postgresql.auto.conf</filename> override those
in <filename>postgresql.conf</filename>.
postgresql.conf
に加え、PostgreSQLのデータディレクトリには postgresql.auto.conf
というファイルがあります。
このファイルは postgresql.conf
と同じフォーマットですが、手動ではなく自動で編集されることを意図しています。
このファイルはALTER SYSTEM
コマンドを使った設定値を保存します。
このファイルはpostgresql.conf
が読み込まれるときはいつでも自動的に読み込まれ、同じように設定が反映されます。
postgresql.auto.conf
は、postgresql.conf
の設定を上書きします。
External tools may also
modify <filename>postgresql.auto.conf</filename>. It is not
recommended to do this while the server is running unless <xref
linkend="guc-allow-alter-system"/> is set to <literal>off</literal>, since a
concurrent <command>ALTER SYSTEM</command> command could overwrite
such changes. Such tools might simply append new settings to the end,
or they might choose to remove duplicate settings and/or comments
(as <command>ALTER SYSTEM</command> will).
外部ツールもpostgresql.auto.conf
を変更するかも知れません。
ALTER SYSTEM
が変更を上書きする可能性があるので、allow_alter_systemがoff
に設定されていない限り、サーバが稼働中は外部ツールによる変更は推奨されません。
そのようなツールは、単に新しい設定を最後に追加するか、重複した設定あるいはコメント(ALTER SYSTEM
が行います)を削除することを選択するかも知れません。
The system view
<link linkend="view-pg-file-settings"><structname>pg_file_settings</structname></link>
can be helpful for pre-testing changes to the configuration files, or for
diagnosing problems if a <systemitem>SIGHUP</systemitem> signal did not have the
desired effects.
システムビューのpg_file_settings
は、設定ファイルへの変更を前もってテストしたい場合や、SIGHUPシグナルで望み通りの効果がなかった場合に問題を調査する際に役立ちます。
<productname>PostgreSQL</productname> provides three SQL
commands to establish configuration defaults.
The already-mentioned <command>ALTER SYSTEM</command> command
provides an SQL-accessible means of changing global defaults; it is
functionally equivalent to editing <filename>postgresql.conf</filename>.
In addition, there are two commands that allow setting of defaults
on a per-database or per-role basis:
PostgreSQLは3つのSQLコマンドでデフォルト値を設定します。
すでに説明したALTER SYSTEM
コマンドは、SQLによってグローバルな設定値を変更する方法を提供します; postgresql.conf
を編集するのと等価です。これに加え、データベース単位あるいはロール単位で設定するためのコマンドがあります:
The <link linkend="sql-alterdatabase"><command>ALTER DATABASE</command></link> command allows global
settings to be overridden on a per-database basis.
ALTER DATABASE
コマンドはデータベース単位でグローバルな設定値を上書きします。
The <link linkend="sql-alterrole"><command>ALTER ROLE</command></link> command allows both global and
per-database settings to be overridden with user-specific values.
ALTER ROLE
コマンドはグローバルと、データベース単位の両方をユーザ固有の設定値で上書きします。
Values set with <command>ALTER DATABASE</command> and <command>ALTER ROLE</command>
are applied only when starting a fresh database session. They
override values obtained from the configuration files or server
command line, and constitute defaults for the rest of the session.
Note that some settings cannot be changed after server start, and
so cannot be set with these commands (or the ones listed below).
ALTER DATABASE
とALTER ROLE
による設定値は新しくデータベースセッションを開始した時にのみ適用されます。
これらのコマンドは設定ファイルやサーバのコマンドラインから取得した値を上書きし、セッションの残りの部分のデフォルト値を構成します。
なお、一部の設定はサーバを起動した後では変更できず、これらのコマンドを使っては設定できません(以下に記述するコマンドでも同じことが言えます)。
Once a client is connected to the database, <productname>PostgreSQL</productname> provides two additional SQL commands (and equivalent functions) to interact with session-local configuration settings: クライアントがデータベースに接続すると、PostgreSQLでは更に2つのSQL(そして同等の関数)を使ってセッションローカルの設定変更を行うことができます。
The <link linkend="sql-show"><command>SHOW</command></link> command allows inspection of the
current value of any parameter. The corresponding SQL function is
<function>current_setting(setting_name text)</function>
(see <xref linkend="functions-admin-set"/>).
SHOW
コマンドを使ってすべてのパラメータの現在の値を調べることができます。
対応する関数はcurrent_setting(setting_name text)
です(9.28.1を参照してください)。
The <link linkend="sql-set"><command>SET</command></link> command allows modification of the
current value of those parameters that can be set locally to a
session; it has no effect on other sessions.
Many parameters can be set this way by any user, but some can
only be set by superusers and users who have been
granted <literal>SET</literal> privilege on that parameter.
The corresponding SQL function is
<function>set_config(setting_name, new_value, is_local)</function>
(see <xref linkend="functions-admin-set"/>).
SET
コマンドでセッション内でローカルに変更できるパラメータの値を変更することができます。他のセッションには影響がありません。
多くのパラメータはすべてのユーザがこの方法で設定できますが、スーパーユーザか、そのパラメータのSET
権限が与えられたユーザだけが設定できるものもあります。
対応するSQL関数はset_config(setting_name, new_value, is_local)
です。
(9.28.1を参照してください)。
In addition, the system view <link
linkend="view-pg-settings"><structname>pg_settings</structname></link> can be
used to view and change session-local values:
更にシステムビューのpg_settings
を使ってセッションローカルな値を参照したり変更することができます。
Querying this view is similar to using <command>SHOW ALL</command> but
provides more detail. It is also more flexible, since it's possible
to specify filter conditions or join against other relations.
このビューを問い合わせるのは、SHOW ALL
を使うのと同じですが、更に詳細な情報を提供します。
フィルタ条件を指定したり他のリレーションと結合ができるので、より柔軟です。
Using <command>UPDATE</command> on this view, specifically
updating the <structname>setting</structname> column, is the equivalent
of issuing <command>SET</command> commands. For example, the equivalent of
このビューに対してUPDATE
を実行する、具体的にはsetting
列を更新することは、SET
コマンドを実行するのと同等です。
たとえば、
SET configuration_parameter TO DEFAULT;
is: は以下と同じです。
UPDATE pg_settings SET setting = reset_val WHERE name = 'configuration_parameter';
In addition to setting global defaults or attaching overrides at the database or role level, you can pass settings to <productname>PostgreSQL</productname> via shell facilities. Both the server and <application>libpq</application> client library accept parameter values via the shell. グローバルなデフォルト値を設定したりデータベース、ロール単位で上書きを行えるだけでなく、シェル機能を使ってPostgreSQLに設定値を渡すことができます。 サーバもlibpqクライアントライブラリもシェル経由でパラメータ値を受けとることができます。
During server startup, parameter settings can be
passed to the <command>postgres</command> command via the
<option>-c name=value</option> command-line parameter, or its equivalent
<option>--name=value</option> variation. For example,
サーバ起動時に、-c
コマンドラインパラメータか、それと同等で別の形式の--name=value
を使ってパラメータ設定値をpostgres
に渡すことができます。たとえば、
postgres -c log_connections=yes --log-destination='syslog'
Settings provided in this way override those set via
<filename>postgresql.conf</filename> or <command>ALTER SYSTEM</command>,
so they cannot be changed globally without restarting the server.
このようにして渡された設定値は、postgresql.conf
やALTER SYSTEM
による設定を上書きします。
したがってサーバを再起動しない限りこれらの設定値をグローバルに変更することはできません。
When starting a client session via <application>libpq</application>,
parameter settings can be
specified using the <envar>PGOPTIONS</envar> environment variable.
Settings established in this way constitute defaults for the life
of the session, but do not affect other sessions.
For historical reasons, the format of <envar>PGOPTIONS</envar> is
similar to that used when launching the <command>postgres</command>
command; specifically, the <option>-c</option>, or prepended
<literal>--</literal>, before the name must be specified. For example,
libpqを使ってクライアントセッションを開始するときにPGOPTIONS
環境変数を使って設定値を指定できます。
このようにして渡された設定値はセッションのデフォルトとなりますが、他のセッションには影響を与えません。
歴史的な理由により、PGOPTIONS
の形式はpostgres
を起動するときのものと似ています。とりわけ、-c
を指定するか、先頭に--
を付加した名前を指定しなければならない点です。たとえば、
env PGOPTIONS="-c geqo=off --statement-timeout=5min" psql
Other clients and libraries might provide their own mechanisms, via the shell or otherwise, that allow the user to alter session settings without direct use of SQL commands. 他のクライアントやライブラリではそれぞれ固有の方法でシェルなどを経由して、SQLコマンドを直接使わずにセッションの設定を変更することができるかもしれません。
<productname>PostgreSQL</productname> provides several features for breaking
down complex <filename>postgresql.conf</filename> files into sub-files.
These features are especially useful when managing multiple servers
with related, but not identical, configurations.
PostgreSQLは複雑なpostgresql.conf
ファイルを複数の小さなファイルに分割する複数の方法を提供しています。
これは、とりわけお互いに関連しているものの設定が同じではない複数のサーバを管理する際に有用です。
In addition to individual parameter settings,
the <filename>postgresql.conf</filename> file can contain <firstterm>include
directives</firstterm>, which specify another file to read and process as if
it were inserted into the configuration file at this point. This
feature allows a configuration file to be divided into physically
separate parts. Include directives simply look like:
パラメータ設定に加え、postgresql.conf
ファイルにincludeディレクティブを入れることができます。
このようにすると、別のファイルがあたかも設定ファイルのその場所に挿入されているかのごとく読み込まれ、処理されるように指定されます。
この機能により、設定ファイルを物理的に異なる複数のパーツに分解することができます。
Includeディレクティブは単に次のような形式になります。
<programlisting>
include 'filename'
</programlisting>
include 'ファイル名'
If the file name is not an absolute path, it is taken as relative to the directory containing the referencing configuration file. Inclusions can be nested. ファイル名が絶対パスでない場合、参照する設定ファイルを含むディレクトリからの相対パスであると受け取られます。 Includeコマンドは入れ子にすることができます。
There is also an <literal>include_if_exists</literal> directive, which acts
the same as the <literal>include</literal> directive, except
when the referenced file does not exist or cannot be read. A regular
<literal>include</literal> will consider this an error condition, but
<literal>include_if_exists</literal> merely logs a message and continues
processing the referencing configuration file.
include_if_exists
ディレクティブもあります。
これは参照ファイルが存在しないか、または読み込むことができない場合の動作を除き、include
ディレクティブと同一の動作をします。
通常のinclude
はこれをエラーと解釈しますが、include_if_exists
はただ単にメッセージをログ出力し、そして参照している設定ファイルの処理を続けます。
The <filename>postgresql.conf</filename> file can also contain
<literal>include_dir</literal> directives, which specify an entire
directory of configuration files to include. These look like
includeする設定ファイルを含むディレクトリ全体を指定するinclude_dir
ディレクティブを、postgresql.conf
ファイルに含めることもできます。
このような感じです。
<programlisting>
include_dir 'directory'
</programlisting>
include_dir 'ディレクトリ名'
Non-absolute directory names are taken as relative to the directory
containing the referencing configuration file. Within the specified
directory, only non-directory files whose names end with the
suffix <literal>.conf</literal> will be included. File names that
start with the <literal>.</literal> character are also ignored, to
prevent mistakes since such files are hidden on some platforms. Multiple
files within an include directory are processed in file name order
(according to C locale rules, i.e., numbers before letters, and
uppercase letters before lowercase ones).
絶対パスではないディレクトリ名はその設定ファイルがあるディレクトリへの相対パスと見なされます。
指定したディレクトリの中で、ディレクトリではないファイルで末尾が.conf
で終わるファイルだけがincludeされます。
また、文字.
で開始するファイル名は一部のプラットフォームでは隠しファイルとされるので、間違いを防止するため無視されます。
includeされるディレクトリにある複数ファイルはファイル名順に処理されます(ファイル名は C ロケール規則で順序付けされます。
つまり、文字より数字、小文字より大文字が先になります)。
Include files or directories can be used to logically separate portions
of the database configuration, rather than having a single large
<filename>postgresql.conf</filename> file. Consider a company that has two
database servers, each with a different amount of memory. There are
likely elements of the configuration both will share, for things such
as logging. But memory-related parameters on the server will vary
between the two. And there might be server specific customizations,
too. One way to manage this situation is to break the custom
configuration changes for your site into three files. You could add
this to the end of your <filename>postgresql.conf</filename> file to include
them:
includeされるファイルもしくはディレクトリは、大きな単一のpostgresql.conf
ファイルを使う代わりに、データベース設定の一部分を論理的に分離するために使用することが可能です。
異なるメモリ容量を持つ二つのデータベースサーバを所有する会社を考えてみてください。
例えばログ取得のように、二つが共有する設定の要素があると思われます。
しかし、サーバ上のメモリに関連したパラメータは二つの間では異なります。
更に、サーバ特有のカスタマイズも存在することがあります。
この状況に対処する一つの方法として、そのサイトに対するカスタマイズされた設定の変更を三つのファイルにすることです。
それらをincludeするためにはpostgresql.conf
ファイルの最後に以下を追加します。
include 'shared.conf' include 'memory.conf' include 'server.conf'
All systems would have the same <filename>shared.conf</filename>. Each
server with a particular amount of memory could share the
same <filename>memory.conf</filename>; you might have one for all servers
with 8GB of RAM, another for those having 16GB. And
finally <filename>server.conf</filename> could have truly server-specific
configuration information in it.
全てのシステムは同一のshared.conf
を所有する様になるでしょう。
特定のメモリ容量を所有するそれぞれのサーバは同じmemory.conf
を共有できます。
RAMが8GBのすべてのサーバには共通のmemory.conf
を1つ使い、16GBのサーバ群には別のものを使う、ということもできるでしょう。
そして最後のserver.conf
には、本当にサーバ固有となる設定情報を記載します。
Another possibility is to create a configuration file directory and
put this information into files there. For example, a <filename>conf.d</filename>
directory could be referenced at the end of <filename>postgresql.conf</filename>:
別の方法として、設定ファイルディレクトリを作成し、この情報をそこのファイルに格納することができます。
たとえば、conf.d
ディレクトリをpostgresql.conf
の最後で参照するようにできます。
include_dir 'conf.d'
Then you could name the files in the <filename>conf.d</filename> directory
like this:
そして、conf.d
の中のファイルを以下のような名前にすることができます。
00shared.conf 01memory.conf 02server.conf
This naming convention establishes a clear order in which these
files will be loaded. This is important because only the last
setting encountered for a particular parameter while the server is
reading configuration files will be used. In this example,
something set in <filename>conf.d/02server.conf</filename> would override a
value set in <filename>conf.d/01memory.conf</filename>.
この命名規則により、これらのファイルが読み込まれる順序が明確になります。
サーバが設定を読み込んでいるときに各パラメータについて最後にあった設定だけが使用されるので、このことは重要です。
この例では、conf.d/02server.conf
でされた指定はconf.d/01memory.conf
の設定値よりも優先します。
You might instead use this approach to naming the files descriptively: 代わりに以下の方法を使って、ファイルにわかりやすい名前をつけることもできます。
00shared.conf 01memory-8GB.conf 02server-foo.conf
This sort of arrangement gives a unique name for each configuration file variation. This can help eliminate ambiguity when several servers have their configurations all stored in one place, such as in a version control repository. (Storing database configuration files under version control is another good practice to consider.) こういった工夫で、設定ファイルのバリエーションに対して固有の名前を付与することができます。 また、バージョン管理リポジトリのリポジトリに複数のサーバの設定ファイルを置く場合に生じる曖昧さを排除することができます。 (データベース設定ファイルをバージョン管理することは、これもまた検討に値するやり方です。)