pg_ctl start [-w] [-s] [-D datadir] [-l filename] [-o options] [-p path]
pg_ctl stop [-W] [-s] [-D datadir] [-m
s[mart] | f[ast] | i[mmediate]
]
pg_ctl restart [-w] [-s] [-D datadir] [-m
s[mart] | f[ast] | i[mmediate]
] [-o options]
pg_ctl reload [-s] [-D datadir]
pg_ctl status [-D datadir]
pg_ctl は PostgreSQL のバックエンドサーバ(postmaster) を起動、停止、再起動、あるいは稼働中のサーバの状態を表示するためのユーティリティです。 サーバは手動で起動することも可能ですが、pg_ctl はログ出力のリダイレクトや、ターミナルとプロセスグループの的確な分離などの作業をカプセル化します。 さらにシャットダウン制御のための便利なオプションも提供します。
start モードでは、新しいサーバが立ち上がります。 サーバはバックグラウンドで起動され、標準入力は /dev/null に接続されます。 標準出力と標準エラーは、(-l オプションが使われた場合)ログファイルに追加されます。 そうでない場合は pg_ctl の標準出力 (標準エラー出力ではありません) にリダイレクトされます。 ログファイルを指定しない場合、pg_ctl の標準出力は、ファイルにリダイレクトするか、例えばログ回転プログラムのような別プロセスにパイプで渡すべきです。 そうしないと、postmaster は出力を (バックグラウンドから) 制御ターミナルに書き出すので、シェルのプロセスグループから切り離せません。
stop モードは、指定されたデータディレクトリで稼働しているサーバを停止 (シャットダウン)します。 -m オプションで 3 つの異なる停止方式を選択することができます。 "Smart" モードは全てのクライアントが切断するまで待ちます。これがデフォルトです。 "Fast" モードはクライアントが切断するまで待ちません。 すべての実行中のトランザクションはロールバックされ、クライアントとの接続は強制的に切断され、その後サーバの停止が行なわれます。 "Immediate" モードは、クリーンアップ処理なしで、全てのサーバプロセスを中断します。 この指定により、再起動時に回復処理が実行されることになります。
restart モードは、効果的に停止を行い、そして次に起動を実行します。 これは postmaster コマンドラインオプションの変更を可能にします。
reload モードは単に postmaster に SIGHUP シグナルを送り、(postgresql.conf、pg_hba.conf などの) 設定ファイルを再度読み込ませます。 これにより、完全な再起動をすることなく、設定ファイルのオプションの変更を反映させることができます。
status モードは指定したデータディレクトリでサーバが起動しているかを確認します。 起動している場合は PID と、サーバを起動する時に使われたコマンドラインオプションを表示します。
データベースファイルのファイルシステム上の場所を指定します。これが省略された場合、環境変数 PGDATA が使われます。
サーバログ出力を filename に追加します。そのファイルが存在しない場合は作成されます。 umask は 077 に設定されるため、他のユーザからのログファイルへのアクセスはデフォルトでは許可されません。
停止 (シャットダウン) モードを指定します。mode は smart、fast、または immediate、もしくはこれらの 3 つのうちのどれかの最初の文字になります。
直接 postmaster に渡されるオプションを指定します。
このオプションは通常、1 つのグループとして渡されることを保証するために、単一引用符または二重引用符で囲まれます。
postmaster の実行プログラムの位置を指定します。 デフォルトでは postmasterの実行プログラム は pg_ctl と同じディレクトリにあるものと仮定され、もしなければ構築時に指定したインストールディレクトリとなります。 このオプションは何か異例なことをしていて postmaster が見つからないというようなエラーが出ない限り、使う必要はありません。
エラーメッセージのみを表示し、その他の情報を表示しません。
起動もしくは停止処理が完了するのを待ちます。 60 秒でタイムアウトします。 停止 (シャットダウン) 処理のデフォルトです。 停止に成功したかどうかは、PID ファイルの削除により分かります。 起動の際は、psql -l で成功したかどうかが分かります。 pg_ctl はpsql用の適切なポートを使用しようとします。 環境変数 PGPORT があれば、それが使用されます。 さもなくば、postgresql.conf ファイルで設定されたポートがあるか確認します。 どちらも使用されない場合は、PostgreSQL のコンパイル時のデフォルトポートが使用されます。(デフォルトは5432です。)
起動もしくは停止が完了するのを待ちません。起動と再起動のデフォルトです。
データディレクトリにこのファイルがあるかどうかによって、pg_ctl はサーバが現在稼働中か否かを決定します。
このファイルがデータディレクトリにあれば、pg_ctl (のstartモード)は、-o で上書きされるものを除き、このファイルの内容をオプションとしてpostmasterに渡します。
このファイルがデータディレクトリにあれば、pg_ctl (のrestartモード)は、-o で上書きされるものを除き、このファイルの内容をオプションとしてpostmasterに渡します。 また、このファイルの内容が status モードで表示されます。
データディレクトリに置かれるこのファイルは、start モードで-wが使用された時に psql で使用する適切なポートを見付けるために解析されます。
サーバを起動します。
$ pg_ctl start
以下はサーバが立ち上がるまでブロックする、サーバの起動例です。
$ pg_ctl -w start
ポート 5433 を使い fsync なしでサーバを起動します。
$ pg_ctl -o "-F -p 5433" start