• 日本語
    • English (英語)
Avinton JapanAvinton JapanAvinton JapanAvinton Japan
  • サービス
    • Avinton Data Platform
    • エッジAIカメラ
      • 自動車ナンバープレート自動認識システム
    • プライベートクラウド
    • AIサービス開発
    • AIカメラ/画像解析無料体験版
    • 見てわかる観光庁オープンデータ
  • 最新情報
    • ニュースリリース&イベント情報
    • 技術ブログ&インタビュー
  • アカデミー
    • Avintonアカデミー
    • Academy on Campus
    • Academy with Platform
  • 採用情報
    • Avintonジャパン 採用ページ
    • 求人一覧
    • よくある質問
    • 新卒採用
  • 企業情報
    • 会社概要
    • 代表からご挨拶
    • SDGsへの貢献
  • お問い合わせ

SampleアプリケーションのKubernetes上へのデプロイ

  • ルーティング
  • データベースの命名規則
  • 三目並べ – 2.〇×を交互にゲーム盤に入るようにしよう
  • 三目並べ – 3.勝敗がつくようにしよう
  • クリーンコード(Clean Code)
  • 三目並べ – 4.「スタート」「リセット」ボタンをつけよう
  • 三目並べ – 5.先攻後攻を決めて、コンピュータ対戦にしよう(前編)
  • インフラストラクチャー(サーバー、コンポーネント、RAID)
  • 機械学習入門者向け Support Vector Machine (SVM) に触れてみる
  • YOLOv8を用いた物体検出
  • 正規表現とパイプ
  • 機械学習エンジニアに必要なスキル
  • 軽量版Kubernetesディストリビューション – k0s クラスターの構築
  • ファイル操作コマンド
  • グループとユーザー
  • 困った時に使うコマンド
  • 一般グループのユーザーとグループ
  • プライバシーポリシー
  • 三目並べ – 6.先攻後攻を決めて、コンピュータ対戦にしよう(後編)
  • フロントエンド開発のための環境構築
  • ファイル検索コマンド
  • 質問
  • 仮想化環境のディスク容量を拡張する
  • ユーザー権限とアクセス権
  • データ分析基礎 – Part1
  • 三目並べ – 0.導入
  • テキスト処理
  • データベースへのデータロード
  • 機械学習概要1
  • 機械学習入門者向け Naive Bayes(単純ベイズ)アルゴリズムに触れてみる
  • ファイル管理
  • SSHを使用してホストOSからゲストOSに接続する
  • 機械学習入門者向け ChainerRLでブロック崩しの学習
  • 機械学習入門者向け ランダムフォレストによる Kaggle Titanic生存者予測
  • 機械学習概要2
  • データ分析基礎 – Part 2
  • 機械学習入門者向け 分類と回帰の違いをプログラムを書いて学ぼう
  • フロントエンドのWeb開発について
  • ダイナミックルーティング
  • 三目並べ – 1.ゲーム盤を作ろう
  • 【Python入門】Python Numpy チュートリアル
  • Amazon EC2 インスタンスの初期設定をしよう
  • AmazonEC2とVPCでネットワークとサーバーを構築しよう
  • Apache NiFi Exercise
  • Apache NiFi データパイプライン基礎
  • Apache NiFiの環境設定
  • Apache Spark 基礎
  • Apache SparkとApache Zeppelinの概要と環境構築
  • Apache Superset maptoolの使い方
  • Apache Superset 基礎
  • Apache Superset 概要と環境構築
  • Apache Zeppelin 基本機能
  • APIのデモンストレーション
  • Avinton Academy コンテンツガイド
  • AWS CLIをインストールしてコマンド操作しよう
  • AWS CLIを使ってEC2のファイルをS3へアップロードしよう
  • AWS Route 53を使って独自ドメインのWebページを表示させてみよう
  • AWSアカウントの作成と必ずやるべきセキュリティ対策
  • AWSのEC2インスタンスでWordPressブログを公開してみよう
  • AWS入門者向け 初心者が最初に理解すべきEC2とVPCの基本的な用語解説
  • CCNA
  • Certbotを使ってSSL証明書を発行し、HTTP通信を暗号化しよう
  • CISCO 1800ルータセットアップ
  • CSV import & export – Node.js, mySQL – 1
  • CSV import & export – Node.js, mySQL – 2
  • Docker Compose(Nginx + Flask + MySQL)演習
  • Docker Engineのubuntu上へのinstall
  • Docker 概要とセットアップ
  • Docker, Kubernetesの学び方について
  • Dockerコンテナイメージの最適化/ベストプラクティス
  • DockerとApacheを使ってWebサーバーを構築しよう
  • EC2からS3へ自動でぽいぽいアップロードするスクリプトの作成
  • ESP32-CAMのサンプルアプリケーションを実行する
  • 01 – Sparkfun Inventor’s Kit の準備
  • 02 – Sparkfun Inventor’s KitでLチカ
  • 03 ポテンショメータでLEDの点滅間隔をアナログ入力する
  • 04 フォトレジスタで明るさに反応するシステムをつくる
  • 05 LCDに文字列を表示する
  • 06 – BME280とLCDを組み合わせて温度計をつくる
  • ESP32とArduino IDE/PlatfromIOでHello Worldアプリケーションの実行
  • ESP32と超音波センサー HC-SR04 で物体の距離を計測する
  • ESXi – Switchの追加とVLAN
  • ESXi – VyOS
  • ESXi – 小規模ネットワーク 構築
  • Gitとは
  • VS CodeでGitHub Copilotを設定する
  • VSCode リモート開発環境
  • GNS3のセットアップ
  • Kubernetesクラスター上へのOpenVINOモデルサーバーを使用したサンプルアプリケーションのデプロイ
  • Linuxとは
  • NAT
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – Socket.IO編
  • NVIDIA Cumulus VX + GNS3でBGPネットワークのシミュレーション
  • OpenCVのテストプログラム
  • PacketTracerのセットアップ
  • Pandasによる構造化データ分析
  • PCからルータ、スイッチへのSSH接続設定
  • PostGIS exercise
  • PostgreSQL – Python – Apache – Bootstrap
  • MySQLとMySQL Workbench のセットアップ
  • PostgreSQL Setup
  • PostgreSQL – インデックスを利用したパフォーマンス改善方法
  • PostgreSQL – パーティショニングを利用したパフォーマンス改善方法
  • PostgreSQLによるデータ分析
  • postgreSQLへのshp fileのimport
  • Python2.7とOpenCVのインストール
  • Python3.8 と OpenCV のインストール (Ubuntu20.04LTS)
  • Pythonでデータベースを操作する
  • Pythonで画像を分類するプログラムを作成する
  • Pythonによるマルチスレッドプログラミング実践
  • Raspberry Pi 4B のセットアップ
  • Raspberry PiとBME280を使用して温度と湿度、気圧を読み取る
  • REDIS
  • Redux基礎 – 主要な概念と用語
  • Ruby on Rails を MySQLでセットアップ
  • Ruby on Railsによる簡単なウェブアプリケーション
  • SampleアプリケーションのKubernetes上へのデプロイ
  • Scala 基礎
  • scikit-learnとは
  • Spark SQL エクササイズ
  • SparkMLによるKaggle Titanic生存者予測
  • KNIME, AutoMLライブラリによる住宅価格予測
  • SparkMLによる住宅価格予測
  • SQL 便利な関数
  • Ubuntuの基本設定
  • uhubctlでUSBデバイスのオンオフをコントロール
  • Terraform入門 2 – Terraformのstate管理
  • Terraform入門 1 – TerraformでAWS上にEC2インスタンスを作成する
  • Virtualisation and Container (仮想化とコンテナ) – Ansible, Docker and Kubernetes
  • viエディタ
  • VLAN
  • VMware ESXi サーバー構築
  • Webアプリ開発に欠かせないGoogle Chrome DevToolsの基本
  • Windows Server 2012 R2 Hyper-V
  • Object Detection with YOLOv8
