非常に高価なクエリの結果があります。それはいくつかのテーブルの結合であり、マップ削減ジョブです。memcached期限切れシナリオで犬の積み重ねや雷を避ける
これはmemcached
に15分間キャッシュされます。キャッシュが期限切れになると、クエリは明らかに実行され、キャッシュは再び暖かくなります。
ただし、有効期限が到来するとthundering herd problem
の問題が発生する可能性があります。
この問題を解決する1つの方法は、今は14分に始まるスケジュールされたタスクを実行することです。しかし、どういうわけか、これは私には非常に最適ではないようです。
私が好きな別のアプローチは、nginxのproxy_cache_use_stale updating;
メカニズムです。
Webサーバー/マシンは、有効期限が切れた時点でスレッドが起動してキャッシュが更新されている間、古いキャッシュを引き続き配信します。
私はこれがクライアント側の戦略であると理解していますが、誰かがこれをmemcached
シナリオに適用しましたか?
私が恩恵を受ける場合、私はDjango
を使用します。
を見ているかもしれません。私は興味があります、あなたは何を使って終わりましたか? – Seperman