CoreDNS コンポーネントが古いバージョンであるにもかかわらず、Container Service for Kubernetes (ACK) コンソールの [コンポーネント管理] ページでアップグレードボタンが利用できない場合、お使いのクラスターは CoreDNS の自動アップグレードをサポートしていません。このトピックでは、CoreDNS を手動でアップグレードする方法について説明します。
前提条件
kubectl ツールを使用してクラスターに接続します。詳細については、「kubectl を使用してクラスターに接続する」をご参照ください。
開始する前に
kube-proxy のロードバランシングモードとして IPVS を使用している場合、CoreDNS のアップグレード完了後、最大 5 分間、クラスター全体の DNS 解像度のタイムアウトまたは失敗が発生する可能性があります。この IPVS のバグの影響は、次のいずれかの方法で軽減できます。
kube-proxy で IPVS の UDP セッション維持のタイムアウト期間を変更します。詳細については、「IPVS ベースのクラスターの UDP タイムアウト期間を設定する」をご参照ください。
NodeLocal DNSCache を使用します。詳細については、「NodeLocal DNSCache を使用する」をご参照ください。
アップグレードプロセスには約 2 分かかります。実際に必要な時間は、クラスター内の CoreDNS レプリカの数によって異なる場合があります。古いレプリカは停止されません。これにより、アプリケーションの DNS 解像度が影響を受けないことが保証されます。
現在の CoreDNS バージョンの確認
コンソールの使用
ACK コンソールにログインします。左側のナビゲーションウィンドウで、[クラスター] をクリックします。
クラスター ページで、管理するクラスターを見つけてその名前をクリックします。左側のナビゲーションウィンドウで、 を選択します。
[ステートレス] ページの上部で、[名前空間] を kube-system に設定し、CoreDNS のバージョンを表示します。

