[ https://issues.apache.org/jira/browse/HTTPCLIENT-2284?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17759262#comment-17759262 ]
Oleg Kalnichevski commented on HTTPCLIENT-2284: ----------------------------------------------- [~lacompas] Please take a look at this PR: https://github.com/apache/httpcomponents-client/pull/478 With this change-set one should be able to implement custom cache storage backends with a specific cache entry eviction strategy. This is the best I can do for you. Oleg > BasicHttpCacheStorage leaking variant keys in root response's variantMap > ------------------------------------------------------------------------ > > Key: HTTPCLIENT-2284 > URL: https://issues.apache.org/jira/browse/HTTPCLIENT-2284 > Project: HttpComponents HttpClient > Issue Type: Bug > Components: HttpCache > Affects Versions: 4.5.13 > Reporter: Pascal Lacombe > Priority: Minor > Fix For: 5.3-alpha2 > > Attachments: 0001-Add-disabled-test-for-HTTPCLIENT-2284.patch > > Time Spent: 1h 10m > Remaining Estimate: 0h > > BasicHttpCacheStorage has a memory leak in the root response's variantMap. > When a variant cached entry is evicted due to CacheMap being too large, the > root cache entry does not remove the variant key in its variantMap. This is a > memory leak that can grow the variantMap indefinitely, or until the root > entry get's evicted itself. > Simplified testcase: > # A request is being sent from a client that contains a header > "x-my-variant" with a hash of the current timestamp. > # The server responds 200, with a cacheable response. The response Vary's on > "x-my-variant" > # These requests repeat, causing: > ## The "root" CacheEntry to be kept in CacheMap > ## The oldest variant CacheEntry to be evicted due to the CacheMap size limit > ## However the "root" CacheEntry never removes the evicted variant keys from > the variantMap -- This message was sent by Atlassian Jira (v8.20.10#820010) --------------------------------------------------------------------- To unsubscribe, e-mail: dev-unsubscr...@hc.apache.org For additional commands, e-mail: dev-h...@hc.apache.org