<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head> 
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
        <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0"> 
        <base href="https://hibernate.atlassian.net"> 
        <title>Message Title</title> 
    </head> 
    <body class="jira" style="color: #333333; font-family: Arial, sans-serif; font-size: 14px; line-height: 1.429"> 
        <table id="background-table" cellpadding="0" cellspacing="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0; background-color: #f5f5f5; border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0" bgcolor="#f5f5f5"> 
            <!-- header here --> 
            <tbody>
                <tr> 
                    <td id="header-pattern-container" style="padding: 0; border-collapse: collapse; padding: 10px 20px"> 
                        <table id="header-pattern" cellspacing="0" cellpadding="0" border="0" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0"> 
                            <tbody>
                                <tr> 
                                    <td id="header-avatar-image-container" valign="top" style="padding: 0; border-collapse: collapse; vertical-align: top; width: 32px; padding-right: 8px" width="32"> <img id="header-avatar-image" class="image_fix" src="https://secure.gravatar.com/avatar/df12d7792bd3b7be3a4edf12cabd58cb?d=mm&amp;s=48" height="32" width="32" border="0" style="border-radius: 3px; vertical-align: top"> </td> 
                                    <td id="header-text-container" valign="middle" style="padding: 0; border-collapse: collapse; vertical-align: middle; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 1px"> <a class="user-hover" rel="steve" id="email_steve" href="https://hibernate.atlassian.net/secure/ViewProfile.jspa?name=steve" style="color:#6c797f;; color: #3b73af; text-decoration: none">Steve Ebersole</a> <strong>commented</strong> on <a href="https://hibernate.atlassian.net/browse/HHH-11356" style="color: #3b73af; text-decoration: none"><img src="cid:jira-generated-image-avatar-3dbb8ed2-e5ab-499d-b06b-182255efac62" height="16" width="16" border="0" align="absmiddle" alt="Improvement"> HHH-11356</a> </td> 
                                </tr> 
                            </tbody>
                        </table> </td> 
                </tr> 
                <tr> 
                    <td id="email-content-container" style="padding: 0; border-collapse: collapse; padding: 0 20px"> 
                        <table id="email-content-table" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0; border-spacing: 0; border-collapse: separate"> 
                            <tbody>
                                <tr> 
                                    <!-- there needs to be content in the cell for it to render in some clients --> 
                                    <td class="email-content-rounded-top mobile-expand" style="padding: 0; border-collapse: collapse; color: #ffffff; padding: 0 15px 0 16px; height: 15px; background-color: #ffffff; border-left: 1px solid #cccccc; border-top: 1px solid #cccccc; border-right: 1px solid #cccccc; border-bottom: 0; border-top-right-radius: 5px; border-top-left-radius: 5px; height: 10px; line-height: 10px; padding: 0 15px 0 16px; mso-line-height-rule: exactly" height="10" bgcolor="#ffffff">&nbsp;</td> 
                                </tr> 
                                <tr> 
                                    <td class="email-content-main mobile-expand " style="padding: 0; border-collapse: collapse; border-left: 1px solid #cccccc; border-right: 1px solid #cccccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #ffffff" bgcolor="#ffffff"> 
                                        <table class="page-title-pattern" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0"> 
                                            <tbody>
                                                <tr> 
                                                    <td style="vertical-align: top;; padding: 0; border-collapse: collapse; padding-right: 5px; font-size: 20px; line-height: 30px; mso-line-height-rule: exactly" class="page-title-pattern-header-container"> <span class="page-title-pattern-header" style="font-family: Arial, sans-serif; padding: 0; font-size: 20px; line-height: 30px; mso-text-raise: 2px; mso-line-height-rule: exactly; vertical-align: middle"> <a href="https://hibernate.atlassian.net/browse/HHH-11356" style="color: #3b73af; text-decoration: none">Re: Adjust the 2nd-Cache SPIs to better reflect supported uses</a> </span> </td> 
                                                </tr> 
                                            </tbody>
                                        </table> </td> 
                                </tr> 
                                <tr> 
                                    <td id="text-paragraph-pattern-top" class="email-content-main mobile-expand  comment-top-pattern" style="padding: 0; border-collapse: collapse; border-left: 1px solid #cccccc; border-right: 1px solid #cccccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #ffffff; border-bottom: none; padding-bottom: 0" bgcolor="#ffffff"> 
                                        <table class="text-paragraph-pattern" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 2px"> 
                                            <tbody>
                                                <tr> 
                                                    <td class="text-paragraph-pattern-container mobile-resize-text " style="padding: 0; border-collapse: collapse; padding: 0 0 10px"> 
                                                        <blockquote style="margin: 10px 0 0; margin-top: 0; border-left: 1px solid #cccccc; color: #707070; margin-left: 19px; padding: 10px 20px"> 
                                                            <p style="margin: 10px 0 0; margin-top: 0">Ad timestamps (1): I haven't asked you to remove these two methods, I've asked to remove txTimestamp from RegionAccessStrategy.get and other RegionAccess methods, because there's already the SharedSessionContractImplementor session argument which provides that value in the SharedSessionContractImplementor.getTimestamp() method - therefore, repeating this in each method args seemed unnecessary. My apologies, I was a bit vague about this in the comment.</p>
                                                        </blockquote> <p style="margin: 10px 0 0">Yep, as I said: " So we can certainly remove passing it around in the cache SPI calls as method args. Perhaps that is all you meant?" I think we should plan on reoving those args then. As an extra bonus that would better document the intent of this timestamp. On <tt>SharedSessionContractImplementor#getTimestamp</tt> we already document the fact that this is meant to be a timestamp that is prior to the start of the last transaction for the Session; we should expand on that some to be very clear about the intentions of that. </p> 
                                                        <blockquote style="margin: 10px 0 0; border-left: 1px solid #cccccc; color: #707070; margin-left: 19px; padding: 10px 20px"> 
                                                            <p style="margin: 10px 0 0; margin-top: 0">I've mentioned that I find relying on a wall-clock time for consistency pretty unsafe practice, though Infinispan implementation does that, too. ORM's use of these timestamps is perfectly fine AFAIK.</p>
                                                        </blockquote> <p style="margin: 10px 0 0">As you said, I think the use of "JVM clock time" is perfectly valid for this use case as discussed above.</p> 
                                                        <blockquote style="margin: 10px 0 0; border-left: 1px solid #cccccc; color: #707070; margin-left: 19px; padding: 10px 20px"> 
                                                            <p style="margin: 10px 0 0; margin-top: 0">Ad timeout (2): Sorry, I could not find what you are referring to :-/</p>
                                                        </blockquote> <p style="margin: 10px 0 0">I am referring to <tt>Region#getTimeout</tt>. ATM all look ups for "timeout" go through a Region (that's where the method is defined). I am just asking whether there is any need for this to be on Region (which implies it can be different for different Regions), or whether we should move that to RegionFactory (aka, it is more general to the provider)?</p> 
                                                        <blockquote style="margin: 10px 0 0; border-left: 1px solid #cccccc; color: #707070; margin-left: 19px; padding: 10px 20px"> 
                                                            <p style="margin: 10px 0 0; margin-top: 0">Ad stats (3): I agree that these may not be meaningful (and I am happy to see toMap going out - that's not even statistics). But users will ask for something like that, so the path should be paved - providing that as optional part is fine. </p>
                                                        </blockquote> <p style="margin: 10px 0 0">The only one that I feel strongly about is <tt>#toMap</tt>. I know people implementing 2nd level cache providers before have complained about this one. IMO it should go away - I think it serves no purpose to expose this through Hibernate's caching SPI. On a related note, I would like to suggest y'all consider "unwrap" capabilities to allow users to get to your specific APIs. I mean something like adding <tt>RegionFactory#unwrap</tt>, <tt>Region#unwrap</tt> and/or <tt>RegionAccess#unwrap</tt></p> 
                                                        <blockquote style="margin: 10px 0 0; border-left: 1px solid #cccccc; color: #707070; margin-left: 19px; padding: 10px 20px"> 
                                                            <p style="margin: 10px 0 0; margin-top: 0">I am just unsure how should the StatisticsImplementor be used, and how will user figure out how many entities are stored in 2LC or its part.</p>
                                                        </blockquote> <p style="margin: 10px 0 0">You mean the StatisticsImplementor I am injecting into <tt>StatisticsAwareRegionAccess</tt>? The intent of that is to have the Region/RegionAccess take over responsibility for managing reporting lookups, hits and misses to the statistics implementor (IMO this is where that belongs). For the moment I just pass in StatisticsImplementor, but ultimately I think a "RegionObserver" contract makes more sense. </p> <p style="margin: 10px 0 0">Although, if we continue to support <tt>#getSizeInMemory</tt>, <tt>#getElementCountInMemory</tt> and <tt>#getElementCountOnDisk</tt> then that changes the dynamic a bit. Injecting the StatisticsImplementor/RegionObserver operates on a push model in regards to letting the Region/RegionAccess manage notifications to statistics about lookups/hits/misses. But <tt>#getSizeInMemory</tt>, <tt>#getElementCountInMemory</tt> and <tt>#getElementCountOnDisk</tt> are inherently more pull related. Perhaps we just handle these (lookup/hit/miss counts versus size-in-memory/element-count...) separately - especially if we say the latter ones are "optional". </p> <p style="margin: 10px 0 0">Relatedly, at the moment I inject the StatisticsImplementor into the RegionAccess. Logically however the statistics are per Region. So I'd actually propose that we move that injection target to Region. The RegionAccess is still the right place to recognize hits/misses/etc, but it can simply delegate to its Region's RegionObserver.</p> <p style="margin: 10px 0 0">Keep in mind too that statistics report this information per-Region. That means from the perspective of statistics lookup count, hit count, miss count, size in memory, etc are all relative to Region. Having the Region be able to answer especially these optional <tt>#getSizeInMemory</tt>, <tt>#getElementCountInMemory</tt> and <tt>#getElementCountOnDisk</tt> means the Region would have to keep track of all the RegionAccess objects built from it (so that it can group all those values together). One option to remove this from cache-specific statistics (org.hibernate.stat.SecondLevelCacheStatistics) and instead expose it through the entity/collection/natural-id statistics (EntityStatistics, CollectionStatistics, NaturalIdStatistics)</p> 
                                                        <blockquote style="margin: 10px 0 0; border-left: 1px solid #cccccc; color: #707070; margin-left: 19px; padding: 10px 20px"> 
                                                            <p style="margin: 10px 0 0; margin-top: 0">Ad SessionFactoryOptions: yes, to resolve settings.getServiceRegistry().getService( StrategySelector.class ).resolveDefaultableStrategy(...) and then also to access user-provided configuration file using proper class loader.</p>
                                                        </blockquote> <p style="margin: 10px 0 0">Ok, but those are easily handleable in other ways... RegionFactory is itself a Service. Services can be injected with the ServiceRegistry they belong to.</p> </td> 
                                                </tr> 
                                            </tbody>
                                        </table> </td> 
                                </tr> 
                                <tr> 
                                    <td class="email-content-main mobile-expand " style="padding: 0; border-collapse: collapse; border-left: 1px solid #cccccc; border-right: 1px solid #cccccc; border-top: 0; border-bottom: 0; padding: 0 15px 0 16px; background-color: #ffffff" bgcolor="#ffffff"> <script type="application/ld+json">
{
  "@context": "http://schema.org",
  "@type": "EmailMessage",
  "description": "View Issue",
  "potentialAction": {
    "@type": "ViewAction",
        "target": "https://hibernate.atlassian.net/browse/HHH-11356?inbox=true&focusedCommentId=90112&page=com.atlassian.jira.plugin.system.issuetabpanels%3Acomment-tabpanel#comment-90112",
    "name": "View Comment"
      },
  "publisher": {
    "@type": "Organization",
    "name": "Atlassian",
    "url": "https://www.atlassian.com"
  }
}
</script> 
                                        <table id="actions-pattern" cellspacing="0" cellpadding="0" border="0" width="100%" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 1px"> 
                                            <tbody>
                                                <tr> 
                                                    <td id="actions-pattern-container" valign="middle" style="padding: 0; border-collapse: collapse; padding: 10px 0 10px 24px; vertical-align: middle; padding-left: 0"> 
                                                        <table align="left" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0"> 
                                                            <tbody>
                                                                <tr> 
                                                                    <td class="actions-pattern-action-icon-container" style="padding: 0; border-collapse: collapse; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 0; vertical-align: middle"> <a href="https://hibernate.atlassian.net/browse/HHH-11356#add-comment" target="_blank" title="Add Comment" style="color: #3b73af; text-decoration: none"> <img class="actions-pattern-action-icon-image" src="cid:jira-generated-image-static-comment-icon-45e3811d-142b-4120-8fb0-b9c896473c22" alt="Add Comment" title="Add Comment" height="16" width="16" border="0" style="vertical-align: middle"> </a> </td> 
                                                                    <td class="actions-pattern-action-text-container" style="padding: 0; border-collapse: collapse; font-family: Arial, sans-serif; font-size: 14px; line-height: 20px; mso-line-height-rule: exactly; mso-text-raise: 4px; padding-left: 5px"> <a href="https://hibernate.atlassian.net/browse/HHH-11356#add-comment" target="_blank" title="Add Comment" style="color: #3b73af; text-decoration: none">Add Comment</a> </td> 
                                                                </tr> 
                                                            </tbody>
                                                        </table> </td> 
                                                </tr> 
                                            </tbody>
                                        </table> </td> 
                                </tr> 
                                <!-- there needs to be content in the cell for it to render in some clients --> 
                                <tr> 
                                    <td class="email-content-rounded-bottom mobile-expand" style="padding: 0; border-collapse: collapse; color: #ffffff; padding: 0 15px 0 16px; height: 5px; line-height: 5px; background-color: #ffffff; border-top: 0; border-left: 1px solid #cccccc; border-bottom: 1px solid #cccccc; border-right: 1px solid #cccccc; border-bottom-right-radius: 5px; border-bottom-left-radius: 5px; mso-line-height-rule: exactly" height="5" bgcolor="#ffffff">&nbsp;</td> 
                                </tr> 
                            </tbody>
                        </table> </td> 
                </tr> 
                <tr> 
                    <td id="footer-pattern" style="padding: 0; border-collapse: collapse; padding: 12px 20px"> 
                        <table id="footer-pattern-container" cellspacing="0" cellpadding="0" border="0" style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0"> 
                            <tbody>
                                <tr> 
                                    <td id="footer-pattern-text" class="mobile-resize-text" width="100%" style="padding: 0; border-collapse: collapse; color: #999999; font-size: 12px; line-height: 18px; font-family: Arial, sans-serif; mso-line-height-rule: exactly; mso-text-raise: 2px"> This message was sent by Atlassian JIRA <span id="footer-build-information">(v1000.747.1#100028-<span title="3d05bd69f16f8de5a8061c8aed7fc0a7dba99d65" data-commit-id="3d05bd69f16f8de5a8061c8aed7fc0a7dba99d65}">sha1:3d05bd6</span>)</span> </td> 
                                    <td id="footer-pattern-logo-desktop-container" valign="top" style="padding: 0; border-collapse: collapse; padding-left: 20px; vertical-align: top"> 
                                        <table style="border-collapse: collapse; mso-table-lspace: 0; mso-table-rspace: 0"> 
                                            <tbody>
                                                <tr> 
                                                    <td id="footer-pattern-logo-desktop-padding" style="padding: 0; border-collapse: collapse; padding-top: 3px"> <img id="footer-pattern-logo-desktop" src="cid:jira-generated-image-static-footer-desktop-logo-ec74c820-3661-45bd-ac09-428e2b453a06" alt="Atlassian logo" title="Atlassian logo" width="169" height="36" class="image_fix"> </td> 
                                                </tr> 
                                            </tbody>
                                        </table> </td> 
                                </tr> 
                            </tbody>
                        </table> </td> 
                </tr> 
            </tbody>
        </table>   
    </body>
</html>