Home Avintonアカデミー SampleアプリケーションのKubernetes上へのデプロイ
Kubernetes logo

はじめに

このチュートリアルでは、docker composeで構築されたサンプルのアプリケーションをKubernetes上にデプロイします。DockerとKubernetesを一通り勉強したが、Kubernetes上にどのようにアプリケーションをデプロイするか分からない方におススメです。

目的

Kubernetes初級者やDevOps技術の学習者が、dockerとの違いを理解し、Kubernetes上にアプリケーションをデプロイする練習となることを目的としています。また、Kubernetes上でのコンテナイメージやボリューム、ネットワーク構成などを実際にデプロイしながら学びます。

対象:

  • LinuxやDocker、Kubernetesについての基礎知識がある
  • Dockerでアプリケーションのビルドをしたことがある
  • Webアプリケーションの基礎知識
  • Avinton Academy Docker compose 演習を実施済み

目標

こちらのdocker composeで構築されたサンプルアプリケーションをKubernetes上にデプロイします。アプリケーションの仕組みを理解するためにcompose.yamlをよく読み、一通りREADME通りにアプリケーションを動かしてみてください。

Deploying a sample application on Kubernetes

最終的な完成品として、以下の図のようにKubernetes上にデプロイします。

Deploying a sample application on Kubernetes

