目次
なぜダウンタイムなしで公開できるのでしょうか?
クラスター モード
マスター/ワーカー モード
拡張読書
概要
ホームページ バックエンド開発 PHPチュートリアル [CI/CD] いくつかの一般的なノンストップ公開方法

[CI/CD] いくつかの一般的なノンストップ公開方法

Jun 20, 2016 pm 12:25 PM

なぜダウンタイムなしで公開できるのでしょうか?

この記事で言及されているノンストップ リリースとは、外部サービスを停止せずにアプリケーションの更新を完了することを指します。ホット デプロイメントとの違いは、ホット デプロイメントは アプリケーション レベルに焦点を当てており、アプリケーションを再起動しないという前提に基づいているのに対し、ノンストップ リリースは サービスに焦点を当てていることです。 レベル。ムーアの法則が徐々に限界に近づき、マルチコア時代が到来するにつれ、分散アプリケーションが事実上の主流になりました。次の記事では、まず分散アプリケーション環境に適した一般的なノンストップ パブリッシング方法を示し、次にスタンドアロン アプリケーションに適した一般的なノンストップ パブリッシング方法であるマスター/ワーカーを紹介します。

クラスター モード

クラスター環境で実行される分散アプリケーションの場合、通常、アプリケーションの上に負荷分散 (LB) の層があります。リリース プロセス中に、ノードを更新する前に任意のノード (またはノードのグループ) に対応するロードをクローズし、更新後にロードをオープンすると、サービス全体のノンストップ リリースを実現できます。これに基づいて、サービスの安定性を確保するために、スタンバイ マシンのサポートを追加できます。つまり、特定のノードを更新するときに、最初にスタンバイ マシンをマウントし、更新後にスタンバイ マシンを削除してから、スタンバイをアップグレードします。以下の図に示すように、すべてのノードを順番に更新した後のマシン:

完全な設計については、私が書いた別の記事を参照してください。

上記のリリース プロセスは、実際には単純な CD です。 (継続的展開) システム。リファレンス実装として、Jenkins 2.0 Pipeline 機能を使用してリリース プロセス全体を定義し、Nginx Dynamic Upstream プラグインを使用して Nginx を操作し、スクリプトと連携してアプリケーションの開始、停止、検出を完了できます。

マスター/ワーカー モード

スタンドアロン アプリケーションの場合、LB がないため、ノンストップ パブリッシュ機能は通常、アプリケーション コンテナーによって実装されます。最も一般的なのはマスター/ワーカーです。モード。コンテナ内にはマスター プロセスと複数のワーカー プロセスが存在し、マスター プロセスはプログラムのロードとリクエストの分散のみを担当し、フォークされたワーカー プロセスは特定の作業を完了します。コンテナーがアプリケーションを更新するシグナルを受信すると、マスター プロセスは更新されたプログラムを再ロードし、新しいリクエストを処理するために新しいワーカー プロセスをフォークし、現在のリクエストを処理した後、古いワーカー プロセスは自動的に破棄されます。 Ruby の Unicorn と PHP の FPM は両方ともこのメカニズムを使用します。

拡張読書

マスター/ワーカー モデルとは異なり、erlang はノンストップ パブリッシングを実現するために別のユニークな方法を採用しています。

Erlang VM は、モジュールごとにコードのコピーを最大 2 つ保存します。モジュールが初めてロードされるとき、コードは現在のバージョン「current」と古いバージョン「old」です。 「現在の」バージョン。新しいコードがロードされると、コードの「現在の」バージョンは「古い」バージョンになり、新しいコードは「現在の」バージョンになります。 Erlang は 2 つのバージョンの共存方法を使用して、いつでも常に 1 つのバージョンを使用できるようにし、外部サービスが停止しないようにします。

<br>gt;
- erlang ホットアップデート実装メカニズムの分析より引用

概要

LB であってもマスター/ワーカーであっても、基本的な考え方は、公開プロセス中、サービス リクエストは常にシステム内の特定のノードまたはプロセスによって特定のメカニズムを通じて処理され、それによってサービスの可用性が保証されるというものです。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

11ベストPHP URLショートナースクリプト(無料およびプレミアム) 11ベストPHP URLショートナースクリプト(無料およびプレミアム) Mar 03, 2025 am 10:49 AM

11ベストPHP URLショートナースクリプト(無料およびプレミアム)

Instagram APIの紹介 Instagram APIの紹介 Mar 02, 2025 am 09:32 AM

Instagram APIの紹介

Laravelでフラッシュセッションデータを使用します Laravelでフラッシュセッションデータを使用します Mar 12, 2025 pm 05:08 PM

Laravelでフラッシュセッションデータを使用します

LaravelのバックエンドでReactアプリを構築する:パート2、React LaravelのバックエンドでReactアプリを構築する:パート2、React Mar 04, 2025 am 09:33 AM

LaravelのバックエンドでReactアプリを構築する:パート2、React

Laravelテストでの簡略化されたHTTP応答のモッキング Laravelテストでの簡略化されたHTTP応答のモッキング Mar 12, 2025 pm 05:09 PM

Laravelテストでの簡略化されたHTTP応答のモッキング

PHPのカール:REST APIでPHPカール拡張機能を使用する方法 PHPのカール:REST APIでPHPカール拡張機能を使用する方法 Mar 14, 2025 am 11:42 AM

PHPのカール:REST APIでPHPカール拡張機能を使用する方法

Codecanyonで12の最高のPHPチャットスクリプト Codecanyonで12の最高のPHPチャットスクリプト Mar 13, 2025 pm 12:08 PM

Codecanyonで12の最高のPHPチャットスクリプト

Laravelの通知 Laravelの通知 Mar 04, 2025 am 09:22 AM

Laravelの通知

See all articles