Hippo で WebAssembly を始める

Hippo で WebAssembly を始める

導入

WebAssembly は、Microsoft のクラウド ネイティブ コンピューティング チーム (子会社のDeis LabsAzure の両方) が非常に興味を持っている、非常に有望な新しいテクノロジです。新しいWebAssemblyツールが急速に登場しているため、それらを試すことができる環境が必要です。

だからこそ、 Deis Labs新しい Hippo WebAssembly プラットフォームのリリースは非常に重要です。 Deisの多くのツールと同様に、これは、ブラウザでホストされるか、 WebAssembly System Interface (WASI)を使用してスタンドアロンで、 WebAssembly (WASM)コードをすばやくインストール、管理、実行する方法です。組み込みチャネルをGitサーバーと組み合わせて使用​​すると、1 つの環境で異なるバージョンを作成してデプロイし、運用、ステージング、開発ビルドを分離できますが、必要な Hippo サーバーは 1 つだけです。

Hippoでは複数のアプリケーションをホストできますWebAssembly は、デフォルトでサンドボックス化されており、ホスト システムまたは外部デバイスにアクセスするには明示的な権限が必要であることを意味します。コードも移植可能です。 WebAssembly用にコンパイルされるとWindows Linux macOS Intel RISC-V ARMなど、どのWebAssemblyシステムでも実行できます Hippo は、一度ビルドして一度テストすれば、どこでもコードを実行できる方法を提供します。

開発用PCにHippoを設定する

Hippoのようなツールはクラウドネイティブ操作に適していますが、現在の開発者リリースはデスクトップ システムでのみテストされています。私は、最新バージョンのWSL2を実行し UbuntuをホストしているWindows PCで試してみることにしました。 Deis は、macOS および Linux システムの詳細とともに、 Hippo をローカルで実行するための手順を提供しています

WSL2 Ubuntu 20.04 LTSシステムHippoを実行するための前提条件を取得する際にいくつか問題がありますまず、 WAGI (WebAssembly Application Gateway Interface) をインストールする必要があります。これは簡単にインストールできます。GitHub リポジトリにホストされているダウンロード可能なtar ファイルにバイナリが含まれていますダウンロードして解凍し、ユーザーのバイナリ ディレクトリに移動すると、簡単に実行できます。 Deisツールを再コンパイルする必要がある場合に必要になる可能性があるため、この機会にRustをインストールしました

この手順は、 ビルド必須ツール パッケージのコピーが必要になるため、 WSL2ではおそらく最も困難です。 Ubuntu 20.04 には正しい依存関係セットがないため、特定の重要なライブラリを適切なバージョンにダウングレードできる代替パッケージ インストーラーが必要です。 Stack Overflow の回答で、 aptitude を紹介されました。これは apt の代替であり、インストールに適切な依存関係を選択して、2 つの低レベル C ライブラリを置き換えることができます。最後に、インストール スクリプトを使用してbuild-essentialをインストールし Rust準備ができました

バインディングとは何ですか?

Hippo インストールの一部として Rust をインストールする主な理由は DeisWebAssemblyバンドラーである Bindleのためです Bindle は、「集約オブジェクト ストレージ」システムとして説明されています。そのドキュメントでは、「 バインダーはデジタルの銀色の引き出しである」という比喩が使われています私たちは皆、銀食器の引き出しの中にいくつかの異なるアイテムを入れているかもしれませんが、引き出しを使って銀食器を分類し、保管しています。 Bindle は、最新のアプリケーションを構成する成果物に対してほぼ同じことを行いますが、アプリケーションがどのように、どこで、どのように使用されるかに基づいて、アプリケーションがどのように組み立てられるかについての理解レベルも提供します。

推奨ホワイトペーパー

Raspberry Piなどのリソースが制限されたエッジ ホストや、パブリック クラウドの中核にある高性能サーバー上のスパース インストールに必要な要素を含むアプリケーションのBindle記述を作成できます。アプリケーション ホスト内のBindleクライアントは、要素と依存関係を取得し、適切にデプロイできます。その結果、リポジトリとインテリジェントな記述を使用して複数のビルドを回避し、適切なコードを適切な環境に配信する、アプリケーション中心のデプロイメント モデルが実現します。

