助け合いフォーラム

OSS-DB

OSS-DB Silver(Ver3.0)
問題ID : 35357
問題を開く
PostgreSQLの設定ファイルについて、正しいものはどれか。(2つ選択)

この問題はプレミアムコンテンツです。

上に戻る

pg_hba.confの説明について

投稿日 2025/06/02

AIの回答が以下だったのですが、結局この選択肢の不正解な理由は
「#で始まる
ではなく
「#が記載
だからでしょうか?ちょっとわかりにくく。

<<AIの回答>>
Eの選択肢について説明します。

× E. 「pg_hba.conf」に「#」が記載されている場合はその行をコメントとして扱う

この選択肢は実は正しい内容を含んでいますが、文の構成が不適切です。実際には、「pg_hba.conf」ファイルでは、「#」で始まる行はコメントとして扱われます。コメント行は、設定に影響を与えず、主に注釈や説明を付け加える目的で使用されます。このように「pg_hba.conf」で「#」がコメントの役割を果たすのは一般的な設定ファイルのルールです。

つまり、質問の文脈や問題の選択肢の記述のバランスから、Eは不正解とされていますが、実際のファイル操作においてはこの説明は正確なものです。他の選択肢の正誤を考慮し、Eが誤りとして扱われた可能性も考えられます。したがって、「#」がコメントを示すという基本的な働き自体は間違っていません。
<<私の質問>>
わかりにくいのですが、このE.選択肢は記載、となっているから不正解?

<<AIの回答>>
ご指摘の通り、選択肢Eが不正解として扱われている理由は文の構成そのものかもしれません。しかし、実際には選択肢自体の内容は通常正しい認識です。

「pg_hba.conf」において、「#」が記載されている行はコメントとして扱われます。この「記載」という言葉が、問題の文脈上で何か特定の意図や混乱を招いている可能性も考えられますが、一般的な理解としては、「#」がコメントのためのものであること自体は間違いありません。

したがって、特に記載の言葉によって不正解になる理由は明確にはお示しできません。問題作成者の意図により細部が影響しているか、あるいは問題全体のバランスのために誤りとして選ばれている可能性があります。

2025/06/02 17:53

こういう話ですよね。

# TYPE  DATABASE        USER            ADDRESS     METHOD
host    postgres        all             web1        md5     # Web サーバ1号機からの接続を許可
host    postgres        all             web2        md5     # Web サーバ2号機からの接続を許可
# host    debug-db        all             web2        md5     # 動作確認のために web2 から debug-db に接続できるようにするための設定行
host    debug-db        all             devel        md5     # Debug DB へは devel ホストからのみ接続を許可

Method に該当する md5 の記述以降に「「#」が記載されている」行が4つありますが、先頭に # がない「行」はコメントとして扱われないですね。(もうちょっと厳密にいうと、「その行の # 以降がコメントとして扱われる」です)
対して、3行目の debug-db に web2 から接続可能にするための設定行は「先頭に #」があるためにその行自体がコメント扱いになります。

ご質問の元になった

「pg_hba.conf」に「#」が記載されている場合はその行をコメントとして扱う

は、その記載のとおり(そしてご認識の通り)「先頭」「で始まる」などの記載がないので、必ずしも「その行」がコメントとして扱われるわけではないから正解にならない、ということですね。

(AI の回答、雑だなぁ… 😓)


コメント

k kay0304

2025/06/03 10:30

承知しました。こんなに微妙なわかりにくい日本語で出題されるとしたら引っかかって間違えそうですね。気を付けます。ありがとうございます。

この返信に対して
コメントを記入できます

この投稿に対して返信しませんか?