HarmonyOS 分散アプリケーション フレームワークの詳細な解説

HarmonyOS 分散アプリケーション フレームワークの詳細な解説

[[439631]]

詳細については、以下をご覧ください。

51CTOとHuaweiが共同で構築したHongmengテクノロジーコミュニティ

https://harmonyos..com

背景

ますます多くのデバイスがスマートになるにつれて、マルチデバイス シナリオでのアプリケーション開発では、複数のデバイスの形態の違い (画面のサイズ、解像度、形状が異なり、ボタン、タッチ スクリーン、キーボード、音声、ジェスチャなどのさまざまな操作方法) と、複数のデバイスの機能の違い (数百 KB から GB に及ぶメモリを搭載したデバイス) という課題に直面します。

HarmonyOS は、Internet of Everything 時代の新しい分散型オペレーティング システムとして、上記の課題を解決することができます。これは、HarmonyOS の分散アプリケーション フレームワークのおかげです。これら複数のデバイスがスーパーターミナルを形成し、各デバイスの機能を最大限に活用することで、マルチデバイスおよびマルチターミナルのコラボレーションとターミナル間の移行を実現し、Internet of Everythingの基盤を築きます。

HarmonyOS の分散アプリケーション フレームワークについては、次の章で詳しく説明します。

1. HarmonyOS ユーザープログラム


HarmonyOS システム上のアプリケーションは、HarmonyOS アプリケーションとアトミック サービスに分かれています。 HarmonyOS アプリケーションは、従来のアプリケーションと同様に、アプリ ストアからダウンロードしてインストールする必要があります。アトミック サービスは独立した操作入口を持ち、インストールは必要なく、特定の機能を実装します。 WeChat アプレットよりも強力です。 HarmonyOS のクロスデバイス、分散機能、アプリケーションと組み合わせることで、この 2 つには無限の機能が備わります。

開発者の観点から見ると、HarmonyOS の基本コンポーネントは 3+1 に分かれています。3 は 3 つの機能を表します。つまり、PageAbility: ユーザー インターフェイスの表示を担当し、DataAbility: データ管理を担当し、外部に統一されたデータ アクセス抽象化を提供し、ServiceAbility: バックグラウンドでタスクを実行を担当します。 1 は AbilityForm サービス カードを表します。重要な情報や操作を前面に配置して直接的なサービスを実現し、経験レベルを下げることができます。 HarmonyOS 上でアプリケーションを開発するには、3+1 のコンポーネントが組み合わされ、そのパッケージ形式は HAP (HarmonyOS Ability Package) です。 HAP はインターフェースの有無によって、FA (Feature Ability) と PA (Particle Ability) の 2 種類に分けられます。

2. HarmonyOS分散アプリケーションフレームワークの全体的なアーキテクチャ


アプリケーション フレームワークの観点から見ると、システムは次の 5 つのレイヤーに分かれています。

下層ソフトウェア

カーネル、HAL、ソフト バスを含むこのレイヤーは開発者によって使用されず、通常は開発者とユーザーに黙ってサービスを提供します。

基本サービス層

分散スケジュール管理、分散データ管理、分散ハードウェア管理、分散権限管理などが含まれます。

コアサービス層

グローバルパッケージ管理や分散運用管理などが含まれます。グローバル パッケージ管理: HarmonyOS 上のアプリケーションは単一のデバイスに限定されなくなり、パッケージ管理には仮想端末全体のすべてのデバイスも含まれます。分散運用管理は、コラボレーション フレームワーク、移行フレームワーク、サービス カード フレームワークなどのアプリケーションの動的なランタイム管理を担当します。

アプリケーション インターフェース レイヤー

これは、開発者がアプリケーションを開発するためにシステムによって提供されるインターフェース層です。システムの基盤となる実装がどれほど複雑であっても、開発者に提供されるインターフェースは可能な限りシンプルです。このレイヤーには、前述の基本コンポーネントと、ACE (Ability Cross-platform Environment) フレームワークが含まれます。マルチデバイスインタラクションモデルでは、一貫性が非常に重要です。 UI の観点からは、UI フレームワークを大画面、小画面、縦長画面、正方形画面、横長画面などに適応させる方法。この一貫性は、ACE フレームワークによって大きくサポートされています。

