createuser — 新しいPostgreSQLのユーザアカウントを定義する
createuser [connection-option...] [option...] [username]
createuserは新しいPostgreSQLのユーザ(より正確にいえばロール)を作成します。
新しいユーザを作成できるのは、スーパーユーザとCREATEROLE権限を持つユーザのみです。
したがって、createuserは、スーパーユーザもしくはCREATEROLE権限を持つユーザとして接続可能なユーザによって実行されなければなりません。
SUPERUSER、REPLICATION、またはBYPASSRLS権限を持つロールを作成したいのであれば、スーパーユーザとして接続しなければなりません。CREATEROLE権限だけではいけません。
スーパーユーザであるということは、そのデータベースにおけるアクセス権限の検査を素通りできることを意味しています。したがって、スーパーユーザのアクセス権を簡単に与えてはなりません。
CREATEROLEも非常に広範な権限を付与します。
createuserはSQLコマンドCREATE ROLEのラッパーです。
このユーティリティによってユーザを作成しても、これ以外の方法でサーバにアクセスしてユーザを作成しても特に違いはありません。
createuserでは、下記のコマンドライン引数を指定できます。
username作成するPostgreSQLユーザの名前を指定します。 この名前は、そのPostgreSQLインストレーションに存在するすべてのロールと異なるものでなければなりません。
-a role--with-admin=role
アドミンオプションを持つ新しいロールのメンバとして自動的に追加される既存のロールを指定します。
これにより、新しいロールのメンバ資格を他の人に付与する権利が与えられます。
-aスイッチを複数記述することで、複数の既存のロールを指定できます。
-c number--connection-limit=number新しいユーザの最大接続数を設定します。 デフォルトでは無制限です。
-d--createdb新しいユーザに対してデータベースの作成を許可します。
-D--no-createdb新しいユーザに対してデータベースの作成を禁止します。 これはデフォルトです。
-e--echocreateuserが生成しサーバに送信するコマンドを出力します。
-E--encryptedこのオプションは廃止されましたが、後方互換性のためにまだ受け付けられます。
-g role--member-of=role--role=role (deprecated)
新しいロールが、指定された既存のロールのメンバとして自動的に追加されるように指定します。
-gスイッチを複数記述することで、複数の既存のロールを指定できます。
-i--inherit新しいロールは自動的にメンバとして属するロールの権限を継承します。 これがデフォルトです。
-I--no-inherit新しいロールは自動的にメンバとして属するロールの権限を継承しません。
--interactive
ユーザ名がコマンドラインで指定されない場合、ユーザ名の入力を促し、更に
-d/-D、-r/-R、-s/-Sオプションがコマンドラインで指定されない場合にはどちらにするか入力を促します。
(これはPostgreSQL 9.1までのデフォルトの動作でした。)
-l--login新しいユーザに対してログインを許可します。 (つまり、このユーザ名をセッション起動時のユーザ識別子として使用することができます。) これがデフォルトです。
-L--no-login新しいユーザに対してログインを禁止します。 (ログイン権限を持たないロールはデータベース権限管理という面で有意です。)
-m role--with-member=role
新しいロールのメンバとして自動的に追加される既存のロールを指定します。
-mスイッチを複数記述することで、複数の既存のロールを指定できます。
-P--pwpromptこのオプションが指定されると、createuserは新しいユーザのパスワードのプロンプトを表示します。 もしパスワード認証を使う予定がなければ、これは必要ありません。
-r--createrole
他のロールの作成、変更、削除、コメント付与、およびセキュリティラベルの変更を新しいユーザに対して許可します。つまり、このユーザはCREATEROLE権限を持つことになります。
この権限によって付与される機能の詳細については、ロールの作成を参照してください。
-R--no-createrole新しいユーザに対して新しいロールの作成を禁止します。 これはデフォルトです。
-s--superuser新しいユーザはスーパーユーザになります。
-S--no-superuser新しいユーザはスーパーユーザにはなりません。 これはデフォルトです。
-v timestamp--valid-until=timestampロールのパスワードが有効でなくなる日時を設定します。 デフォルトはパスワードの有効期限を設定しません。
-V--versioncreateuserのバージョンを表示し、終了します。
--bypassrls新しいユーザは、すべての行レベルセキュリティ(RLS)ポリシーをバイパスします。
--no-bypassrls新しいユーザは、行レベルセキュリティ(RLS)ポリシーをバイパスしません。 これがデフォルトです。
--replication
新しいユーザはREPLICATION権限を持ちます。
この権限についてはCREATE ROLEの文書で詳しく説明します。
--no-replication
新しいユーザはREPLICATION権限を持ちません。
この権限についてはCREATE ROLEの文書で詳しく説明します。
これがデフォルトです。
-?--helpcreateuserのコマンドライン引数の使用方法を表示し、終了します。
createuserは、以下のコマンドライン引数も接続パラメータとして受け付けます。
-h host--host=hostサーバが稼働しているマシンのホスト名を指定します。 この値がスラッシュから始まる場合、Unixドメインソケット用のディレクトリとして使用されます。
-p port--port=portサーバが接続を監視するTCPポートもしくはUnixドメインソケットファイルの拡張子を指定します。
-U username--username=username接続に使用するユーザ名です(作成するユーザの名前ではありません)。
-w--no-password
パスワードの入力を促しません。
サーバがパスワード認証を必要とし、かつ、.pgpassファイルなどの他の方法が利用できない場合、接続試行は失敗します。
バッチジョブやスクリプトなどパスワードを入力するユーザが存在しない場合にこのオプションは有用かもしれません。
-W--passwordcreateuserは強制的にパスワード入力を促します。 (新しいユーザのパスワードではなく、サーバに接続するためのパスワードです)。
サーバがパスワード認証を要求する場合createuserは自動的にパスワード入力を促しますので、これが重要になることはありません。
しかし、createuserは、サーバにパスワードが必要かどうかを判断するための接続試行を無駄に行います。
こうした余計な接続試行を防ぐために-Wの入力が有意となる場合もあります。
PGHOSTPGPORTPGUSERデフォルトの接続パラメータです。
PG_COLOR
診断メッセージで色を使うかどうかを指定します。
可能な値はalways、auto、neverです。
また、このユーティリティは、他のほとんどのPostgreSQLユーティリティと同様、libpqでサポートされる環境変数を使用します(34.15を参照してください)。
問題が発生した場合、考えられる原因とエラーメッセージの説明については、CREATE ROLEとpsqlを参照してください。 データベースサーバは対象ホストで稼働していなければなりません。 また、libpqフロントエンドライブラリで使用される、デフォルトの接続設定と環境変数が適用されることを覚えておいてください。
デフォルトデータベースサーバ上にjoeというユーザを作成します。
$createuser joe
デフォルトデータベースサーバ上にjoeというユーザを一部の属性入力が促されるように作成します。
$createuser --interactive joeShall the new role be a superuser? (y/n)nShall the new role be allowed to create databases? (y/n)nShall the new role be allowed to create more new roles? (y/n)n
ホストedenのポート番号5000上のサーバを使って上記と同じjoeというユーザを属性を明示的に指定して作成し、背後で実行される問い合わせを表示します。
$createuser -h eden -p 5000 -S -D -R -e joeCREATE ROLE joe NOSUPERUSER NOCREATEDB NOCREATEROLE INHERIT LOGIN;
joeというユーザをスーパーユーザとして作成します。作成時にパスワードを割り当てます。
$createuser -P -s -e joeEnter password for new role:xyzzyEnter it again:xyzzyCREATE ROLE joe PASSWORD 'md5b5f5ba1a423792b526f799ae4eb3d59e' SUPERUSER CREATEDB CREATEROLE INHERIT LOGIN;
上の例で、実際には入力した新しいパスワードは画面上に表示されませんが、分かりやすくするために記載しています。 上記の通りこのパスワードはクライアントに送信される前に暗号化されます。