「Rescached」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
(→‎参照: == Integration with OpenResolv == と == Integration with OpenResolv == を追加(英語版より))
 
(2人の利用者による、間の9版が非表示)
1行目: 1行目:
[[Category:Domain Name System]]
+
[[Category:ドメインネームシステム]]
 
[[en:Rescached]]
 
[[en:Rescached]]
  +
{{Related articles start}}
  +
{{Related|ドメイン名前解決}}
  +
{{Related articles end}}
 
[https://github.com/shuLhan/rescached rescached] はインターネットの名前解決・アドレス解決をキャッシュするデーモンです。実行中はローカルメモリに保存し、実行していない間はディスクキャッシュに保存されます。
 
[https://github.com/shuLhan/rescached rescached] はインターネットの名前解決・アドレス解決をキャッシュするデーモンです。実行中はローカルメモリに保存し、実行していない間はディスクキャッシュに保存されます。
   
7行目: 10行目:
 
== 特徴 ==
 
== 特徴 ==
   
  +
現在の特徴の一覧です。
* UDP と TCP によるリクエストを処理可能。
 
  +
* ディスクにキャッシュを保存・ロード。
 
  +
* UDP と TCP 接続からの要求の処理を有効にする
  +
* UDP と TCP によるリクエストを提供できるようにする
 
* {{ic|/etc/hosts}} でアドレスとホストネームをロード・提供。
 
* {{ic|/etc/hosts}} でアドレスとホストネームをロード・提供。
  +
* ディレクトリ /etc/rescached/hosts.d/ 内にホスト形式のファイルをロードして提供します
  +
* /etc/rescached/hosts.d/ のホストリストを通じて広告や悪意のある Web サイトをブロックする
  +
* /etc/rescached/zone.d からのゾーンファイル形式のロードと提供のサポート
  +
* openresolv との統合
  +
* DNS over TLS (DoH) (RFC 7858) をサポート
  +
* DNS over HTTPS (DoH) (RFC 8484) をサポート
   
 
== rescached のキャッシュの仕組み ==
 
== rescached のキャッシュの仕組み ==
   
メモリにおけるキャッシュの順番は使用頻度によって決まります。頻繁問い合わせがされホストネームはキャッシュリストの一番上り、問い合わせが少ないホストネームはキャッシュリストの下に沈みます。ユーザーの習慣を元にキャッシュリストが作成され、解決速度が高速ります。
+
キャッシュ内の各 DNS レコードには、最終アクセス時刻フィールドがあり、メモリ内でキャッシュがどように序付けされるかを定義します。最後クエリされホストはキャッシュリストの最後り、クエリされた最も古いホストはキャッシュ リストの一番上ります。
  +
  +
次の表は、メモリ内のキャッシュのリストを示しています。
   
 
{| class="wikitable"
 
{| class="wikitable"
  +
! Accessed At
! #
 
 
! ホスト名
 
! ホスト名
 
|-
 
|-
  +
| 2018-01-01 00:00:01
| 529
 
  +
| kilabit.info
| www.reddit.com
 
 
|-
 
|-
  +
| 2018-01-01 00:00:02
| 233
 
  +
| archlinux.org
| www.google.com
 
 
|-
 
|-
 
| ...
 
| ...
 
| ...
 
| ...
 
|-
 
|-
  +
| 2018-01-01 00:01:00
| 1
 
  +
| wiki.archlinux.org
| www.kilabit.info
 
 
|-
 
|-
 
|}
 
|}
   
  +
キャッシュからの古いレコードのプルーニングは、{{ic|cache.prune_delay}} ごと (たとえば 5 分ごと) に行われます。キャッシュ内のレコードの accessed-at 値が {{ic|current-time + cache.threshold}} より小さい場合 (''cache.threshold'' の値は負の値である必要があることに注意してください)、キャッシュからレコードが削除されます。
rescached で保存されるキャッシュエントリの数は設定ファイルの ''cache.max'' の値によって決まります。''cache.max'' の上限に達すると、デーモンは ''cache.threshold'' に設定されている閾値よりもアクセスが少ないキャッシュエントリを全て削除します。
 
   
 
== インストール ==
 
== インストール ==
57行目: 70行目:
 
nameserver 127.0.0.1
 
nameserver 127.0.0.1
   
他のプログラムが設定を上書きしてしまうことがあります。詳しくは [[resolv.conf#DNS 設定保護]]を見てください。
+
他のプログラムが設定を上書きしてしまうことがあります。詳しくは [[ドメイン名前解決#/etc/resolv.conf の上書き]]を見てください。
   
 
設定できたら {{ic|rescached.service}} を[[起動]]・[[有効化]]してください。
 
設定できたら {{ic|rescached.service}} を[[起動]]・[[有効化]]してください。
   
== Integration with OpenResolv ==
+
== OpenResolv との統合 ==
   
  +
Rescached は、[[resolvconf]] によって生成された [[resolv.conf]] ファイルの変更を検出できます。
Rescached can detect change on "resolv.conf" file generated by resolvconf.
 
To use this feature set the "file.resolvconf" to "/etc/rescached/resolv.conf" in configuration file. In "/etc/resolvconf.conf" set either "dnsmasq_resolv", "pdnsd_resolv", or "unbound_conf" to point to the same file "/etc/rescached/resolv.conf".
+
この機能を使用するには、設定ファイルで {{ic|file.resolvconf}} {{ic|/etc/rescached/resolv.conf}} に設定します。{{ic|/etc/resolvconf.conf}} で、同じファイル {{ic|/etc/rescached/resolv.conf}}、{{ic|dnsmasq_resolv}}、{{ic|pdnsd_resolv}}、または {{ic|unbound_conf}} のいずれかを設定します。
   
  +
== web ユーザーインターフェース ==
== Web user interface ==
 
   
  +
再キャッシュされたサービスは、http://127.0.0.1:5380 でアクセスできる Web ユーザーインターフェイスを提供します。
The rescached service provide a web user interface that can be accessed at http://127.0.0.1:5380.
 
  +
最新リリースでは次のユーザーインターフェイスが利用可能です。
The following user interfaces are available on the latest release,
 
   
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_frontpage.png The front page].
+
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_frontpage.png The front page]
  +
フロントページでは、ユーザーがアクティブなキャッシュの監視、キャッシュのクエリ、およびキャッシュの削除を行うことができます。
The front page allow user to monitor active caches, query the caches, and removing the caches.
 
   
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_environment.png The environment page].
+
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_environment.png The environment page]
  +
''設定''ページでは、再キャッシュされた設定をその場で変更できます。
The Environment page allow user to modify the rescached configuration on the fly.
 
   
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_hosts_blocks.png The Hosts Blocks page].
+
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_hosts_blocks.png The Hosts Blocks page]
  +