ユーザープログラム層

このレイヤーは、ユーザーが使用するために開発者が開発したアプリケーションです。

3. HarmonyOS分散アプリケーションフレームワークの操作ビュー


これは実行時のアプリケーション フレームワークのビューです。実行中、各アプリケーションは独立したサンドボックス内にあり、互いに分離され、互いに影響を与えないため、システムのセキュリティが確保されます。システムには、プロセスインキュベーションを担当するAppSpawn、プロセス管理を担当するAppMS、パッケージ管理を担当するBMS(Bundle Manager Service)、基本コンポーネント管理を担当するAMS(Ability Manager Service)、分散ビジネスを担当するDMS(Distributed Manager Service)が含まれます。専用の基盤サービスです。当社の上位サービスの多くは分散ビジネスであり、接続されたビジネスを統合するためにこれを使用します。その主な役割には、分散タスク管理、デバイス間のステータス、データ同期などがあります。

4. HarmonyOS分散操作:複数端末の連携


マルチ端末連携は、当社のアプリケーションが複数の端末でビジネスを完了できるようにすることです。現時点では、システム フレームワークはアプリケーションに 3 つの機能を提供します。最初のクロスデバイス コンポーネントが開始され、この機能により同時実行が完了できます。 2つ目は、接続チャネルを介したビジネスコラボレーションを可能にするクロスデバイスデータ伝送です。 3 つ目は、分散共有オブジェクトを使用すると、2 つ以上のデバイス間で状態を自動的に同期できることです。

右上隅のコード スニペットは接続を強調しています。実際、システムレベルで接続を提供することは自然なことのように思えますが、舞台裏では非常に複雑です。 HarmonyOS 上のデバイスは、小型から中型、大型までさまざまな種類のデバイスにわたります。チップの種類が異なり、接続方法も異なります。 Wi-Fi、Bluetooth などが備わっている場合があります。このような接続はワイヤレスであるため、干渉を受けることがよくあります。このタイプの接続では、基盤となるネットワーク ジッターも除去する必要があります。

マルチターミナルコラボレーションフレームワークに基づいて、開発者は複数のデバイスにまたがるアプリケーションを開発できます。たとえば、パッド上でビデオを視聴するためのアプリケーションを開発し、携帯電話を使用してビデオにテキストコメントや返信をしたり、端末間でビジネスを行ったりすることで、同時実行性、コラボレーション、補完性を実現できます。

5. HarmonyOS 分散操作: クロスエンド移行


HarmonyOS 上のタスク管理センターでは、スーパーターミナル上のすべてのタスクを一元的に管理できます。このタスク管理センターを使用すると、タスクを携帯電話から大画面に簡単に移行できます。このプロセスは、開発者とシステム間の接続です。システム自体はタスク管理センターとアプリケーションを通じてステータスを取得し、アプリケーション自体はコールバックを通じてシステムにステータスを渡します。開発者はシステム間で渡されるステータスについて心配する必要がありません。移行フレームワークを使用すると、ユーザーに対して継続的かつ一貫した効果を生み出すことができます。

6. HarmonyOSの基本アーキテクチャ: 分散ウィンドウ管理


マルチターミナルコラボレーションやクロスターミナル移行に関係なく、ユーザーがタスクセンターにドラッグすると、システムはドラッグされたタスクウィンドウをレンダリング用の仮想ウィンドウにドラッグし、レンダリング結果をターゲットプロキシウィンドウに渡して埋めます。ビデオストリームの送信だけでなく、ユーザーのインタラクションイベントも元のアプリケーションに送り返されます。システムにはマルチモードの統合インタラクション モジュールがありますが、アプリケーションは実際にはそれを感知できず、イベントがこちら側から来たのか、それとも向こう側から来たのかを知りません。

7. HarmonyOSの基本アーキテクチャ:分散ハードウェア


