Machine Learning Operations (略して MLOps) は、機械学習 (ML) エンジニアリングの重要な側面であり、ML モデルを運用環境に提供し、保守および監視するプロセスを簡素化および高速化することに重点を置いています。 MLOps には、データ サイエンティスト、DevOps エンジニア、IT 専門家など、さまざまなチーム間のコラボレーションが含まれます。
MLOps は、組織が AI および機械学習ソリューションを作成し、品質を向上させるのに役立ちます。 MLOps を採用すると、機械学習エンジニアとデータ サイエンティストが協力して、継続的インテグレーションと継続的デプロイ (CI/CD) プラクティスを実装することでモデルのパフォーマンスを向上させることができます。 ML モデルの適切な監視、ガバナンス、検証を統合することで、ML モデルの開発プロセスを加速します。
DevOps は、開発と運用の概念を組み合わせたもので、通常、アプリケーション開発チームと IT 運用チームが別々に関係するタスクを実行するための協調的なアプローチを説明します。最も広い意味で、DevOps は、組織内のこれら (および他の) チーム間のコミュニケーションとコラボレーションの向上を促進する哲学です。
最も狭い意味では、DevOps は、反復的なアプリケーション開発、自動化、およびプログラム可能なインフラストラクチャの展開と保守を可能にするプラクティスの導入を指します。これには、開発者、システム管理者、その他のチーム メンバー間の信頼構築やつながりなど、職場文化の変化も含まれます。 DevOps はテクノロジーをビジネス目標に合わせて調整し、ソフトウェア配信チェーン、職務機能、サービス、ツール、ベスト プラクティスを変革できます。
MLOps と従来の DevOps の主な違いをいくつか示します。
開発の概念はモデルごとに異なるものを指し、CI/CD パイプラインは若干異なります。
DevOps:
MLOps:
DevOps:
MLOps:
DevOps:
MLOps:
モニタリングは DevOps と MLOps の両方にとって不可欠ですが、その理由は若干異なります。
DevOps:
MLOps:
DevOps と MLOps はどちらもクラウド テクノロジーに大きく依存していますが、運用要件は異なります。
DevOps は、次のようなインフラストラクチャに依存します。
MLOps は次のインフラストラクチャに依存しています:
DevOps と MLOps を推進する主要なトレンドのいくつかを次に示します。
DevOps ワークフローの新たな進化として、GitOps はインフラストラクチャを制御および自動化するための新しいパラダイムです。 Kubernetes のパラダイムにより、開発者と運用チームは Git を使用して Kubernetes クラスターを管理し、コンテナ化されたアプリケーションを配信できるようになります。運用チームと開発チームに Git ワークフローを実装すると、開発者は Git プル リクエストを活用してソフトウェアのデプロイメントとインフラストラクチャを管理できるようになります。
GitOps は既存の開発ツールを統合し、CI/CD を通じてクラウドネイティブおよびクラスターベースのアプリケーションを管理します。 Git リポジトリを唯一の信頼できる情報源として使用し、クラウドネイティブ アプリケーションを自動的にデプロイ、監視、保守します。
GitOps は、Kubernetes でクラスターを実装および維持する方法です。継続的な配信と展開により、開発者は増分リリースを通じてソフトウェアをより迅速に構築、テスト、展開できるようになります。 Kubernetes の継続的インテグレーションとランタイム パイプラインは、ファイルの読み取りと書き込み、コンテナー リポジトリの更新、Git からのコンテナーのロードができる必要があります。 GitOps は、バージョン管理、リアルタイム監視、構成変更アラートを通じて企業がインフラストラクチャを管理するのに役立ちます。
合成データとは、実際のイベントから収集されたものではなく、人為的に生成された情報です。このアルゴリズムは、運用テスト データ セットおよび実稼働テスト データ セットの代用として使用される合成データを生成します。合成データセットは、数学的モデルの検証や機械学習モデルのトレーニングにも使用できます。
合成データの利点は次のとおりです。
機械学習には、モデルのトレーニングをセットアップして処理するためのコンピューター コードが含まれることがよくありますが、常にそうであるとは限りません。コードレス機械学習は、ML アプリケーションが時間のかかるプロセスを実行する必要をなくすプログラミング アプローチです。
CodelessML を使用すると、専門家がシステム ソフトウェアを開発する必要がなくなります。また、展開と実装がより簡単かつ低コストになります。機械学習中にドラッグ アンド ドロップ入力を使用すると、次のようなトレーニングが簡素化されます。
#コードレス ML により、開発者は機械学習アプリケーションに簡単にアクセスできるようになりますが、高度で微妙なプロジェクトに代わるものではありません。このアプローチは、社内のデータ サイエンス チームを維持する資金が不足している中小企業に適しています。
TinyML は、機械学習および人工知能モデル開発への新しいアプローチです。これには、スマートカー、冷蔵庫、電力メーターに電力を供給するマイクロコントローラーなど、ハードウェア制約のあるデバイス上でモデルを実行することが含まれます。この戦略はアルゴリズムを高速化するため、サーバー上でデータをやり取りする必要がないため、これらのユースケースに最適です。これは大規模サーバーでは特に重要であり、ML 開発プロセス全体を高速化できます。
TinyML プログラムを IoT エッジ デバイスで実行すると、
TinyML を使用すると、計算プロセスが完全にローカルであるため、プライバシーが強化されます。消費電力と帯域幅が少なくなり、処理のためにデータを中央の場所に送信する必要がないため、待ち時間が短くなります。このイノベーションを活用している業界には、農業や医療などがあります。通常、TinyML アルゴリズムが組み込まれた IoT デバイスを使用して、収集されたデータを使用して現実世界のイベントを監視および予測します。
この記事では、MLOps と DevOps の主な違いを紹介します。
最後に、近い将来に DevOps と MLOps を変える重要なトレンドをいくつか紹介します。この記事が、新しくエキサイティングな開発エコシステムの中で自分の位置を見つけるのに役立つことを願っています。
以上がMLOps と DevOps: 違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。