Skip to content

Commit

Permalink
SOLR-17597: Fix CaffeineCache.put() ramBytes decrement (apache#2917)
Browse files Browse the repository at this point in the history
  • Loading branch information
magibney authored Dec 20, 2024
1 parent 7d856f8 commit a40826e
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 18 deletions.
36 changes: 20 additions & 16 deletions solr/core/src/java/org/apache/solr/search/CaffeineCache.java
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ private V computeAsync(K key, IOFunction<? super K, ? extends V> mappingFunction
// We reserved the slot, so we do the work
V value = mappingFunction.apply(key);
future.complete(value); // This will update the weight and expiration
recordRamBytes(key, null, value);
recordRamBytes(key, value);
inserts.increment();
return value;
} catch (Error | RuntimeException | IOException e) {
Expand Down Expand Up @@ -262,7 +262,7 @@ public V computeIfAbsent(K key, IOFunction<? super K, ? extends V> mappingFuncti
if (value == null) {
return null;
}
recordRamBytes(key, null, value);
recordRamBytes(key, value);
inserts.increment();
return value;
});
Expand All @@ -275,30 +275,34 @@ public V computeIfAbsent(K key, IOFunction<? super K, ? extends V> mappingFuncti
public V put(K key, V val) {
inserts.increment();
V old = cache.asMap().put(key, val);
recordRamBytes(key, old, val);
// ramBytes decrement for `old` happens via #onRemoval
if (val != old) {
// NOTE: this is conditional on `val != old` in order to work around a
// behavior in the Caffeine library: where there is reference equality
// between `val` and `old`, caffeine does _not_ invoke RemovalListener,
// so the entry is not decremented for the replaced value (hence we
// don't need to increment ram bytes for the entry either).
recordRamBytes(key, val);
}
return old;
}

/**
* Update the estimate of used memory
* Update the estimate of used memory.
*
* <p>NOTE: old value (in the event of replacement) adjusts {@link #ramBytes} via {@link
* #onRemoval(Object, Object, RemovalCause)}
*
* @param key the cache key
* @param oldValue the old cached value to decrement estimate (can be null)
* @param newValue the new cached value to increment estimate
*/
private void recordRamBytes(K key, V oldValue, V newValue) {
private void recordRamBytes(K key, V newValue) {
ramBytes.add(
RamUsageEstimator.sizeOfObject(newValue, RamUsageEstimator.QUERY_DEFAULT_RAM_BYTES_USED));
if (oldValue == null) {
ramBytes.add(
RamUsageEstimator.sizeOfObject(key, RamUsageEstimator.QUERY_DEFAULT_RAM_BYTES_USED));
ramBytes.add(RamUsageEstimator.LINKED_HASHTABLE_RAM_BYTES_PER_ENTRY);
if (async) ramBytes.add(RAM_BYTES_PER_FUTURE);
} else {
ramBytes.add(
-RamUsageEstimator.sizeOfObject(
oldValue, RamUsageEstimator.QUERY_DEFAULT_RAM_BYTES_USED));
}
ramBytes.add(
RamUsageEstimator.sizeOfObject(key, RamUsageEstimator.QUERY_DEFAULT_RAM_BYTES_USED));
ramBytes.add(RamUsageEstimator.LINKED_HASHTABLE_RAM_BYTES_PER_ENTRY);
if (async) ramBytes.add(RAM_BYTES_PER_FUTURE);
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,7 @@ public void testRamBytesSync() throws IOException {

cache.put(0, "test");
long nonEmptySize = cache.ramBytesUsed();
cache.put(0, "test");
cache.put(0, random().nextBoolean() ? "test" : "rest");
assertEquals(nonEmptySize, cache.ramBytesUsed());

cache.remove(0);
Expand Down Expand Up @@ -341,7 +341,7 @@ public void testRamBytesAsync() throws IOException {

cache.put(0, "test");
long nonEmptySize = cache.ramBytesUsed();
cache.put(0, "test");
cache.put(0, random().nextBoolean() ? "test" : "rest");
assertEquals(nonEmptySize, cache.ramBytesUsed());

cache.remove(0);
Expand Down

0 comments on commit a40826e

Please sign in to comment.