हाइबरनेट - कैशिंग

कैशिंग एक प्रणाली के प्रदर्शन को बढ़ाने के लिए एक तंत्र है। यह एक बफर मेमोरीथ है जो एप्लिकेशन और डेटाबेस के बीच स्थित है। संभव के रूप में डेटाबेस हिट की संख्या को कम करने के लिए कैश मेमोरी स्टोर ने हाल ही में डेटा आइटम का उपयोग किया।

हाइबरनेट के साथ-साथ कैशिंग महत्वपूर्ण है। यह बहुस्तरीय कैशिंग योजना का उपयोग करता है जैसा कि नीचे बताया गया है -

प्रथम-स्तरीय कैश

प्रथम स्तर का कैश सत्र कैश है और एक अनिवार्य कैश है जिसके माध्यम से सभी अनुरोधों को पारित करना होगा। सत्र ऑब्जेक्ट डेटाबेस में करने से पहले किसी वस्तु को अपनी शक्ति के अंतर्गत रखता है।

यदि आप किसी ऑब्जेक्ट के लिए कई अपडेट जारी करते हैं, तो हाइबरनेट अपडेट किए गए SQL स्टेटमेंट की संख्या को कम करने के लिए यथासंभव लंबे समय तक अपडेट करने में देरी करने की कोशिश करता है। यदि आप सत्र बंद करते हैं, तो कैश की जा रही सभी वस्तुएँ खो जाती हैं और या तो डेटाबेस में बनी रहती हैं या अपडेट रहती हैं।

दूसरे स्तर का कैश

दूसरे स्तर का कैश एक वैकल्पिक कैश है और दूसरे स्तर के कैश में किसी वस्तु का पता लगाने के लिए किए जाने वाले किसी भी प्रयास से पहले हमेशा पहले स्तर के कैश से परामर्श किया जाएगा। दूसरे स्तर के कैश को प्रति-वर्ग और प्रति-संग्रह के आधार पर कॉन्फ़िगर किया जा सकता है और मुख्य रूप से सत्रों में कैशिंग ऑब्जेक्ट के लिए जिम्मेदार है।

किसी भी तृतीय-पक्ष कैश का उपयोग हाइबरनेट के साथ किया जा सकता है। एकorg.hibernate.cache.CacheProvider इंटरफ़ेस प्रदान किया गया है, जिसे कैश कार्यान्वयन के लिए हैंडल के साथ हाइबरनेट प्रदान करने के लिए लागू किया जाना चाहिए।

क्वेरी-स्तरीय कैश

हाइबरनेट भी क्वेरी परिणाम के लिए एक कैश लागू करता है जो दूसरे स्तर के कैश के साथ निकटता से एकीकृत करता है।

यह एक वैकल्पिक विशेषता है और इसके लिए दो अतिरिक्त भौतिक कैश क्षेत्रों की आवश्यकता होती है जो कैश्ड क्वेरी परिणाम और टाइमस्टैम्प को पकड़ते हैं जब एक तालिका को अंतिम बार अपडेट किया गया था। यह केवल उन प्रश्नों के लिए उपयोगी है जो समान मापदंडों के साथ अक्सर चलते हैं।

दूसरा स्तर कैश

हाइबरनेट डिफ़ॉल्ट रूप से प्रथम-स्तरीय कैश का उपयोग करता है और आपके पास प्रथम-स्तरीय कैश का उपयोग करने के लिए कुछ भी नहीं है। आइए सीधे वैकल्पिक द्वितीय-स्तरीय कैश पर जाएं। सभी वर्गों को कैशिंग से लाभ नहीं होता है, इसलिए दूसरे स्तर के कैश को अक्षम करने में सक्षम होना महत्वपूर्ण है।

हाइबरनेट दूसरे स्तर का कैश दो चरणों में स्थापित किया गया है। सबसे पहले, आपको यह तय करना होगा कि कौन सी निर्णायक रणनीति का उपयोग करना है। उसके बाद, आप कैश समाप्ति और भौतिक कैश विशेषताओं को कैश प्रदाता का उपयोग करके कॉन्फ़िगर करते हैं।

कंज्यूरिटी स्ट्रेटेजीज