kubectl の使用
次のコマンドを実行して、現在の CoreDNS バージョンを確認します。
kubectl get deployment coredns -n kube-system -o jsonpath="{.spec.template.spec.containers[0].image}"期待される出力:
registry-vpc.cn-hangzhou.aliyuncs.com/acs/coredns:1.6.2 # 1.6.2 はこの例で使用されているバージョンです。ターゲットアップグレードバージョンの確認
アップグレードする前に、ターゲットの CoreDNS バージョンを決定します。次の表に、CoreDNS バージョンとクラスターバージョンの互換性を示します。クラスターと互換性のある最新の CoreDNS バージョンを使用する必要があります。
Kubernetes バージョン | CoreDNS バージョン |
1.11 から 1.16 | v1.6.2 (メンテナンス終了) |
1.14.8 から 1.22 | v1.6.7 (メンテナンス終了)、v1.7.0 |
1.20.4 以降 | v1.8.4、v1.9.3 重要 v1.8.4 と v1.9.3 には、 |
1.21 以降 | v1.11.3 |
手動アップグレード
コンソールの使用
(オプション)
proxyフィールドをforwardフィールドに置き換えることができます。Proxy プラグインは CoreDNS v1.6.2 で非推奨になりました。v1.6.2 より前のバージョンから v1.6.2 以降のバージョンにアップグレードする場合は、次のように CoreDNS 構成を手動で変更する必要があります。
CoreDNS イメージのバージョンを更新します。
ACK コンソールにログインします。左側のナビゲーションウィンドウで、[クラスター] をクリックします。
クラスター ページで、管理するクラスターを見つけてその名前をクリックします。左側のナビゲーションウィンドウで、 を選択します。
[ステートレス] ページで、[名前空間] を kube-system に設定します。[coredns] を見つけます。[アクション] 列で、 を選択します。
[YAML の編集] ページで、
imageフィールドのバージョンを更新し、[更新] をクリックします。
アップグレードが成功したことを確認します。
次のコマンドを実行して、現在の CoreDNS バージョンを確認します。
kubectl get deployment coredns -n kube-system -o jsonpath="{.spec.template.spec.containers[0].image}"期待される出力:
registry-cn-shanghai-vpc.ack.aliyuncs.com/acs/coredns:v1.9.3.10-5e7ba42d-aliyun次のコマンドを実行して、クラスター内のすべての CoreDNS Pod が実行中状態であることを確認します。
kubectl get pods -n kube-system | grep coredns期待される出力:
coredns-78d4b8****-6g62w 1/1 Running 0 9d coredns-78d4b8****-n6wjm 1/1 Running 0 9d
kubectl の使用
(オプション)
proxyフィールドをforwardフィールドに置き換えることができます。Proxy プラグインは CoreDNS v1.6.2 で非推奨になりました。v1.6.2 より前のバージョンから v1.6.2 以降のバージョンにアップグレードする場合は、次のように CoreDNS 構成を手動で変更する必要があります。
次のコマンドを実行して CoreDNS 構成を編集します。
imageフィールドのバージョンを更新し、変更を保存して終了します。kubectl edit deployment/coredns -n kube-systemアップグレードが成功したことを確認します。
次のコマンドを実行して、現在の CoreDNS バージョンを確認します。
kubectl get deployment coredns -n kube-system -o jsonpath="{.spec.template.spec.containers[0].image}"期待される出力:
registry-cn-shanghai-vpc.ack.aliyuncs.com/acs/coredns:v1.9.3.10-5e7ba42d-aliyun次のコマンドを実行して、クラスター内のすべての CoreDNS Pod が実行中状態であることを確認します。
kubectl get pods -n kube-system | grep coredns期待される出力:coredns-78d4b8****-6g62w 1/1 Running 0 9d coredns-78d4b8****-n6wjm 1/1 Running 0 9d
coredns-78d4b8****-6g62w 1/1 Running 0 9d coredns-78d4b8****-n6wjm 1/1 Running 0 9d
IPVS クラスターの UDP タイムアウトの設定
クラスターが kube-proxy IPVS モードを使用している場合、IPVS セッション維持ポリシーにより、アップグレード後 5 分間、クラスター全体で断続的な DNS 解像度の失敗が発生する可能性があります。解像度の失敗回数を減らすには、IPVS UDP セッション維持のタイムアウトを 10 秒に短縮できます。クラスターに UDP ベースのサービスがある場合は、続行する前にこの操作の潜在的な影響を評価してください。
クラスターが IPVS クラスターでない場合は、このセクションを無視できます。kube-proxy プロキシモードの確認方法の詳細については、「クラスター情報の表示」をご参照ください。
Kubernetes 1.18 以降のクラスターの場合
コンソールの使用
ACK コンソールにログインします。左側のナビゲーションウィンドウで、[クラスター] をクリックします。
クラスター ページで、変更するクラスターの名前をクリックします。左側のナビゲーションウィンドウで、 を選択します。
[ConfigMap] ページで、[kube-system] 名前空間を選択します。kube-proxy-worker ConfigMap を見つけ、[アクション] 列の [YAML の編集] をクリックします。
[YAML の表示] パネルで、ipvs フィールドの下に
udpTimeout: 10sを追加し、[OK] をクリックします。apiVersion: v1 data: config.conf: | apiVersion: kubeproxy.config.k8s.io/v1alpha1 kind: KubeProxyConfiguration # 他の無関係なフィールドは省略されます。 mode: ipvs # ipvs キーが存在しない場合は、追加します。 ipvs: udpTimeout: 10skube-proxy-worker という名前のすべての Pod を再作成します。
[クラスター情報] ページの左側のナビゲーションウィンドウで、 を選択します。
DaemonSet リストで、[kube-proxy-worker] を見つけてクリックします。
[kube-proxy-worker] ページで、[Pod] タブをクリックします。Pod の行で、 を選択し、[OK] をクリックします。
このステップを繰り返して、すべての Pod を削除します。Pod が削除されると、システムは自動的にそれらを再作成します。
UDP タイムアウトが設定されていることを確認します。
次のコマンドを実行して [ipvsadm] をインストールします。
[ipvsadm] は IPVS モジュールの管理ツールです。詳細については、「ipvsadm」をご参照ください。
sudo yum install -y ipvsadmクラスター内の任意の ECS ノードで次のコマンドを実行し、出力の 3 番目の数値を確認します。
sudo ipvsadm -L --timeout出力の 3 番目の数値が 10 の場合、IPVS クラスターの UDP タイムアウトは正常に変更されています。
変更が成功したら、次のステップに進む前に少なくとも 5 分間待ちます。
コマンドラインの使用
次のコマンドを実行して、kube-proxy-worker 構成ファイルを編集します。
kubectl -n kube-system edit configmap kube-proxy-workerkube-proxy 構成ファイルで、ipvs フィールドの下に
udpTimeout: 10sを追加します。次に、ファイルを保存して終了します。apiVersion: v1 data: config.conf: | apiVersion: kubeproxy.config.k8s.io/v1alpha1 kind: KubeProxyConfiguration # 他の無関係なフィールドは省略されます。 mode: ipvs # ipvs キーが存在しない場合は、追加します。 ipvs: udpTimeout: 10s次のコマンドを実行して、kube-proxy-worker という名前のすべての Pod を再作成します。
次のコマンドを実行して、既存の Pod に関する情報を表示します。
kubectl -n kube-system get pod -o wide | grep kube-proxy-worker次のコマンドを実行して、前のステップで見つけた Pod を削除します。システムは、kube-proxy-worker という名前の Pod を自動的に再作成します。
kubectl -n kube-system delete pod <kube-proxy-worker-****><kube-proxy-worker-****> を前のステップで見つけた Pod の名前に置き換えます。
UDP タイムアウトが設定されていることを確認します。
次のコマンドを実行して [ipvsadm] をインストールします。
[ipvsadm] は IPVS モジュールの管理ツールです。詳細については、「ipvsadm」をご参照ください。
sudo yum install -y ipvsadmクラスター内の任意の ECS ノードで次のコマンドを実行し、出力の 3 番目の数値を確認します。
sudo ipvsadm -L --timeout出力の 3 番目の数値が 10 の場合、IPVS クラスターの UDP タイムアウトは正常に変更されています。
変更が成功したら、次のステップに進む前に少なくとも 5 分間待ちます。
Kubernetes 1.16 以前のクラスターの場合
これらのバージョンを実行するクラスターの kube-proxy コンポーネントは、udpTimeout パラメーターをサポートしていません。Operation Orchestration Service (OOS) を使用して、すべてのクラスターノードで ipvsadm コマンドをバッチで実行し、UDP タイムアウト構成を調整できます。コマンドは次のとおりです。
sudo yum install -y ipvsadm
sudo ipvsadm -L --timeout > /tmp/ipvsadm_timeout_old
sudo ipvsadm --set 900 120 10
sudo ipvsadm -L --timeout > /tmp/ipvsadm_timeout_new
diff /tmp/ipvsadm_timeout_old /tmp/ipvsadm_timeout_newOOS でのバッチ操作の詳細については、「インスタンスの一括操作」をご参照ください。
次のステップ
アップグレードが完了したら、CoreDNS を最適化および設定できます。詳細については、「CoreDNS 構成の最適化」をご参照ください。
