KubernetesとOpenStack:どちらを選ぶ?

by Canonical on 8 May 2023

KubernetesかOpenStackの選択は、最新のITインフラストラクチャを導入した組織に共通の悩みです。どちらもクラウドインフラストラクチャを構築する確立されたオープンソース技術であり、併用した場合には特に、それぞれ明確なメリットがあります。しかし2つの違いは大きく、ソリューションとして完全に統合するにはコツが要ります。

具体的にはどういう意味でしょうか? 一緒に見ていきましょう! 最初にOpenStackとKubernetesの概要を説明します。次に2つの類似点と相違点に注目し、上手に統合する方法を検討します。

同じ内容をウェビナーでご覧になりたい方は、どうぞご登録ください >

KubernetesとOpenStack:いったいどんなもの?

「KubernetesかOpenStackか」という迷いは、両方に対する理解不足から生じるのが一般的です。KubernetesはOpenStackの後継? KubernetesはOpenStackに取って替わった? 2つの技術の関係は? これを理解するため、いったんOpenStackとKubernetesの定義に戻りましょう。

OpenStackとは?

OpenStackとはクラウドプラットフォームです。分散したコンピューティング、ネットワーク、ストレージリソースを管理し、プールにまとめた上で、セルフサービスポータルを通じて仮想リソースのオンデマンドプロビジョニングを可能にします。Amazon Web Services(AWS)Elastic Compute Cloud(EC2)をご存じなら、十分に機能的なプライベートクラウドやパブリッククラウドを構築するという点で似たようなものと言えます。OpenStackは、大手テレコム会社サービスプロバイダー金融機関製造企業、行政機関に広く利用されています。

Kubernetesとは?

Kubernetes(K8s)は、コンテナオーケストレーションプラットフォームです。コンテナ化したワークロードやサービスの運用、ネットワーキング、拡張、提供を自動化します。少数のコンテナなら手動でも対処できます。しかしKubernetesのような自動機能なしに実運用環境で大規模に管理するのは大変な作業です。近年、Kubernetesは、パブリッククラウドデータセンターエッジサイト、さらにはIoTなどさまざまなインフラストラクチャで活用されています。

KubernetesとOpenStack:類似点と相違点

OpenStackとKubernetesは、2つのコミュニティが別々の技術的問題を解決するために開発しました。したがって一部の機能が重複するものの、動作理念は異なります。次に、この2つの最も一般的な類似点と相違点を見てみましょう。

対応するワークロードのタイプ

もともとOpenStackは仮想マシン(VM)、Kubernetesはコンテナのみのサポートに使用されていました。しかし今では違います。2つの技術は時とともに進化し、あらゆるタイプのワークロードに対応しました。現在、OpenStackは、Ironicプロジェクトでベアメタル、Magnumプロジェクトでコンテナ化されたワークロードもサポートしています。一方、Kubernetesのユーザーは、Metal³などのツールを利用して物理的なマシンやKataコンテナ、KubeVirtを利用してVMのプロビジョニングが可能です。

メタル管理機能

OpenStackはベアメタルで直接動くよう設計されています。したがってメタル管理機能については一般にKubernetesより進んでいます。Kubernetesも物理レイヤーで直接実行できますが、OpenStackの13年の実績にはかないません。市販のストレージプラットフォームやSDN(ソフトウェア定義ネットワーク)コントローラ、あるいはパフォーマンス強化機能(ハードウェアオフローディングなど)との統合には、一般にOpenStackのほうがよく対応しています。

アプリケーション管理機能

逆にアプリケーション管理に関してはKubernetesの右に出るものはありません。Kubernetesは、各種のコントローラ(ReplicaSetやDaemonSet)、クラウドネイティブ機能など、豊富なアプリケーション管理機能を備えています。これにはローリングアップデートやオートスケーリングも含まれます。OpenStackのコミュニティも、かつてHeatプロジェクトとMuranoプロジェクトでこの欠点を埋める努力をしましたが、高い成果は出ず、アプリケーション管理の分野ではKubernetesに遅れを取っています。

両方の長所を活用

ここまでで、OpenStackとKubernetesのどちらも、すべての機能を備えているわけではないことがおわかりいただけたでしょう。それぞれ別の目的で作られているからです。最も妥当なのは両方を併用することです。

OpenStackでKubernetesを実行

OpenStackの上でKubernetesを実行することには多くの利点があります。まずベアメタルで直接実行するのが簡単になることです。OpenStack上でKubernetesクラスターを即座にプロビジョニングするツールは、Juju、Magnum、Cluster APIなどいくつかあります。これにより各ユーザーや事業体はクラウドリソースの専用プールを取得し、そこで必要に応じてK8sを実行することでOpenStackのマルチテナンシーを活用できます。さらに前述のように、このK8sクラスターでOpenStackのメタル管理機能(Octaviaによる適切なロードバランシング、vGPUリソースプロビジョニングなど)を利用することもできます。

KubernetesでOpenStackを実行