ホストブロックページでは、ユーザーがホストブロックリストの外部ソースを有効または無効にすることができます。
The Hosts Blocks page allow user to enable or disable the external sources of hosts blocks list.
 
   
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_hosts_d.png The hosts.d page].
+
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_hosts_d.png The hosts.d page]
  +
Hosts.d ページでは、ユーザーは hosts ファイルの管理、新しい hosts ファイルの作成、新しいレコードの作成、またはレコードの削除を行うことができます。
The Hosts.d page allow user to manage hosts file, creating new hosts file, create new record, or delete a record.
 
   
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_zone_d.png The zone.d page].
+
* [https://raw.githubusercontent.com/shuLhan/rescached-go/master/_doc/images/Screenshot_wui_zone_d.png The zone.d page]
  +
Zone.d ページでは、ユーザーがゾーンファイルを管理や作成をしたり、ゾーンファイル内の新しいリソースレコードを追加または削除したりできます。
The Zone.d page allow user manage zone file, creating new zone file, adding or deleting new resource record in the zone file.
 
   
 
== 参照 ==
 
== 参照 ==
   
* 設定について詳しくは rescached の man ページを参照してください。
+
* 詳細と設定については、インストール後に {{man|5|rescached.cfg|url=}} を参照してください。
  +
* バグの報告と機能リクエストは [https://github.com/shuLhan/rescached-go/issues GitHub] で行うことを推奨します。
* 簡単な説明は [http://kilabit.info/journal/2009/12/04__rescached_is_here/index.html こちら] を参照。
 
* [http://kilabit.info/projects/rescached/doc/user/index.html ユーザードキュメント]
 
* [https://github.com/shuLhan/rescached/issues github]
 

2024年8月15日 (木) 13:40時点における最新版

関連記事

rescached はインターネットの名前解決・アドレス解決をキャッシュするデーモンです。実行中はローカルメモリに保存し、実行していない間はディスクキャッシュに保存されます。

rescachedBIND などの DNS サーバーの再実装ではありません。rescached の目標はあくまで DNS クエリをキャッシュして外部ネットワークへの不必要なトラフィックを減らすことにあります。個人的・小規模な環境での使用が想定されています。

特徴

現在の特徴の一覧です。

  • UDP と TCP 接続からの要求の処理を有効にする
  • UDP と TCP によるリクエストを提供できるようにする
  • /etc/hosts でアドレスとホストネームをロード・提供。
  • ディレクトリ /etc/rescached/hosts.d/ 内にホスト形式のファイルをロードして提供します
  • /etc/rescached/hosts.d/ のホストリストを通じて広告や悪意のある Web サイトをブロックする
  • /etc/rescached/zone.d からのゾーンファイル形式のロードと提供のサポート
  • openresolv との統合
  • DNS over TLS (DoH) (RFC 7858) をサポート
  • DNS over HTTPS (DoH) (RFC 8484) をサポート

rescached のキャッシュの仕組み

キャッシュ内の各 DNS レコードには、最終アクセス時刻フィールドがあり、メモリ内でキャッシュがどのように順序付けされるかを定義します。最後にクエリされたホスト名はキャッシュリストの最後にあり、クエリされた最も古いホスト名はキャッシュ リストの一番上にあります。

次の表は、メモリ内のキャッシュのリストを示しています。

Accessed At ホスト名
2018-01-01 00:00:01 kilabit.info
2018-01-01 00:00:02 archlinux.org
... ...
2018-01-01 00:01:00 wiki.archlinux.org

キャッシュからの古いレコードのプルーニングは、cache.prune_delay ごと (たとえば 5 分ごと) に行われます。キャッシュ内のレコードの accessed-at 値が current-time + cache.threshold より小さい場合 (cache.threshold の値は負の値である必要があることに注意してください)、キャッシュからレコードが削除されます。

インストール

rescached-gitAUR パッケージをインストールしてください。

設定

デフォルトで設定でデーモンを直接起動できます。

Rescached の設定は /etc/rescached/rescached.cfg に存在します。以下のような設定があります:

  • 親の DNS サーバーの設定:
server.parent の値を使用したい DNS サーバーに変えてください。
  • キャッシュの最大値の設定:
cache.maxcache.threshold の値を必要に応じて変更してください。

設定ファイルを編集したら、resolv.conf ファイルを開いてリゾルバのアドレスを localhost のアドレスで置き換えてください:

nameserver 127.0.0.1

他のプログラムが設定を上書きしてしまうことがあります。詳しくは ドメイン名前解決#/etc/resolv.conf の上書きを見てください。

設定できたら rescached.service起動有効化してください。

OpenResolv との統合

Rescached は、resolvconf によって生成された resolv.conf ファイルの変更を検出できます。 この機能を使用するには、設定ファイルで file.resolvconf/etc/rescached/resolv.conf に設定します。/etc/resolvconf.conf で、同じファイル /etc/rescached/resolv.confdnsmasq_resolvpdnsd_resolv、または unbound_conf のいずれかを設定します。

web ユーザーインターフェース

再キャッシュされたサービスは、http://127.0.0.1:5380 でアクセスできる Web ユーザーインターフェイスを提供します。 最新リリースでは次のユーザーインターフェイスが利用可能です。

フロントページでは、ユーザーがアクティブなキャッシュの監視、キャッシュのクエリ、およびキャッシュの削除を行うことができます。

設定ページでは、再キャッシュされた設定をその場で変更できます。

ホストブロックページでは、ユーザーがホストブロックリストの外部ソースを有効または無効にすることができます。

Hosts.d ページでは、ユーザーは hosts ファイルの管理、新しい hosts ファイルの作成、新しいレコードの作成、またはレコードの削除を行うことができます。

Zone.d ページでは、ユーザーがゾーンファイルを管理や作成をしたり、ゾーンファイル内の新しいリソースレコードを追加または削除したりできます。

参照

  • 詳細と設定については、インストール後に rescached.cfg(5) を参照してください。
  • バグの報告と機能リクエストは GitHub で行うことを推奨します。