Capistrano が Docker と Kubernetes に置き換えられた理由

Capistrano が Docker と Kubernetes に置き換えられた理由

David Eastman 氏は、コンテナ以前 (Chef 以前!) のソフトウェア ツールである Capistrano を振り返りながら、アンティーク ショーの技術版を主催します。

Capistrano が Docker と Kubernetes に取って代わられた理由からの翻訳。

知的財産権とデジタル権利の擁護者として有名なコーリー・ドクトロウ氏が新著の一部を読んでいるのを聞いていると、彼がカリフォルニア州カピストラーノについて言及しているのが聞こえた。しかし、もちろん、2010 年代初頭に人気があったリモート サーバー自動化ツールである Capistrano を覚えています。それは、コンテナーや Kubernetes が登場する前のことでした。

私は、時が経つにつれて人気が薄れていく、よく使われる技術に興味を持つことがあります。もちろん、カピストラノは本当に死んではいません。たとえ私が過去形で説明しているとしても。オープンソース ツールは実際には決して消滅することはありません。単に人気がなくなるだけです (そしておそらく屋根裏にしまっておかれるでしょう)。 10 年以上前に Capistrano をリモート サーバー自動化ツールとして使用していたことを覚えています。 SSH を使用してスクリプトを実行し、ターゲット サーバーに更新を展開できるようになります。更新は、新しい実行可能ファイル、コード、構成、データベースの変更である可能性があります。それは素晴らしいことですが、もはや一般的に使用されていないシステムをなぜレビューするのでしょうか?

まず、傾向を理解するには、過去の例を振り返ることが役立ちます。何かが失われたかどうかを確認しながら、何かの人気が下がった時点を記録することも役立ちます。現在のテクノロジーはタイムライン上のほんの一瞬に過ぎず、時々振り返ってみると、次に何が起こるかを予測するのははるかに簡単です。新しいサイトへの展開を処理する必要がある場合は、自分の好みのツールに加えて、さまざまなツールがあると便利です。古いスタックで Capistrano を使用する必要がある場合もあります。それでは、この骨董品を評価して、どれくらいの価値があるか見てみましょう。

環境

Capistrano は、通常、運用、ステージング、開発という 3 つの基本的な環境を理解します。開発環境はラップトップである可能性があります。ステージング環境は、QA がアクセスできる何らかのクラウド サーバーである可能性があります。これらの定義を使用して、Capistrano は特定のコンピューターを対象に実行することができます。

使命と役割

Capistrano における基本的なコマンドはタスクです。これらは展開のさまざまな段階で実行されます。ただし、これらのタスクをフィルタリングするには、ロールを使用して、システムのどの部分で作業しているかを記述できます。

 role :app, "my-app-server.com" role :web, "my-static-server.com" role :db, "my-db-server.com"

これは、アプリケーション サーバー (動的コンテンツを生成する部分)、Web ページまたは Web サーバー、およびデータベースが別々の部分であることを意味します。もちろん、独自の定義を作成することもできます。

あるいは、環境の分離に重点を置き、その下でキャラクターを操作することもできます。実稼働環境の説明については、次のように設定します。

 # config/deploy/production.rb server "11.22.333.444", user: "ubuntu", roles: %w{app db web}

デフォルトのデプロイ タスクには、デプロイの段階を表すいくつかのサブタスクがあります。

  • deploy:starting はデプロイメントを開始し、前提条件が満たされていることを確認します。
  • deploy:updating サーバーを新しいバージョンに更新します
  • deploy:publishing 新しいバージョンをリリースする
  • deploy:finishing デプロイを完了し、クリーンアップを開始します
  • deploy:upload は、現在デプロイされているバージョンにファイルをコピーします。これは段階的にファイルを更新する場合に便利です
  • deploy:rollback すべてをロールバックする

これはカスタム展開タスクの例です。この Ruby のようなコードは、ロールを使用してタスクとデプロ​​イメントのフェーズをフィルター処理します。この場合、終了する前に style.css ファイルを更新できます。

 namespace :deploy do after :finishing, :upload do on roles(:web) do path = "web/assets" upload! "themes/assets/style.css", "#{path}" end on roles(:db) do # Migrate database end end end

Capistrano をインストールした後、次のコマンドを使用してコマンドラインからこのアクションをトリガーできます。

デフォルトのデプロイメント プロセスと対応するロールバック プロセス。より詳細な例を以下に示します。

 deploy deploy:starting [before] deploy:ensure_stage deploy:set_shared_assets deploy:check deploy:started deploy:updating git:create_release deploy:symlink:shared deploy:updated [before] deploy:bundle [after] deploy:migrate deploy:compile_assets deploy:normalize_assets deploy:publishing deploy:symlink:release deploy:published deploy:finishing deploy:cleanup deploy:finished deploy:log_revision

「starting」、「publishing」などのアクションに対応するフック(「started」、「updated」、「published」、「finished」)が表示されます。これらは、上で説明したように、before 句と after 句を使用してカスタム タスクをプロセスにフックするために使用されます。

公開後、最新バージョンを指す「現在の」シンボリックリンクが作成または更新されることに注意してください。いずれかのステップでデプロイメントが失敗した場合、現在のシンボリック リンクは引き続き古いバージョンを指します。

それで何が起こったのですか?

「これを実行してから、あれを実行する」というモデルは、必ずしも展開後のシステムがどのようになるかを適切に予測できるわけではありません。 Chef のようなツールは、モデルから始めて「この設定を true にする」と指示するため、無秩序に広がるシステムに対処するのに適しています。 Chef は収束とべき等性に基づいて動作します。不足している部分が追加されますが、その後同じ手順を再度適用しても何も変わりません。したがって、同じ操作を複数回実行しても、状態に副作用は発生しません。

Capistrano の柔軟性により、経験の浅い開発者でも、機能するが不安定なデプロイメントを構築できるようになります。

対照的に、単一の Docker イメージを使用すると、OS、パッケージ、ライブラリ、コードを体系的に制御できます。また、ラップトップやクラウド サーバーを、コンテナーをマウントする場所として同様に扱うことも可能になります。

最後に、Kubernetes は速度低下やタイムアウトを心配することなくクラスターを処理します。完全に透明なインフラストラクチャと、必要なサービスと正確な構成のあらゆる側面を実行できる機能により、DevOps チームの作業が大幅に容易になります。すでに実行中のサービスを変更する代わりに、新しいコンテナを作成し、古いコンテナを終了することができます。

現代的な観点から見た Capistrano のもう 1 つの問題は、Ruby で構築されていることです。 Ruby 言語は Ruby on Rails の人気と不当に関連付けられています。 Node.js と JavaScript の台頭により減少しました。一般的に、他の言語や言語のトレンドが人気を上回っています。たとえば、Python はスクリプト言語として選ばれるようになりました。示されているタスクは、実際には Ruby Rake ビルド ツールである DSL を使用します。

何か紛失したものはありますか?可能。迅速な変更を行うための一連のカスタム タスクがあると、ハッカーのアプローチが促進されますが、小規模でアドホックなイベント ベースの変更も可能になります。 「サーバーを常にこのように保ちたい」ではなく、「この変更を実現する」です。

もっと良い言い方をすれば、Capistrano のようなツールは、より広い視点が必要になる前の通過点として、あらゆるチームのデプロイメントの過程に現れると言えるでしょう。しかし、たとえほこりをかぶった遺物であっても、Capistrano は Web アプリケーションの展開とメンテナンスを自動化するための優れたモジュール式ツールです。

カリフォルニア州カピストラノについてはどうですか?残念ですがそれは悪い知らせです。

写真

驚き

記事を読み終えると、カピストラノがすぐそばにいることに気づいた。 Vagrant はこれを使用しました:

写真


<<:  1 つの記事で K8s コントローラー ランタイムを理解する

>>:  クラウドのエンドポイントセキュリティについて知っておくべきこと

推薦する

完全なクラウド コンピューティングの時代において、企業にはどのようなクラウド セキュリティ機能が必要ですか?

クラウド セキュリティの重要性は、いつ言及されても過小評価されることはありません。 サイバーセキュリ...

盛業:人間本位を堅持し、産業技術の配置を加速する

疫病の影響、貿易環境の変化、戦争紛争の影響…全体的な経済低迷とマクロ経済環境への高圧力の状況下で、す...

クラウド コンピューティングの時代において、ハードウェアが依然として重要な理由は何でしょうか?

カリフォルニア大学サンディエゴ校は、「クラウドファースト」戦略を採用し、3 台​​のメインフレームを...

Kafka とは何ですか?知りたいですか?

あなたはプログラマーで、2 つのサービス A と B を管理しているとします。サービス B は 1 ...

トラフィックを獲得するために間違ったキーワードを使用する方法

草の根ウェブマスターにとって、Baidu からより多くのトラフィックを獲得することは非常に困難になっ...

フォーラムに人々を引き付ける5つの魔法のツール

SEO の初期の発展においては、フォーラム BBS が SEOER がビジネスを始めるための最も一般...

siteground-70% オフ/ウェブホスティング/シンガポール データセンター

米国の老舗ホスティング会社であるSitegroundは、ブラックフライデーに30%割引、サイバーマン...

クラウドネットワーク統合における専用回線の需要に関する簡単な分析

[[442453]] 1. 専用回線市場の現状専用線市場は、企業数、クラウド事業展開、政策支援などの...

2018年、3つの大きな「破産」ライブ放送

今年最もハマるものは何ですか?意外だが妥当な答えは「生放送」だ。その年、最もハマったライブ配信ルーム...

タオバオがPinterestのようなウェブサイト「Wantu」を立ち上げ、ソーシャルイメージショッピング戦略を開始

Admin5によると、Taobaoは4月9日、写真共有コミュニティ「Wantu」を立ち上げるため、第...

zgovps: 新しいオランダの VPS、年間 16.9 ドル、2G メモリ/2 コア (AMD EPYC)/25g SSD/2T トラフィック (1Gbps 帯域幅)/40G 防御

zgovps は、オランダの新しい VPS サービスを開始しました。データ センターは「Naaldw...

ファン・サンウェン氏自身の説明: スノーボール・ファイナンスのウェブサイトが「成長」した経緯

シンプルなページで広告がほとんどないウェブサイト「スノーボール・ファイナンス」は、どのようにしてこれ...

安全で信頼性の高いグローバルインテリジェントクラウドが中国企業の世界進出を支援

マイクロソフトが中国クラウドコンピューティングカンファレンス (CCCC) に参加するのは、今年で ...

ウェブサイトデータ分析:ユーザーセグメンテーションに基づく比較分析

ウェブサイトのユーザーレベルでは、訪問時の行動特性に応じてユーザーをさまざまなタイプにセグメント化し...