この記事では、軽量デプロイのK3sを例に、すでにK8sクラスタをデプロイしている場合、この記事の後半の設定を参考に同様の設定を行うことができます。
このチュートリアルは、操作を行う前に必ず全文を読むようにしてください。そうしないと、デプロイ結果が期待通りにならない可能性があります。
Docker公式サイトで関連するインストール手順を見つけることができます。そして、クイックスタートの基本設定を使用してGZCTFを起動します。
k3sは軽量なk8sディストリビューションで、シングルマシンやマルチマシン上でk8sクラスタを迅速にデプロイすることができます。公式ドキュメントのURL:https://docs.k3s.io
もしサーバーが1台だけの場合、他の方法でデプロイすることを強くお勧めします:
最後に、どうしてもDockerを使用してk3sを実行したい場合、インストール時に以下のパラメータを追加してDockerバックエンドを指定できますが、強くお勧めしません。さまざまな互換性の問題を修正する必要があるかもしれず、多くの困難が生じる可能性があります。
もし一台のk3sインスタンスで255個を超える問題コンテナを実行したい場合は、k3sのインストール時にINSTALL_K3S_EXECを指定し、node-cidr-mask-sizeを必要なサブネットサイズに変更する必要があります。
上記の設定はインストール後に容易には変更できません。 推奨は /22(各ノード約 1024 Pod)で、必要に応じて /20(各ノード約 4096 Pod)を使用してください。さらに大きくしても(例: /16)単一ノードに過大なアドレス空間を確保するだけで、worker を増やしてスケールさせる能力を損ないます。
上記の設定は、ノードのPodが使用するIPアドレス範囲を変更するだけであり、ノードのPod数制限を変更する場合は、以下を参照してください。
そして、以下の形式でk3sをインストールします。詳細はk3sのインストール設定を参照してください:
中国のユーザーは、以下の方法でインストールを高速化することができます:
マルチマシンのインストールとクラスタの構築については、公式ドキュメントを参照してください。
k3sの接続設定ファイルは/etc/rancher/k3s/k3s.yamlにあり、以下のコマンドでエクスポートできます:
以下のコマンドを使用して、k3s control-panelが存在するマシンのIPを取得します:
もし127.0.0.1が表示された場合、それはk3s control-panelが現在のマシンであることを意味します。ip aを使用して現在のマシンのIPを確認してください。
IPアドレスを直接使用することも、ドメイン名を使用することもできますが、ドメイン名がk3s control-panelのあるマシンに解決され、GZCTFのマシンがその6443ポートにアクセスできることを確認する必要があります。
上記の出力内容をkube-config.yamlとして保存し、serverフィールドをk3s control-panelのあるマシンのIPに変更します。例えば、
これをGZCTFをデプロイするマシンに保存し、compose.ymlと同じフォルダに置きます。例えばkube-config.yamlとします。
次にcompose.ymlのマウント情報を変更します:
同時にappsettings.jsonを変更し、ContainerProviderフィールドを設定します:
GZCTFを再起動すると、k3sをコンテナバックエンドとして使用できるようになります。すでにk8sを使用した経験があるユーザーは、上記の設定プロセスを参考にして、GZCTFを既存のk8sクラスタに接続することができます。
k3sのデフォルトのNodePortポート範囲は30000-32767ですが、これは要件と一致しない場合があります。そのため、必要に応じてk3sのNodePortポート範囲を変更することができます。
k3s control-panelが存在するマシンで以下のコマンドを実行します:
sudo nano /etc/systemd/system/k3s.service
ExecStartの設定を編集し、service-node-port-rangeを指定します。
sudo systemctl daemon-reload
sudo systemctl restart k3s
k3sのデフォルトのコンテナ数制限は110ですが、これは大量の小さなコンテナを含むゲームには適していないかもしれません。そのため、必要に応じてk3sのコンテナ数制限を変更することができます。
k3s control-panelが存在するマシンで、内蔵の設定ファイル /etc/rancher/k3s/config.yaml を使用して調整します:
sudo nano /etc/rancher/k3s/config.yaml
以下を追加・編集します(例:各ノードの上限を 800 に設定):
保存後、サービスを再起動して反映します:
オプション:各ノードにより大きな Pod サブネットを確保したい場合は、同じファイルで kube-controller-manager-arg を設定します。推奨は /22(各ノード約 1024 Pod)、必要に応じて /20:
注意:node-cidr-mask-size を小さくしすぎる(例:/16)と、単一ノードに過大なアドレスブロックが割り当てられ、worker を追加して水平スケールする柔軟性が低下します。
外部のコンテナイメージリポジトリは、k3sで直接使用することはできません。そのため、k3sにイメージリポジトリを追加する必要があります。
k3s control-panelが存在するマシンで以下のコマンドを実行します:
sudo nano /etc/rancher/k3s/registries.yaml
mirrorsの設定を編集し、必要なイメージリポジトリのアドレスを指定します。
sudo systemctl restart k3s