एक संगामिति रणनीति एक मध्यस्थ है, जो कैश में डेटा की वस्तुओं को संग्रहीत करने और उन्हें कैश से पुनर्प्राप्त करने के लिए जिम्मेदार है। यदि आप एक दूसरे स्तर के कैश को सक्षम करने जा रहे हैं, तो आपको प्रत्येक स्थिर वर्ग और संग्रह के लिए निर्णय लेना होगा, जिसे उपयोग करने के लिए संक्षिप्त रणनीति का उपयोग करना है।

  • Transactional - पढ़ने के लिए इस रणनीति का उपयोग करें ज्यादातर डेटा जहां यह समवर्ती लेनदेन में बासी डेटा को रोकने के लिए महत्वपूर्ण है, एक अद्यतन के दुर्लभ मामले में।

  • Read-write - फिर से इस रणनीति का उपयोग रीड-ज्यादातर डेटा के लिए करें जहां अपडेट के दुर्लभ मामले में समवर्ती लेनदेन में बासी डेटा को रोकना महत्वपूर्ण है।

  • Nonstrict-read-write- यह रणनीति कैश और डेटाबेस के बीच स्थिरता की कोई गारंटी नहीं देती है। इस रणनीति का उपयोग करें यदि डेटा शायद ही कभी बदलता है और बासी डेटा की एक छोटी संभावना महत्वपूर्ण चिंता का विषय नहीं है।

  • Read-only- डेटा के लिए उपयुक्त एक निर्णायक रणनीति, जो कभी नहीं बदलती। इसे केवल संदर्भ डेटा के लिए उपयोग करें।

अगर हम अपने लिए दूसरे स्तर की कैशिंग का उपयोग करने जा रहे हैं Employee वर्ग, आइए हम हाइबरनेट को कैश-एंप्लॉयी को पढ़ने-लिखने की रणनीति का उपयोग करके बताने के लिए आवश्यक मानचित्रण तत्व जोड़ते हैं।

<?xml version = "1.0" encoding = "utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 
<hibernate-mapping>
   <class name = "Employee" table = "EMPLOYEE">
      
      <meta attribute = "class-description">
         This class contains the employee detail. 
      </meta>
      
      <cache usage = "read-write"/>
      
      <id name = "id" type = "int" column = "id">
         <generator class="native"/>
      </id>
      
      <property name = "firstName" column = "first_name" type = "string"/>
      <property name = "lastName" column = "last_name" type = "string"/>
      <property name = "salary" column = "salary" type = "int"/>
      
   </class>
</hibernate-mapping>

उपयोग = "पठन-लेखन" विशेषता हाइबरनेट को परिभाषित कैश के लिए एक पठन-लेखन संगोष्ठी रणनीति का उपयोग करने के लिए कहती है।

कैश प्रदाता

संगामिति रणनीतियों पर विचार करने के बाद आपका अगला कदम, आप कैश प्रदाता चुनने के लिए अपने कैश उम्मीदवार वर्गों का उपयोग करेंगे। हाइबरनेट आपको पूरे एप्लिकेशन के लिए एकल कैश प्रदाता चुनने के लिए मजबूर करता है।

अनु क्रमांक। कैश नाम और विवरण
1

EHCache

यह मेमोरी या डिस्क और क्लस्टरिंग कैशिंग में कैश कर सकता है और यह वैकल्पिक हाइबरनेट क्वेरी परिणाम कैश का समर्थन करता है।

2

OSCache

समाप्ति नीतियों और रिच कैशे समर्थन के एक समृद्ध सेट के साथ एकल JVM में मेमोरी और डिस्क पर कैशिंग का समर्थन करता है।

3

warmCache

JGroups पर आधारित एक क्लस्टर कैश। यह संकुलित अमान्य का उपयोग करता है, लेकिन हाइबरनेट क्वेरी कैश का समर्थन नहीं करता है।

4

JBoss Cache

एक पूरी तरह से ट्रांजेक्शनल प्रतिकृति क्लस्टर्ड कैश भी JGroups मल्टीकास्ट लाइब्रेरी पर आधारित है। यह प्रतिकृति या अमान्य, तुल्यकालिक या अतुल्यकालिक संचार और आशावादी और निराशावादी लॉकिंग का समर्थन करता है। हाइबरनेट क्वेरी कैश समर्थित है।

प्रत्येक कैश प्रदाता प्रत्येक संगामिति रणनीति के अनुकूल नहीं है। निम्नलिखित संगतता मैट्रिक्स आपको एक उपयुक्त संयोजन चुनने में मदद करेगी।

रणनीति / प्रदाता सिफ़ पढ़िये Nonstrictread-लिखने पढ़ना लिखना लेन-देन संबंधी
ehcache एक्स एक्स एक्स  
OSCache एक्स एक्स एक्स  
SwarmCache एक्स एक्स    
JBoss कैश एक्स     एक्स

आप hibernate.cfg.xml कॉन्फ़िगरेशन फ़ाइल में कैश प्रदाता निर्दिष्ट करेंगे। हम EHCache को अपने दूसरे स्तर के कैश प्रदाता के रूप में चुनते हैं -