今日のデバイスには、カメラ、マイク、さまざまなセンサーなど、多くのハードウェアと周辺機器が搭載されています。たとえば、時計は睡眠、毎日の歩行、その他の健康状態を監視できます。これらのデバイスが 1 つのデバイスでのみ使用できるように制限されている場合、それは大きな制限となります。したがって、分散環境でのプログラミングでは、システムはハードウェアの観点から 2 つの機能を提供します。 1 つ目は、ハイパーターミナルに接続されたすべてのハードウェア周辺機器をグローバルにプールするグローバル仮想化です。これにより、開発者は、接続を自分で確立したり、ハードウェア使用権の交換を自分で管理したり、二次認証を要求したりすることなく、端末間の通話を行うことができます。これは、ハードウェアがプライバシーに関係することが多く、システムが統合されたグローバル仮想化を通じてこれらの基礎となる機能を開放しているためです。

2番目は自動ハードウェア追従です。当社のソフトウェアは 1 つのデバイスに限定されません。あるデバイスから別のデバイスに移行される可能性があります。たとえば、この時点でサウンドを再生している場合や、この時点で他のユーザーとビデオチャットしている場合、これらのハードウェアは自動的に移行されます。このシステムは、アプリケーション フレームワークと基盤となる分散ハードウェアを組み合わせることでこれを実現し、開発者の負担を軽減します。

詳細については、以下をご覧ください。

51CTOとHuaweiが共同で構築したHongmengテクノロジーコミュニティ

https://harmonyos..com

<<:  クラウドネイティブのインメモリデータベースであるTairは、ユーザーエクスペリエンスの最適化に役立ちます。

>>:  Huyaの「特別な目的のための特別な図書館」の海外ライブストリーミング戦略

推薦する

vpsag: ブルガリアの VPS、月額 3 ユーロ、2G メモリ/1 コア/20g SSD/10T トラフィック、100G 防御

vpsag は現在、ブルガリアのソフィア データ センターで VPS 事業を運営しており、デフォルト...

そもそもなぜzacブログの「seo」のランキングが安定しないのか?

検索エンジンのアルゴリズムの変更は、ウェブサイトのキーワードのランキングに影響を与えます。SEOはウ...

スマートルーターの時代が来るのか?

モバイルインターネットの発展に伴い、スマートホームはますます一般大衆に身近なものになり、多くの伝統的...

リン・コンプ:インテルは中国聯通の 5G エッジコンピューティングのアプリケーションシナリオの拡大と商用化の加速を支援

「インテルと中国聯通は、MEC エッジ コンピューティングとビデオの組み合わせに関する本格的なコラボ...

分散リンク トレーシング: Spring Cloud Sleuth に関する 9 つの致命的な質問

[[433789]]この記事はWeChat公式アカウント「Mayuan Technology Col...

Weiboチャンネル運用をすぐに始めるための5つのステップ!

インターネット全体のゴシップの中心地として、Weiboはますます注目を集めています。データによると、...

hosthatch ニューヨーク VPS はいかがでしょうか?実測データの共有

Hosthatchは、米国東海岸のニューヨークデータセンターにVPSクラウドサーバーサービスを展開し...

クラウド支出の無駄を減らすために知っておくべきこと

おそらく、2018 年に多くの企業にとって最も優先度の高い取り組みは、クラウド支出の最適化となるでし...

エンタープライズデジタルトランスフォーメーションからクラウドネイティブソリューションまで

クラウドネイティブへのデジタルトランスフォーメーションの概要今日は、エンタープライズのデジタル化とク...

ウェブサイトの外部リンクを確認する新しい方法があります

Yahoo は数年前に外部リンク クエリ機能を廃止し、その後 Aizhan が外部リンク クエリ機能...

電子商取引は単なる一つの手段ではありません。最も収益性の高い垂直電子商取引のトップ10

著者: Weiwuism {WeChat 公開アカウント: weiwuzy}電子商取引がいつから「お...

zgocloudはどうですか?高性能な日本のソフトバンクVPSのレビュー

当サイトでは最近、新しいVPS業者zgocloud(現在はzgovpsに改名)の日本VPSを導入しま...

China Search がクラウドソーシングで試験運用中: 異なる種類の検索の可能性はあるか?

検索エンジンはインターネットへの最初の入り口であり、常にインターネット企業にとっての戦場となっていま...

bettervps-512m メモリ KVM/20g ハードディスク/1T 月間トラフィック/月額 5 ドル

BetterVPS は、2011 年に Web デザイナーと開発者によって設立された ShoveHo...