Bindleをインストールしたら、それを実行して、Hippo が使用するデフォルト設定でローカル Bindle サーバーをセットアップできます。次に、 Microsoft が提供する WSL の手順に従ってNode.jsをインストールしました。これには、 curlを使用してnvmをダウンロードし、それを実行して、 node.js最新かつ長期サポートバージョンをインストールする必要があります。 Ubuntu の手順を使用してノードをインストールしないでくださいインストールにはsnapを使用しますが、 snap はWSL2では十分にサポートされていません

HippoでホストされるRust WebAssemblyアプリケーションには、 Rustwasm32-wasiサポートと、 yo-wasm Yeomanアプリケーション スキャフォールディング ツールをインストールする必要がありますこれにより、 RustコードをWASIターゲットコンパイルし、 Hippoで実行できるようになります

これで、 .NET 5 をインストールできるようになりました。まず .NET 5 SDKとランタイムをインストールする前に、 MicrosoftDebianパッケージ リポジトリのサポートを設定します。 .NET ランタイム ASP.NET Coreをサポートするオプションとサポートしないオプションの 2 つがあります。 Hippoはモデル・ビュー・コントローラー Web アプリケーションなのでランタイムのASP.NETバージョンを使用する必要があります。

Hippoの構築と実行

すべての前提条件がインストールされたら、 Hippoをビルドできます。まず、 Hippo GitHubリポジトリをWSLシステム上のローカル ディレクトリ複製しますインストールが完了したら、 BINDLE_URL環境変数を追加してアプリケーションをビルドして実行し、ローカルのBindleサーバーを指定することができますアプリケーションの開発とデプロイメントにはHippoCLI が必要なので、この時点でインストールしておくのも良いでしょう

これで、 Hippoサーバーに接続して、正常に動作しているかどうかをテストできます。 localhostポート5001で見つかるはずです最新バージョンのWSL 2 を実行している場合はlocalhostを使用してWindowsデスクトップ ブラウザーから接続できるはずです。これは、 Microsoft がWSL 2の長年の問題であったネットワーク問題をようやく修正し、独自のIPアドレスと仮想ネットワーク スイッチを保持しながら、仮想マシンのネットワークをWindows経由でプロキシするようになったためです。ネットワーク アドレスを抽出して共有するためのスクリプトはもう必要ありません。

サーバーに接続する前に、アカウントを登録する必要があります。ローカルで実行されるため、好きなアカウント詳細を選択できます。最初のアプリケーションを構築するときに詳細が必要になるので、覚えやすいものにしてください。アカウントを作成したら、ログインします。「新しいアプリケーションの作成」ボタンのある「アプリケーション」ページが表示されます。

最初の Hippo WebAssembly アプリケーションを作成する

Hippo用のアプリケーションWeb UI から構築できますが、コマンド ラインを使用する方が簡単になりました。 Yeoman はHippo CLIを使用してアプリケーションをスキャフォールディングするため Hippo CLI がインストールされていることを確認してください。始める前に、 Hippoアカウントとパスワード、およびそのエンドポイントの環境変数を設定します確かに、これは優れたセキュリティ対策ではありませんが、ここでは、まだ本番環境に対応していないソフトウェアを使用して、隔離されたPC上でテスト コードを構築して実行しているだけです

基本的なHello Worldアプリケーションを構築するには、 yo-wasmツールを使用してWebAssembly Rustアプリケーションを構築します。スクリプトに従って適切な値を入力すると、ソース コードがビルドされ、 Hippoサーバーにロードされます。次に、 Rustカーゴ ツールを使用してWASIアプリケーションをコンパイルおよびテストします。コマンドラインで実行した後、 HippoCLIツールを使用してBindleにプッシュすると Hippoで表示できるようになります。プロジェクトを開き、構築した開発環境を選択し、リンクをクリックしてコードを実行します。

