このドキュメントでは、Google Distributed Cloud コネクテッド のドメイン ネーム システム(DNS)プロバイダ オプションを構成する方法について説明します。クラスタの DNS 構成は、default という名前の
ClusterDNS カスタム リソースに保持されます。このリソースはクラスタ全体にわたります。つまり、名前空間はありません。ClusterDNS
カスタム リソースは、すべてのクラスタタイプに適用されます。
ClusterDNS リソースを作成する
default という名前の ClusterDNS リソースのマニフェストを作成します。spec に入力して、必要なリソース設定を構成します。次に例を示します。
apiVersion: networking.gke.io/v1alpha1
kind: ClusterDNS
metadata:
name: default
spec:
upstreamNameservers:
- serverIP: 8.8.8.8
- serverIP: 8.8.4.4
domains:
- name: altostrat.com
nameservers:
- serverIP: 198.51.100.1
- name: my-own-personal-domain.com
nameservers:
- serverIP: 203.0.113.1
- serverIP: 203.0.113.2
serverPort: 54
googleAccess: default
マニフェストを my-dns.yaml という名前のファイルに保存して、リソースをクラスタに適用するには、次のコマンドを実行します。
kubectl --kubeconfig KUBECONFIG apply -f my-dns.yamlKUBECONFIG は、クラスタの kubeconfig ファイルのパスに置き換えます。
ClusterDNS リソースの表示
ClusterDNS リソースを表示するには、次のコマンドを実行します。
kubectl --kubeconfig KUBECONFIG get clusterdns default --output yamlKUBECONFIG は、クラスタの kubeconfig ファイルのパスに置き換えます。
ClusterDNS の仕様
以下の各セクションでは、クラスタの DNS を構成するために使用する ClusterDNS カスタム リソース定義の一部について説明します。クラスタの ClusterDNS リソースはいつでも更新できます。
spec.upstreamNameservers
spec.upstreamNameservers フィールドを使用して、デフォルトのアップストリーム
ネームサーバーをオブジェクトの配列とともに指定します。各オブジェクトには、サーバーの IP
アドレスと、必要に応じてサーバーポートがあります。サーバーポートのデフォルト値は 53
です。
クラスタ以外のドメインのリクエストは、デフォルトでこのサーバーセットに転送されます。
以下は、upstreamNameservers 構成の例です。
spec:
upstreamNameservers:
- serverIP: 8.8.8.8
- serverIP: 1.2.3.4
serverPort: 54
upstreamNameservers の値を指定しない場合、DNS プロバイダはノード上の /etc/resolv.conf ファイルを使用して、アップストリーム ネームサーバーのリストを検索します。
spec.domains
spec.domains フィールドを使用して、特定のドメイン用に異なるアップストリーム
ネームサーバーを構成します。これらのドメイン特有のネームサーバーの設定は、upstreamNameservers
の構成をオーバーライドします。
ドメインのクエリロギングをオンにすることもできます。指定したドメインまたはクラスタ ドメインである cluster.local
に対してクエリロギングをオンにできます。
以下は、spec.domains 構成の例です。
spec:
domains:
- name: altostrat.com
nameservers:
- serverIP: 198.51.100.1
- name: my-own-personal-domain.com
nameservers:
- serverIP: 203.0.113.1
- serverIP: 203.0.113.2
serverPort: 50000
- name: cluster.local
queryLogging: true
spec.googleAccess
spec.googleAccess フィールドは、Google ドメインの処理方法を指定する文字列です。googleAccess
値は、次の動作を指定します。
default: Google ドメインの特別な処理はありません。googleAccessフィールドを削除しても結果は同じです。private: Google ドメインは、プライベート アクセス IP アドレスにのみ名前解決されます。restricted: Google ドメインは、アクセス制限付き IP アドレスにのみ名前解決されます。
次の設定例では、Google ドメインはプライベート アクセス IP アドレスにのみ名前解決されます。
spec:
googleAccess: private
詳細については、オンプレミス ホスト用のプライベート Google アクセスの構成 をご覧ください。