<?xml version = "1.0" encoding = "utf-8"?>
<!DOCTYPE hibernate-configuration SYSTEM 
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
   <session-factory>
   
      <property name = "hibernate.dialect">
         org.hibernate.dialect.MySQLDialect
      </property>
   
      <property name = "hibernate.connection.driver_class">
         com.mysql.jdbc.Driver
      </property>
   
      <!-- Assume students is the database name -->
   
      <property name = "hibernate.connection.url">
         jdbc:mysql://localhost/test
      </property>
   
      <property name = "hibernate.connection.username">
         root
      </property>
   
      <property name = "hibernate.connection.password">
         root123
      </property>
   
      <property name = "hibernate.cache.provider_class">
         org.hibernate.cache.EhCacheProvider
      </property>
   
      <!-- List of XML mapping files -->
      <mapping resource = "Employee.hbm.xml"/>
   
   </session-factory>
</hibernate-configuration>

अब, आपको कैश क्षेत्रों के गुणों को निर्दिष्ट करने की आवश्यकता है। EHCache की अपनी कॉन्फ़िगरेशन फ़ाइल है,ehcache.xml, जो एप्लिकेशन के क्लास में होना चाहिए। कर्मचारी वर्ग के लिए ehcache.xml में एक कैश कॉन्फ़िगरेशन इस तरह दिख सकता है -

<diskStore path="java.io.tmpdir"/>

<defaultCache
maxElementsInMemory = "1000"
eternal = "false"
timeToIdleSeconds = "120"
timeToLiveSeconds = "120"
overflowToDisk = "true"
/>

<cache name = "Employee"
maxElementsInMemory = "500"
eternal = "true"
timeToIdleSeconds = "0"
timeToLiveSeconds = "0"
overflowToDisk = "false"
/>

यही है, अब हमारे पास कर्मचारी वर्ग और हाइबरनेट के लिए दूसरे स्तर का कैशिंग सक्षम है, अब जब भी आप किसी कर्मचारी को नेविगेट करते हैं या जब आप किसी कर्मचारी को पहचानकर्ता द्वारा लोड करते हैं तो दूसरे स्तर के कैश को हिट करते हैं।

आपको अपनी सभी कक्षाओं का विश्लेषण करना चाहिए और प्रत्येक कक्षाओं के लिए उपयुक्त कैशिंग रणनीति का चयन करना चाहिए। शायद ही कभी, दूसरे स्तर के कैशिंग आवेदन के प्रदर्शन को कम कर सकते हैं। तो, कैशिंग को सक्षम किए बिना और बाद में आपकी अच्छी तरह से अनुकूल कैशिंग को सक्षम करने और प्रदर्शन की जांच करने के लिए, अपने आवेदन को पहले बेंचमार्क करने की सिफारिश की जाती है। यदि कैशिंग सिस्टम प्रदर्शन में सुधार नहीं कर रहा है, तो किसी भी प्रकार के कैशिंग को सक्षम करने का कोई मतलब नहीं है।

क्वेरी-स्तरीय कैश

क्वेरी कैश का उपयोग करने के लिए, आपको पहले इसे उपयोग करके सक्रिय करना होगा hibernate.cache.use_query_cache="true"कॉन्फ़िगरेशन फ़ाइल में गुण। इस गुण को सही करने के लिए, आप हाइबरनेट को क्वेरी और पहचानकर्ता सेट रखने के लिए मेमोरी में आवश्यक कैश बनाते हैं।

इसके बाद, क्वेरी कैश का उपयोग करने के लिए, आप क्वेरी वर्ग के सेटचेलेबल (बुलियन) पद्धति का उपयोग करते हैं। उदाहरण के लिए -

Session session = SessionFactory.openSession();
Query query = session.createQuery("FROM EMPLOYEE");
query.setCacheable(true);
List users = query.list();
SessionFactory.closeSession();

हाइबरनेट भी कैश क्षेत्र की अवधारणा के माध्यम से बहुत महीन दाने वाले कैश सपोर्ट का समर्थन करता है। कैश क्षेत्र कैश का एक भाग है जिसे एक नाम दिया गया है।

Session session = SessionFactory.openSession();
Query query = session.createQuery("FROM EMPLOYEE");
query.setCacheable(true);
query.setCacheRegion("employee");
List users = query.list();
SessionFactory.closeSession();

यह कोड हाइबरनेट को स्टोर करने और कैश के कर्मचारी क्षेत्र में क्वेरी की तलाश करने के लिए विधि का उपयोग करता है।