サーバーの差分(増分)更新について

WBOY
リリース: 2016-06-23 13:20:36
オリジナル
1037 人が閲覧しました

現在サーバー初心者なのでやり方がわかりません

例えば、2人のユーザーの場合、現在10個のサーバーデータがあり、AとBの両方が更新されています
しばらくすると、サーバーが更新され、データが 10 から 15 に増加しました

A が更新され、アプリのローカル データが 10 から 15 に変更されましたが、B は更新されず、まだ 10 でした。その間、サーバーのデータが再び更新され、データは 15 から 20 記事に増加しました


それでは、A には更新された 5 項目 (15 から 20) のみを追加させ、B には 10 項目 (10 から 20) を更新させるにはどうすればよいでしょうか20)?

ディスカッションに返信(解決策)

自分でやります

現在のデータのシリアル番号(ここではIDを使用します)の最大値をアプリに渡し、アプリが記録します

最初はAとBが同時に更新され、両方とも10です

更新時にデータのシリアル番号(ここではIDを使用します)がサーバーに送信されます。サーバーは select * from XXX where id >= クエリするアプリのローカル データ シリアル番号

A が更新されると (10 から 15)、現在の ID は 15 であり、B は更新されずに 10 のままです。同様に、サーバーは 16 から 20 のみを A に送信します 11 から 20 までのデータについては、サーバー B は増分更新を送信します

単純なロジック (データの追加のみ) の場合、上記の部分は次のようになります解決しました

しかし、ここで新たな問題が発生します。サーバーデータが変更されているか、削除対象としてマークされていますか?何をするか?

次に、次の処理を見る必要があります:
新しいフィールドマークを追加し、最初は0に設定します

AとBは最初に同時に更新され(両方とも10個のデータを更新しました)、すべての0 のマークが付いたフィールドは更新されます。ローカル マークは 0 です。

次に、テーブル内のデータを更新し (10 から 15)、その中のデータを変更し (項目 3)、項目 5 (としてマークされています) を削除します。 -1); 現在サーバー 10 から 15 までマークされたデータ マークは 1 です (1 から 10 までのものは 0 のままです)

A が更新され (10 から 15)、彼のローカル マークは 1 になりました。 ; B はローカル マークを更新せず、まだ 0 です
サーバーのデータは再度更新されます (15 から 20)
このとき、A と B は両方とも 1 としてサーバーに送信されます。 、サーバーはマークより大きいマーク (15 ~ 20 個のデータ) を探して A に送信します。同様に、0 より大きいマークを持つマーク (10 ~ 20 個のデータ) を B に送信することもできます。差分更新

それでは上記を見てみましょう。データが変更された場合はどうすればよいでしょうか?
上記のサーバーが 3 番目のデータを変更する場合、アプリが mark+2 に遭遇すると、このデータを更新し、特にクライアントを更新する必要があることに同意します。削除の同じマークの場合、-1 に同意します。これは、マークが表示されないことを意味します

ここで問題が再び発生します

サーバーの現在のマークが 5000 に達している場合、アプリは更新されていません。まだ 0 (同様の状況が新しくインストールされたクライアントにも当てはまります); その場合、同時に 5000 に更新する必要があります (数十万のデータがある可能性があります)。どうすればよいでしょうか?

そこで、制限を追加する必要があります。アプリがローカル マークをアップロードするとき、サーバーはそのマークとサーバー内の最大のマークの差が 50 を超えていると判断し、最大値のみを送信すると仮定します。 50 個のデータ (ここでは 4950 ~ 5000 個のデータ列を使用) なので、クライアントへの負担が軽減されます

それでは、期間中のデータをどうすればよいのかという疑問が生じるかもしれません。

破棄することを好みます。 。 2 番目のオプションは、この部分を処理するために小さいバージョンを選択することです。

しかし、WeChatとQQのデータを参照して、彼らはこの部分も削除しました、そして私たちは彼女がクリックできるようにまだ残しました。 。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート