Kubernetes vs. Terraformの翻訳です。
2022年3月18日
KubernetesとTerraformの比較
DevOpsの世界における2つの重鎮について一刀両断に分析する。
ツールは争いを好まないが、人々は "Xツール vs Yツール "の遺恨試合を仕掛けるのが好きだ。このブログでは、DevOpsの世界で重量級の2つの競合に光を当て、いくつかの一般的な誤解を明らかにしようと試みている。もしあなたがデータベースやデータエンジニアリングを理解しているが、データインフラにKubernetesをいつ使うべきか、Terraformをいつ使うべきかを理解するのに苦労しているのであれば、ぜひ読んでみてほしい。
Kubernetes vs. Terraform - 何が違うのか?
KubernetesとTerraformはどちらもDevOps分野のオープンソースプロジェクトだ。Kubernetesがコンテナを管理するためのオーケストレーションツール*であるのに対して、Terraformはアプリケーションの実行がコンテナであろうと巨大なモノリスであろうと、インフラをコードとして定義することができる。Kubernetesを使用するための最低限のエントリーフィーはコンテナを使用することです。しかし、アプリケーションをコンテナとして実行する場合、基盤となるインフラ(コンピュート、ストレージ、ネットワーク)は誰がセットアップするのでしょうか?アプリケーションはシン・エアーの上で動くわけではない。Terraform以前の時代では、SysAdminがスクリプトやAnsible playbookを書いて仮想マシンやベアメタルサーバを立ち上げて設定していた。Terraformでは、アプリケーション/データインフラをどのように計画するかを宣言することができ、Terraformはその計画に基づいて実行する。
Terraformでインフラを構築・管理し、Kubernetesでアプリケーションを格納するコンテナを管理する。
オーケストレーションと自動化
アプリケーションの観点から見ると、KubernetesやTerraformのようなツールはお互いを補完し合っている。どちらのツールも、システムを宣言的に定義することを可能にし、実行中のシステムをコードで定義されたものと一致させるために実行する。また、システム全体またはその一部に対してモジュール性と再利用性を提供する。こうして、まったく同じインフラを何度もコピーしながら、書くのは一度で済む。
データの観点からは、Terraformはステートフルなインフラストラクチャのプロビジョニングと管理にも役立つ。データベースであろうとストリーミングプラットフォームであろうと、正確な構成を指定すれば、Terraformはデータインフラストラクチャを立ち上げるための基礎となる依存関係とネットワーキングの面倒を見てくれる。
Kubernetes operatorsは、Kubernetesにおけるデータベースやストリーミングプラットフォームのようなカスタムリソースの定義を容易にします。Kubernetesのビルトインスケジューリング機能を使うことで、宣言的な方法でデータインフラストラクチャを作成・管理するためにこれらのオペレータを使うこともできます。
KubernetesとTerraformでAiven上のデータインフラをプロビジョニングする
KubernetesとTerraformのパワーを理解したところで、Aiven上でデータインフラストラクチャをプロビジョニングするためにそれらをどのように使用できるか見てみましょう。Aiven Terraform ProviderとAiven Operator for Kubernetesは、プログラム的にデータリソースを作成する方法を提供します。Aivenは、直感的なWebコンソール、強力なCLI、そしてこれら2つのDevOpsツールを提供していますが、あなたのビジネスに使用するツールをどのように選択しますか?
すでにTerraformに慣れ親しみ、他のインフラリソースのプロビジョニングに使用しているのであれば、Aiven Terraform Providerは完璧な選択となるでしょう。既存のスキルセットを使ってAivenリソースを作成・管理できます。Terraformプロバイダーは、インフラストラクチャのプロビジョニングのドライランを行い、作成するリソースをプレビューするのにも適しています。Terraformは、定義したリソースの依存関係も管理します。つまり、TerraformはどのAivenリソースを最初に作成すべきかを知ることができます。
一方、Aiven Operator for Kubernetesは、アプリケーションがすでにKubernetes上で動作していて、アプリケーションとデータリソースの両方を管理する単一のコントロールプレーンが必要な場合に理にかなっています。現在、このオペレーターはAiven for PostgreSQL®とAiven for Apache Kafka®のみをサポートしています。このツールを選択すると、Kubernetesの自己修復性と自動スケーリング特性の恩恵を受けることができます。
続きを読む
最も人気のある2つのオープンソースプロジェクトとして、KubernetesもTerraformも、サービスのデプロイ、監視、アップグレード、バックアップ、リストアのための独自のユースケースを持っている。Terraformはproviderを使って、アクセス可能なAPIを持つほぼすべてのプラットフォームやサービスと連携します。
Aiven Terraform クックブック
各 "レシピ "には、アーキテクチャ図と、セットアップを自分で構築するために必要なTerraformサンプルコードが含まれています。
[すべてのレシピを探そう!
これらのツールの詳細や、データインフラのプロビジョニングを自動化する方法については、他の記事もチェックしてみてください:
ついでにNavigating your Kubernetes logs with AivenでAivenがKubernetesとどのように連携しているか、Aiven databases with Terraform for fun and profitでTerraformとどのように連携しているかもご覧ください。
--
まだAivenのサービスをご利用になっていませんか?https://console.aiven.io/signupから無料トライアルにお申し込みください!
また、changelogやblogのRSSフィード、またはLinkedInやTwitterのアカウントをフォローし、製品や機能関連の最新情報をご確認ください。