カバには好きなところがたくさんあります。 WebAssemblyに欠けているものが 1 つあるとすれば、それは開始するのに役立つ、効果的なHerokuのようなプレイグラウンドですHippo はまだそのような遊び場ではないかもしれませんが、初期段階でも、今すぐに独自の開発ワークフローの一部として使用できるものであることは間違いありません。サードパーティのシステムに依存する必要がないため、開発用PCで実行できることはさらなる利点です。これはWSL 2環境の一部として実行できるほど影響が少ないため Visual Studio Codeなどのツールのリモート開発機能を使用してWindowsからWSLRustコードを編集できます

WebAssemblyに興味があるなら Hippo は始めるのに必要なツールである可能性が高いです。これにより、開発の実行に必要なさまざまな要素が 1 か所にまとめられ、 WebAssemblyコードの操作がはるかに簡単になります。まだ初期リリースであることは明らかですが、始めるには十分な内容が含まれているため、 WebAssemblyを扱うすべての人にとって必須のツールとなっています

<<:  Red Hat はポートフォリオを更新し、クラウドネイティブ アプリケーション開発のパフォーマンスとスケールをさらに向上させました。

>>:  可用性、同時実行性、パフォーマンスに優れたクラウドネイティブ コンテナ ネットワークを構築するにはどうすればよいでしょうか?

推薦する

Windows 10 環境向け VMware Horizo​​n サイジング ガイド

最新のエンドポイントのほとんどは、リモート ワーカー向けであっても強力なソリッド ステート ドライブ...

新浪はポルノコンテンツで508万元の罰金を科せられ、2つのライセンスを取り消されなければ大きな取引を失うことになるだろう

CCTV スクリーンショット国家ポルノ・違法出版取締局と北京市文化法執行部隊は昨日、新浪網が読書チャ...

分散型ソフトバスにより、アリババの商人はマルチデバイスライブ放送を再生できる

[[428752]]詳細については、以下をご覧ください。 51CTOとHuaweiが共同で構築したH...

Rabbit High Defense CDN: (無料版あり) DDoS に対する高い防御力、CC 防御、申請不要、あらゆる業界へのアクセス、香港 CN2 を含む大規模なノード

「湖北ラビットクラウドテクノロジー株式会社」は、主にエンタープライズレベルのクラウドプラットフォーム...

「100億補助金」はピンドゥオドゥオを救ったのか?

このデータセットが私の注目を集めました。 5月8日現在、 Pinduoduoの株価は54.6ドルだっ...

K8s の交換が必要です!

著者 |趙雲現在、Kubernetes はマイクロサービスのデプロイメント問題を解決し、すでにコンテ...

UAE サーバー: zenlayer、ドバイ データ センター、30% 割引、10Gbps 帯域幅、専用サーバー、月額 286 ドルから

ZenlayerはすでにUAEデータセンターを立ち上げており、世界で最も豪華な都市であるドバイに位置...

Weiboマーケティングを正しく行う方法を共有する

ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービスさまざまなマーケティング...

VMware がクラウド コンピューティング戦略と技術ロードマップを公開

VMworld Europe 2009 において、VMware (NYSE: VMW) の社長兼 C...

GreenWebPage-ヨーロッパ KVM/4 コンピュータ ルーム/3 USD/512 MB メモリ/10 GB SSD/1 TB トラフィック

greewebpage.com という会社は設立されてまだ日が浅いようです。主な事業はドメイン名、バ...

ソフト記事プロモーション:どんなタイトルがすぐに注目を集められるのか?

ソフトテキストプロモーションが効果的かどうかを判断する基準は、消費者の注目を集めることができるかどう...

新しいサイトが掲載とランキングを獲得するための2つの強力なツール

Baidu の新規サイトのレビュー期間は比較的遅いです。新しいドメイン名をお持ちの場合、ウェブサイト...

有能なSEO担当者が習得すべき7つの能力

現在、あらゆる分野の実務家は、習得すべきスキルを習得する必要があります。これらのスキルがなければ、長...