事前準備

必要なもの:

  • インターネット接続のあるLinux環境 (VM可)
  • 4GB memory + 4 CPU以上推奨
  • Dockerコマンドを利用できるビルド環境

 

1. ローカル環境にKubernetes環境を構築

以下のチュートリアルでは、簡単にセットアップできて便利なminikubeを使用します。minikubeはdockerコンテナとしてKubernetesクラスターをローカル環境上に構築できます。Kubernetesのバージョンはv1.25.2を使用します。任意のKubernetesクラスター、バージョンでも構いません。nodeがReadyステータスになっていることを確認してください。

1
$ minikube start --nodes 2

1
2
3
$ kubectl get node
NAME       STATUS   ROLES           AGE     VERSION
minikube   Ready    control-plane   4m30s   v1.25.2

 

2. PV/PVCを利用可能にする

任意のKubernetes Storage(CSI)をインストールします。minikubeの場合はデフォルトで準備されている以下のStorage classを使用します。

1
2
3
$ kubectl get storageclass
NAME                 PROVISIONER                RECLAIMPOLICY   VOLUMEBINDINGMODE   ALLOWVOLUMEEXPANSION   AGE
standard (default)   k8s.io/minikube-hostpath   Delete          Immediate           false                  5m33s

 

3. Container registryの準備

デプロイしたいアプリケーションのコンテナイメージを、Kubernetes側から利用できるようにする必要があります。minikubeの場合はこちらのリンクを参考にしてregistryのアドオンを有効化してください。

必要に応じてホスト側とminikube側の両方でinsecure registryの設定を行ってください。minikubeではクラスターの構築時にinsecure registryのアドレスを指定する必要があります。

1
2
$ minikube start --nodes 2 --insecure-registry "192.168.49.0/24"
$ minikube addons enable registry

クラウド上のレジストリやDockerHubを利用している方はそちらでも構いません。Kubernetesクラスター上でイメージをpullできることを確認してください。

タスク – サンプルアプリケーションのデプロイ

0. 準備

kubectlコマンドを正しく使用できることを確認してください。今回は、compose-to-kubeというnamespaceを作成し、その中で作業します。

1
kubectl create namespace compose-to-kube

またデプロイ対象となるアプリケーションの含まれるレポジトリをクローンします。nginx-flask-mysqlディレクトリに移動します。

1
2
git clone https://github.com/docker/awesome-compose.git
cd nginx-flask-mysql

 

1. DBのデプロイ

サンプルではMariaDBを使用しています。MariaDBはMySQLから派生したオープンソースのデータベースです。

DBなどのデータの状態を保持する”ステートフル”なアプリケーションをデプロイする場合は、Statefulsetが適しています。こちらのブログを参考にMariaDBをデプロイしてください。

YAMLファイルはそれぞれMariaDBのGitHubレポジトリから利用できます。YAMLファイルをダウンロード後、それぞれ以下の条件を満たすように設定してください。

  • mariadb-sts.yaml:
    • Serviceのnameはdbに変更してください
    • MariaDBのイメージにはmariadb:10-focalを使用してください
    • datadir Volumeには100MBを割り当ててください
    • Volumeのstorageclassは適宜変更してください
    • Replicaの数は1に変更してください
    • 2つの環境変数を設定してください
      • MARIADB_ROOT_PASSWORD: Secret mariadb-secretからmariadb-root-passwordの値を取得
      • MARIADB_DATABASE: “example”を指定してください
  • mariadb-secret.yaml:
    • mariadb-root-passwordの値は、こちらのファイルpassword.txtにある文字列db-78n9nに変更してください

最終的に次のコマンドでDBの一覧が取得できれば完了です。

1
2
3
4
5
6
7
8
9
10
$ kubectl exec -it mariadb-sts-0 -n compose-to-kube -- mariadb -uroot -pdb-78n9n -e "SHOW DATABASES;"
+--------------------+
| Database           |
+--------------------+
| example            |
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+

 

2. Backend

2.1 コンテナイメージのビルド&プッシュ

backendディレクトリに移動してコンテナイメージをビルドします。(注: buildkitを有効化する必要があります)

1
2
3
$ docker images backend
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
backend      latest    316613d9976e   3 hours ago   293MB

imageをkubernetesクラスター内のレジストリにpushします。 Minikubeの場合はこちらを参考にしてください。

2.1 Deployment YAMLファイルの作成

