ホームページ >ウェブフロントエンド >jsチュートリアル >好奇心: Ably.io リアルタイム メッセージングを軽量データベースとして使用する

好奇心: Ably.io リアルタイム メッセージングを軽量データベースとして使用する

Susan Sarandon
Susan Sarandonオリジナル
2025-01-05 02:48:38210ブラウズ

Curiosity: Using Ably.io Realtime Messaging as a Lightweight Database

これは dev.to サイトへの 14 回目の書き込みです。この投稿では、リアルタイム メッセージング機能を使用する興味深い方法を紹介します。

注: これはリアルタイム メッセージングの典型的なソリューションではありません。

Ably は開発者向けにさまざまなソリューションを提供しており、最も人気のあるソリューションはパブリッシュ/サブスクライブ モデルに基づくリアルタイム メッセージングです。メッセージをチャネルに公開すると、そのチャネルに接続されているすべてのデバイスが即座にメッセージを受信します。

Ably は、チャンネルのメッセージにメッセージの永続性を提供します (無料アカウントでは 24 時間)。特に興味深いのは、最後のメッセージを 365 日間保持できる機能です。 この例では、この機能を利用します。

概念は単純です。フォームとレコードのリスト (ToDo リスト、買い物リスト、連絡先リストなど) が単一の永続メッセージとして保存されている Web アプリまたはモバイル アプリを想像してください。任意のデバイス (PC、タブレット、または携帯電話) でアプリを起動すると、Ably からのデータが同期されます。データに加えた変更はすべて新しい永続メッセージとして保存され、すべてのデバイスからアクセスできる「リアルタイム データベース」を効果的に作成します。

考慮すべき制限がいくつかあります。メッセージの最大長は 64 KB (メタデータ、ID、タイムスタンプなどを含む) です。 2 KB を超えるメッセージは送信のためにチャンクに分割されるため、Ably ではデータ サイズをこの制限より十分に小さく保つことをお勧めします。したがって、このソリューションは少量のデータに最適です。

このコンセプトをテストしたところ、完璧に機能しました。レコードを追加および削除すると、すべてのクライアント アプリケーション (Web/モバイル) の同期を保つメッセージの更新がトリガーされます。

flems.io 上に単一のページ (HTML CSS JS) として単純な概念実証を作成しました。自分で試してみるには、次のことを行う必要があります:

  1. Ably アプリを作成する
  2. API キーを JS コード (行 37) に挿入します
  3. 「Realtime」という名前のチャネルを作成し、「最後のメッセージを保持する」オプションを有効にします

アプリには重要な部分、JS コードがあります:

const ably = new Ably.Realtime("put your API KEY here");
const channel = ably.channels.get('[?rewind=1]Realtime');
var persons = [];

channel.subscribe("db", (message) => {
  persons = message.data;
  renderTable();
});

function addPerson() {
  const name = document.getElementById('name').value;
  const age = document.getElementById('age').value;
  const role = document.getElementById('role').value;

  if (name && age && role) {
    const newPerson = { name: name, age: age, role: role };
    persons.push(newPerson);
    updatePersons();
    document.getElementById('name').value = '';
    document.getElementById('age').value = '';
    document.getElementById('role').value = '';
  }
}

function deletePerson(index) {
  persons.splice(index, 1);
  updatePersons();
}

function updatePersons() {
  channel.publish("db", persons);
}

function renderTable() {
  const personTable = 
  document.getElementById('personTable');
  personTable.innerHTML = '';
  persons.forEach((person, index) => {
    const row = `<tr>
    <td>${person.name}</td>
    <td>${person.age}</td>
    <td>${person.role}</td>
    <td><button onclick="deletePerson(${index})">( X )</button></td>
    </tr>`;
    personTable.innerHTML += row;
  });
}

flems.io 上の私のアプリ

これがあなたにインスピレーションを与えてくれることを願っています! :-)

以上が好奇心: Ably.io リアルタイム メッセージングを軽量データベースとして使用するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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