逆にOpenStackのコントロールプレーンをKubernetesの上で実行することにもメリットがあります。最も重要なのはOpenStackのサービスがしっかり隔離され、根底にあるオペレーティングシステム(OS)と切り離されることです。さらにこのセットアップでは、OpenStackでKubernetesのライフサイクル管理機能を活用し、アップグレードなどの複雑な作業を簡単にできます。最後に、K8sを標準として使用すれば、OpenStackのアーキテクチャが比較的軽くなり、従来と違って誰でも自分のワークロードステーションであれこれ試すことも可能になります。

KubernetesでOpenStack使ってみる >

スタックをスタックするには?

ちょっと待って。ひょっとしてKubernetesの上のOpenStackの上にKubernetesをセットアップするのがベスト?

当たりです!奇妙に見えますが、このセットアップが最もメリットが多く、1つのプラットフォームで両方の長所を生かすことができます。プラットフォームも数多くありますが、汎用性ではUbuntuに勝るものはありません。UbuntuならOpenStackとKubernetesの両方にスムーズにアクセスし、開発に必要なインフラストラクチャツールをすべて得ることができます。実運用環境については、オプションの商用サブスクリプションを使えばエンタープライズクラスのサービスを利用できます。

1つのサブスクリプションで全部手に入れる

Ubuntu Proは、極めて包括的なLinuxのエンタープライズサブスクリプションであり、セキュリティ、コンプライアンス、サポートなどすべての点でオープンソースに対応します。Ubuntu Proがあれば、お客様はインフラストラクチャの利点を生かすことに力を注ぎ、クラウドのセキュリティ更新、バグ修正、年中無休のテクニカルサポート、高度なサービスレベル契約(SLA)はCanonicalにお任せいただけます。

KubernetesかOpenStackか、まだ迷っていますか? 1つのサブスクリプションですべてに手に入れましょう!

KubernetesとOpenStackの両方について

OpenStackとKubernetesには多くの共通点があります。どちらもオープンソースクラウドインフラストラクチャの基盤となり、どちらも単独で存在できます。しかし2つを組み合わせれば、まるでトールキンの「力の指輪」のようにあらゆる能力を手に入れることができます。 

5月17日ウェビナーは、KubernetesとOpenStackの技術的な比較、統合ソリューションのデモなど充実した内容です。ぜひご参加ください。

CanonicalのOpenStackおよびKubernetesのページでは、世界最先端のオープンソースインフラストラクチャプロジェクトを詳細にご紹介します。

コンテナ化と仮想化に関するブログでは、OpenStackとKubernetesに使用される基本的な技術を解説します。

プロジェクトの商用サポートについてはCanonicalにお問い合わせください

ニュースレターのサインアップ

Ubuntuニュースレターの配信登録

お客様が購読登録を行われる場合、以下の条件に同意されたことになります。Canonicalのプライバシーに関するお知らせ個人情報保護ポリシー

関連記事

日本最大の “AWS を学ぶイベント”AWS Summit Japan登録開始!

Canonical @AWS Summit Japan 2024 Canonicalの招待コードを添えて登録ください! https://aws.amazon.com/jp/summits/japan/招待コード: SPC9461572 毎年 延べ 30,000 人が参加する、日本最大の “AWS を学ぶイベント” AWS Summit Japan が 6月 20 日(木)、21 日(金)の二日間に渡り開催されます。AWS Summit は、クラウドコンピューティングコミュニティが一堂に会して、アマゾン ウェブ サービス (AWS) に関して学習し、ベストプラクティスの共有や情報交換ができる、クラウドでイノベーションを起こすことに興味がある全ての皆様のためのイベントです。基 […]

VMwareの料金にお困りのあなた: UbuntuでVMを便利に運用しよう

[ウェビナー] VMwareの料金にお困りのあなた:UbuntuでVMを便利に運用しよう 日時:2024年8月7日(水)15:00~16:00費用:無料お申し込み Ubuntuは世界中で高いシェアを持つLinuxディストリビューションです。近年では、CentOSの開発打ち切り(CentOS Streamへの移行)、RHELのソースコード公開ポリシーの変更、VMwareの料金体系の変更等に伴い、Ubuntuに乗り換える方も多く、日本国内でも注目度がますます高まっています。 本Webinarでは、NTTテクノクロス社で日頃からUbuntuに関わる業務に携わっている技術者がスピーカーとなり、Ubuntuが提供する様々なツールの紹介や、Ubuntuを商用利用する場合に重要となる脆 […]

Canonical Jobs – Linuxエンジニア

Linuxフィールドエンジニア IoT分野における当社の主力製品、Ubuntu Coreはユニークな存在です。最高の信頼性、セキュリティ、フットプリントを実現するため、Linuxを再発明したものと言えます。当社の顧客は、自動車、市販電子機器、医療機器、産業システム、ロボティクス、ゲートウェイなど、さまざまな業界にわたりますが、厳しい品質とセキュリティの要件を満たすよう迫られているという点では共通しています。 日本市場での急速な展開に対応するため、当社はデバイス部門のフィールドエンジニアチームの拡大を検討しています。この重要なポジションは、新しいテクノロジーを迅速に習得し、多くの業界の最先端でお客様のソリューション構築を支援することが求められるため、能力ある候補者はキャリア […]