backendはDeploymentとして作成します。Deploymentでは作成したいレプリカの数を指定したり、バージョンのロールアウトやスケーリングが容易になります。

以下の条件を満たすように設定してください。

  • Secret mariadb-secretのmariadb-root-passwordの値を/run/secrets/db-passwordのパスにマウントしてください
    • ヒント: subPathを使用することで単一のファイルとしてマウントできます
  • Replicaの数は1に指定してください
  • TCP port 8000でリッスンするようにしてください

2.2 Service YAMLファイルの作成

Serviceを作成して、他のコンテナからbackendとしてアクセスできるようにします。

以下の条件を満たすように設定してください。

  • backendという名前で作成してください
  • TCP port 8000でリッスンするようにしてください
  • selectorを正しく指定して、2.1で作成したdeploymentのPodを指定してください

 

3. Nginx Proxy

最後に、Nginx Proxy(フロントエンド)をたててクラスター外部からbackendにアクセスできるようにします。

3.1 ConfigMapを作成

サンプルのレポジトリから、Nginxのconfファイルを取得します。そのファイルを使用してConfigMapを作成してください。

3.2 Deployment YAMLファイルの作成

NginxはDeploymentとして作成します。以下の条件を満たすように設定してください。

  • imageはnginx:1.13-alpineを使用してください
  • TCP port 80でリッスンするようにしてください
  • 3.1で作成したConfigMapを/etc/nginx/conf.d/default.confとしてマウントしてください
    • ヒント: subPathを使用することで単一のファイルとしてマウントできます
  • Replicaの数は1に指定してください

3.3 Service YAMLファイルの作成

以下の条件を満たすように設定してください。

  • proxyという名前で作成してください
  • TCP port 80でリッスンするようにしてください
  • selectorを正しく指定して、3.2で作成したdeploymentのPodを接続してください
  • NodePortタイプとして作成してください

検証

デプロイしたアプリケーションを検証します。次のコマンドで作成したすべてのリソースを確認します。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
$ kubectl get po,deployment,sts,svc,secrets,cm -n compose-to-kube
NAME                                      READY   STATUS    RESTARTS   AGE
pod/backend-deployment-6ccddcbc8d-hc69j   1/1     Running   0          50m
pod/mariadb-sts-0                         1/1     Running   0          42m
pod/nginx-deployment-6dc94b544-s28cn      1/1     Running   0          8m40s
 
NAME                                 READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/backend-deployment   1/1     1            1           63m
deployment.apps/nginx-deployment     1/1     1            1           11m
 
NAME                           READY   AGE
statefulset.apps/mariadb-sts   1/1     42m
 
NAME              TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
service/backend   ClusterIP   10.99.58.242    <none>        8000/TCP       26m
service/db        ClusterIP   None            <none>        3306/TCP       42m
service/proxy     NodePort    10.111.63.234   <none>        80:32755/TCP   2m1s
 
NAME                    TYPE     DATA   AGE
secret/mariadb-secret   Opaque   1      91m
 
NAME                         DATA   AGE
configmap/kube-root-ca.crt   1      92m
configmap/nginx-conf         1      15m

次のコマンドでproxyサービスのNodePortを確認します。以下の例では32755です。環境によって異なります。

1
2
3
$ kubectl get svc -n compose-to-kube proxy
NAME    TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
proxy   NodePort   10.111.63.234   <none>        80:32755/TCP   3m8s

次にKubernetesのnodeのIPアドレスを確認します。以下の例では192.168.49.2です。環境によって異なります。

1
2
3
$ kubectl get node -o wide
NAME       STATUS   ROLES           AGE   VERSION   INTERNAL-IP    EXTERNAL-IP   OS-IMAGE             KERNEL-VERSION      CONTAINER-RUNTIME
minikube   Ready    control-plane   96m   v1.25.2   192.168.49.2   <none>        Ubuntu 20.04.5 LTS   5.4.0-128-generic   docker://20.10.18

次のような出力が返ってきたら成功です。可能な方はブラウザからもアクセスしてみてください。

1
2
$ curl 192.168.49.2:32755
<div>   Hello  Blog post #1</div><div>   Hello  Blog post #2</div><div>   Hello  Blog post #3</div><div>   Hello  Blog post #4</div>

