1.10. dnstap を使用して DNS クエリーを記録する
ネットワーク管理者は、ドメインネームシステム (DNS) の詳細を記録して、DNS トラフィックパターンの分析、DNS サーバーのパフォーマンスの監視、DNS 問題のトラブルシューティングを行うことができます。受信する名前クエリーの詳細を監視してログに記録する高度な方法が必要な場合は、named サービスから送信されたメッセージを記録する dnstap インターフェイスを使用します。DNS クエリーをキャプチャーおよび記録して、Web サイトまたは IP アドレスに関する情報を収集できます。
前提条件
-
bind-9.11.26-2パッケージ以降のバージョンがインストールされている。
BIND バージョンがすでにインストールされ、実行されている場合、新しいバージョンの BIND を追加すると、既存のバージョンが上書きされます。
手順
/etc/named.confファイルのoptionsブロックを編集して、dnstapとターゲットファイルを有効にします。Copy to Clipboard Copied! Toggle word wrap Toggle overflow ログに記録する DNS トラフィックのタイプを指定するには、
/etc/named.confファイルのdnstapブロックにdnstapフィルターを追加します。次のフィルターを使用できます。-
auth: 権威ゾーンの応答または回答。 -
client: 内部クライアントクエリーまたは回答。 -
forwarder: 転送クエリーまたは応答。 -
resolver: 反復的解決クエリーまたは応答。 -
update: 動的ゾーン更新要求。 -
all: 上記のオプションのいずれか。 queryまたはresponse:queryまたはresponseキーワードを指定しない場合、dnstapは両方を記録します。注記dnstapフィルターでは、dnstap {}ブロック内に;で区切った複数の定義を含めます。次の構文を使用してください。dnstap { ( all | auth | client | forwarder | resolver | update ) [ ( query | response ) ]; … };
-
変更を適用するために、
namedサービスを再起動します。systemctl restart named.service
# systemctl restart named.serviceCopy to Clipboard Copied! Toggle word wrap Toggle overflow アクティブなログの定期的なロールアウトを設定します。
次の例では、
cronスケジューラーは、ユーザーが編集したスクリプトの内容を 1 日に 1 回実行します。rollオプションに値3指定し、dnstapが最大 3 つのバックアップログファイルを作成できるようにしています。この値3は、dnstap-output変数のversionパラメーターをオーバーライドし、バックアップログファイルの数を 3 に制限します。また、バイナリーログファイルは別のディレクトリーに移動されて名前が変更されます。3 つのバックアップログファイルがすでに存在する場合でも、ファイルの接尾辞が.2に達することはありません。サイズ制限に基づくバイナリーログの自動ローリングで十分な場合は、このステップを省略できます。Copy to Clipboard Copied! Toggle word wrap Toggle overflow dnstap-readユーティリティーを使用して、人間が判読できる形式でログを処理および分析します。次の例では、
dnstap-readユーティリティーは出力をYAMLファイル形式で出力します。Example: dnstap-read -y [file-name]
Example: dnstap-read -y [file-name]Copy to Clipboard Copied! Toggle word wrap Toggle overflow