Container Service for Kubernetes (ACK)をアップグレードしよう❗️
Container Service for Kubernetes (ACK)をアップグレードしよう❗️
はじめに
6月は KubeCon China 2019 もありましたし、定期リリースのKubernetes 1.15 もリリース(2019年6月19日(米国時間))されましたね😄
https://kubernetes.io/blog/2019/06/19/kubernetes-1-15-release-announcement/
個人的にはAlibaba Cloud Container PlatformチームがオープンソースとしてKubeCon Chinaで発表したOpenKruiseが気になりますね🤔
色々と気になるネタも多いKubernetes界隈ですが、今回はITに置いて避けては通れないアップグレードに関して、Alibaba Cloud Container Service for Kubernetes (ACK) のアップグレード方法をご紹介したいと思います。
アップグレード手順は公式ドキュメントでも公開されていますが、手順にはない部分での注意点やポイントなどご紹介させて頂きたいと思います❗️
https://www.alibabacloud.com/cloud-tech/doc-detail/86497.htm
Container Service for Kubernetes のアップグレード
ACKのアップグレードは手動でアップグレードの開始を行う必要がありますが、実行を選択するだけでアップグレード処理自体は自動的に実施されます😊
なお、現状日本サイトで提供しているDedicated タイプ(Master Node 有り)のACKではMaster、Worker共に手動での更新実行が必要になります。
残念ながらスケジュール実行の機能は提供しておりません😣
ℹ️管理コンソールのデザインが旧コンソールになっていますが、手順に違いはありません。
ACKで利用可能なKubernetesのバージョンはAlibaba Cloudのプロダクトチームにより管理されています。
利用可能なKubernetesのバージョンがAlibaba Cloudで公開されるとACKのクラスターリスト画面にて「クラスターのアップグレード」に下図のような🔴が表示されます。
※ 該当のクラスターで現在使用中のバージョンよりも新しいバージョンが利用可能な場合に表示されます。
「クラスターのアップグレード」を選択すると下図の様に「アップグレード可能なバージョン」が表示されます。
アップグレード可能なバージョンはACKの提供する最新バージョンへのアップグレードのみとなります。また、連続したバージョンでなくてもアップグレードが可能です。ℹ️タイミングによりバラツキはありますがKubernetesの最新リリースから1~2バージョン前のマイナーバージョンでのご提供です。
本記事執筆時点ではバージョン1.12でのご提供となっています。近々新しいバージョンが提供されるかと思います。
「確認」を選択することでアップグレード処理が開始されます。
あとは正常に終了するのを待つだけです。
アップグレードが実行できない場合
アップグレードを実行した際に下図の様なエラーが発生することがあります。
とても分かりにくくて申し訳ないのですがメッセージ内に必要な作業が記載されていることがあります😓
下図でいうとPlease update your terway to newest version.
と表示されている部分が該当します。
先程のエラーはterway
をアップデートしろとなっていましたのでその作業を行います。
ℹ️terway
はAlibaba Cloud の開発したCNI Network Pluginです、詳しくは下記のリンクをご覧ください。
https://www.alibabacloud.com/cloud-tech/doc-detail/97467.html
クラスターリスト画面にて「アドオンのアップグレード」を選択します。
ACK用のコンポーネントが表示されますので必要なもの、今回ですとterway
のアップグレードを選択します。
確認画面が出ますので「確認」を選択します。
アップグレードが完了すると対象のコンポーネントが「最新」になります。
画面を閉じて再び「クラスターのアップグレード」を実施して下さい。
正常にアップグレードが出来る場合
正常に開始できた場合、以下の様な画面が表示されアップグレードが実行されます。
アップグレード実行中にノードの状態を確認してみます。kubectl get nodes
でノードのステータスが確認できます。
一斉にアップグレードが実施される訳ではなく、ローリングで各ノードのアップグレードが実施されます。
この時はMaster Node 3台、Worker Node 4台の計7台のアップグレードでしたが10分ほどで完了しました。
※アップグレード中はMaster が命令を受け付けないので、Node追加やDeploymentなどが実施できません。
kubectl get nodes
でノードのステータスを確認すると全てのノードのVersionが更新されています。
アップグレードのポイント整理
アップグレードのポイントに関して最後に簡単にまとめたいと思います。
最後に
如何でしたでしょうか?
Kubernetesのアップグレードは大変なイメージがありますが、ACKでは簡単に実現できたのではないでしょうか😊
Alibaba CloudのKubernetes Serviceは管理コンソールから使い易く出来ている部分が多く、Kubernetesが初めてでも比較的使い易く、運用しやすいサービスではないかなと思います。
Kubernetesを使ってみたいけど難しそうと思っていた方も、是非使ってみてください🤗