ログを確認します。nginx-deploymentとbackendの両方のコンテナにアクセスしたログが確認できました。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
$ kubectl logs -n compose-to-kube nginx-deployment-6dc94b544-xh9tj
172.17.0.1 - - [20/Oct/2022:07:52:56 +0000] "GET / HTTP/1.1" 200 132 "-" "curl/7.68.0" "-"
$
$
$ kubectl logs -n compose-to-kube backend-deployment-6ccddcbc8d-w48dk
* Serving Flask app 'hello.py' (lazy loading)
* Environment: development
* Debug mode: on
WARNING: This is a development server. Do not use it in a production deployment. Use a production WSGI server instead.
* Running on all addresses (0.0.0.0)
* Running on http://127.0.0.1:8000
* Running on http://172.17.0.7:8000
Press CTRL+C to quit
* Restarting with stat
* Debugger is active!
* Debugger PIN: 625-488-550
172.17.0.1 - - [20/Oct/2022 07:52:56] "GET / HTTP/1.0" 200 -

課題

  1. backend, proxy, dbのそれぞれのReplicaの数を,(1) kubectl scale、(2) kubectl applyを利用して3つにスケールしてください
  2. Nginx proxyはどのような場合に便利ですか
  3. ConfigMap, Secretはどのような場合に便利ですか
  4. Kubernetesでは実現可能で、docker composeでは実現不可能な特徴や機能はなにがありますか

チャレンジ課題

backendのhello.pyを編集して、DBのhost, port, database, userなどの値を環境変数から取得できるように更新してください。その後、新しくConfigMap backend-confを作成し、backendのdeploymentからそれぞれの値を環境変数として取得できるようにしてください。

まとめ

このタスクではdocker composeで記述されたアプリケーションをKubernetes上デプロイしました。まず、minikubeを使用したローカルのKubernetes環境の準備を行いました。Deployment、StatefulSet、Service、ConfigMap、SecretのYAMLを定義しました。その後、アプリケーションをデプロイし、NodePort経由でbackendのサービスにアクセスできることを確認しました。

Kubernetes上にデプロイしたことで、Kubernetesが定義された理想的な状態を維持します。replica数の変更やConfigの変更をkubectlなどを使用して、Kubernetes API経由で操作することができます。これにより、管理の自動化やCI/CDパイプラインの実装、モニタリングシステムとの統合など、より高度な操作を実現できます。また、nodeの数が2個以上に増えた場合などのスケーラビリティ、冗長性、負荷分散なども可能になります。

あなたも、Avintonでこのような最先端技術を習得し活用してみませんか?

社員の成長を導きながら、AIやビッグデータなどの最先端技術をプロジェクトに活用していくことが私たちのビジョンです。Avintonの充実した技術研修でスキルアップを図り、あなたのキャリア目標を一緒に達成しませんか?

採用情報

採用情報

採用情報

Categories

  • 相互学習
  • 採用
  • 社員インタビュー
  • 学習&資格取得
  • 技術解説
  • イベント告知
  • 学内説明会&講義
  • 産学連携
  • 就職活動
  • イベントレポート
  • その他
  • 技術ブログ&インタビュー
  • mainpage
  • New Graduates Interviews
  • 中途エンジニア
  • カテゴリーなし
  • ニュースリリース&イベント

Avinton SDGs

SDGsへの貢献

Search

タグ

AIカメラ AI時代の経営 AvintonAcademy on Campus AWS Big Data ccna Digital Transformation Docker DQN Edge AI FINOLAB Git James Cauchi LPIC-2 PM&PMO Raspberry Pi SSD イベントレポート エリクソン キャリア クラウトネイティブ コンテナ技術 ディープラーニング データベース データ分析 データ生成 ファンダフルリレーマラソン モブワーク リスキリング リードエンジニア 中瀬幸子 交流会 企業説明会 医療 大学&専門学校 就職活動 帰社日 強化学習、機械学習 技術ブログ 掲載告知 未経験 田中 研之輔 社員紹介 第一級陸上特殊無線技士 観光データ
© 2023 Avinton | All Rights Reserved | プライバシーポリシー
  • サービス
    • Avinton Data Platform
    • エッジAIカメラ
      • 自動車ナンバープレート自動認識システム
    • プライベートクラウド
    • AIサービス開発
    • AIカメラ/画像解析無料体験版
    • 見てわかる観光庁オープンデータ
  • 最新情報
    • ニュースリリース&イベント情報
    • 技術ブログ&インタビュー
  • アカデミー
    • Avintonアカデミー
    • Academy on Campus
    • Academy with Platform
  • 採用情報
    • Avintonジャパン 採用ページ
    • 求人一覧
    • よくある質問
    • 新卒採用
  • 企業情報
    • 会社概要
    • 代表からご挨拶
    • SDGsへの貢献
  • お問い合わせ
  • 日本語
    • English (英語)
Avinton Japan