pg_ctl init[db] [-s] [-D datadir] [-o initdb-options]
pg_ctl start [-w] [-t seconds] [-s] [-D datadir] [-l filename] [-o options] [-p path] [-c]
pg_ctl stop [-W] [-t seconds] [-s] [-D datadir] [-m s[mart] | f[ast] | i[mmediate] ]
pg_ctl restart [-w] [-t seconds] [-s] [-D datadir] [-c] [-m s[mart] | f[ast] | i[mmediate] ] [-o options]
pg_ctl reload [-s] [-D datadir]
pg_ctl status [-D datadir]
pg_ctl promote [-s] [-D datadir]
pg_ctl kill signal_name process_id
pg_ctl register [-N servicename] [-U username] [-P password] [-D datadir] [-S a[uto] | d[emand] ] [-w] [-t seconds] [-s] [-o options]
pg_ctl unregister [-N servicename]
pg_ctlはPostgreSQLデータベースクラスタの初期化、PostgreSQLのデータベースサーバ(postgres)を起動、停止、再起動する、あるいは稼働中のサーバの状態を表示するためのユーティリティです。 サーバは手動で起動することも可能ですが、pg_ctlは、ログ出力のリダイレクトや、端末とプロセスグループの適切な分離などの作業を隠蔽してくれます。 さらにシャットダウン制御のための便利なオプションも提供します。
initまたはinitdbモードはPostgreSQLの新しいデータベースクラスタを作成します。 データベースクラスタとは、単一のサーバインスタンスで管理されるデータベースの集合です。 このモードはinitdbコマンドを呼び出します。 詳しくはinitdbを参照して下さい。
startモードでは、新しいサーバが立ち上がります。 サーバはバックグラウンドで起動され、その標準入力は/dev/null(Windowsの場合はnul)に接続されます。 Unix系のシステムではデフォルトで、サーバの標準出力と標準エラーはpg_ctlの標準出力に転送されます(標準エラー出力には転送されません)。 pg_ctlの標準出力はファイルにリダイレクトするか、例えばrotatelogsなどのログローテーションプログラムのような別プロセスにパイプで渡すべきです。 こうしないと、postgresはその出力を(バックグラウンドから)制御端末に書き出しますので、シェルのプロセスグループから切り離すことができません。 Windowsではデフォルトで、サーバの標準出力と標準エラーは端末に送信されます。 こうしたデフォルトの動作は-lを用いてサーバの出力をログファイルに追加するように変更することができます。 -lまたは出力のリダイレクトのどちらかを使用することを勧めます。
stopモードは、指定されたデータディレクトリで稼働しているサーバを停止(シャットダウン)します。 -mオプションでは、3つの異なる停止方式を選択できます。 "smart"モード(デフォルト)は、全てのクライアントが切断し、オンラインバックアップがあればそれが終了するまで待ちます。 サーバがホットスタンバイ状態の場合、すべてのクライアント接続が切断された後にリカバリとストリーミングレプリケーションは終了します。 "fast"モードはクライアントが切断するまで待たず、かつ、実行中のオンラインバックアップを終了させます。 全ての実行中のトランザクションをロールバックし、クライアントとの接続を強制的に切断した後、サーバを停止します。 "immediate"モードは、クリーンアップ処理なしで、全てのサーバプロセスを即座に中断します。 これを指定すると、再起動時にクラッシュリカバリ処理が実行されます。
restartモードは、実質的にはstopを実行して、その後、startを実行します。 この時、postgresコマンドラインオプションを変更することができます。 指定された相対パスがサーバ起動時にコマンドラインから指定されていた場合に restartが失敗する可能性があります。
reloadモードは、単にpostgresにSIGHUPシグナルを送り、(postgresql.conf、pg_hba.confなどの)設定ファイルの再読み込みを実行させます。 これにより、設定ファイルのオプションで完全な再起動を必要としないものについて、変更を反映させることができます。
statusモードは指定したデータディレクトリでサーバが稼働しているかどうかを確認します。 稼働している場合はPIDと、サーバを起動する時に使われたコマンドラインオプションを表示します。 サーバが稼働していない場合、このプロセスは終了ステータス3を返します。 アクセス可能なデータディレクトリが指定されていない場合、プロセスは終了ステータス4を返します。
promoteモードでは、指定したデータディレクトリで稼動中のスタンバイサーバにリカバリを終了し読み書き操作を始めるようコマンドを送ります。
killモードでは指定したプロセスにシグナルを送信することができます。 これは特に、killコマンドを持たないMicrosoft Windowsで有用です。 サポートするシグナル名の一覧は--helpを使用して確認してください。
registerモードにより、Microsoft Windows上でシステムサービスを登録することができます。 -Sオプションによりサービスの起動種類を"auto"(システム起動時に自動的にサービスを起動)か"demand"(要求が合った時にサービスを起動)から選択することができます。
unregisterによりMicrosoft Windows上のシステムサービスを登録解除することができます。 これは過去にregisterコマンドによりなされた変更を元に戻します。
実現可能なプラットフォームにおいて、サーバクラッシュ時にcoreファイルを生成できるように関連するソフトリソース制限を上げます。 障害が起きたサーバプロセスからスタックトレースを取得できますので、問題のデバッグや診断の際に有用です。
データベース設定ファイルのファイルシステム上の場所を指定します。 これが省略された場合、環境変数PGDATAが使われます。
サーバログ出力をfilenameに追記します。 そのファイルが存在しない場合は作成されます。 umaskは077に設定されますので、他のユーザからのログファイルへのアクセスはデフォルトでは許可されません。
停止(シャットダウン)モードを指定します。 modeはsmart、fast、immediate、もしくはこの3つのモード名の最初の1文字をとることができます。 省略時はsmartが使用されます。
postgresに直接渡されるオプションを指定します。
このオプションは、確実に1グループとして渡すために、通常は単一引用符または二重引用符で囲まなければなりません。
initdbコマンドに直接渡すオプションを指定します。
このオプションは、確実にひとまとめとして渡すために、通常は単一引用符または二重引用符で囲まなければなりません。
postgresの実行プログラムの位置を指定します。 デフォルトではpostgresの実行プログラムはpg_ctlと同じディレクトリにあるものとみなされます。また、このディレクトリに存在しなければ、構築時に指定したインストールディレクトリが使われます。 このオプションは、何か異例なことをしていてpostgresが見つからないというようなエラーが出ない限り、使う必要はありません。
initモードでは、このオプションは同様にinitdb実行プログラムの場所を指定します。
エラーメッセージのみを表示し、その他の情報を表示しません。
起動または停止の完了まで待機する最大の秒数。 デフォルトは60秒です。
pg_ctlのバージョンを表示し、終了します。
起動もしくは停止処理が完了するのを待ちます。 待機は停止処理ではデフォルトのオプションですが、起動処理ではデフォルトではありません。 起動処理を待機している場合、pg_ctlは繰り返しサーバへの接続を試行します。 停止処理を待機している場合、pg_ctlはサーバがPIDファイルを削除するまで待機します。 このオプションにより起動時にSSLパスフレーズを入力することができます。 pg_ctlは、起動もしくは停止が成功したかどうかに基づいて終了コードを返します。
起動処理もしくは停止処理が完了するのを待ちません。 起動と再起動モードのデフォルトです。
pg_ctlコマンドライン引数の説明を表示し、終了します。
デフォルトのデータディレクトリの場所です。
また、pg_ctlは、他のほとんどのPostgreSQLユーティリティと同様、libpqでサポートされる環境変数を使用します(項31.14を参照してください)。 この他のサーバ変数についてはpostgresを参照してください。
データディレクトリにこのファイルがあるかどうかによって、pg_ctlはサーバが現在稼働中かどうかを決定します。
このファイルがデータディレクトリにあれば、pg_ctl(のrestartモード)は、-oで上書きされるものを除き、このファイルの内容をオプションとしてpostgresに渡します。 また、このファイルの内容がstatusモードで表示されます。
サーバを起動します。
$ pg_ctl start
以下はサーバが接続を植え付けられるようになるまで待機する起動例です。
$ pg_ctl -w start
ポート5433を使いfsync
なしでサーバを起動します。
$ pg_ctl -o "-F -p 5433" start
サーバを停止するためには以下を使用します。
$ pg_ctl stop
-mオプションによりどのようにバックエンドを停止させるかを制御できます。
$ pg_ctl stop -m fast