तो मैं Heroku पर अपने जावा अनुप्रयोग को तैनात करना चाहते हैं के साथ हाइबरनेट कॉन्फ़िगर कर सकते हैं। एक बार तैनात किए जाने पर यह एक पर्यावरण चर DATABASE_URL सेट करता है। मैं इसे हाइबरनेट के लिए अपने यूआरएल के रूप में उपयोग करना चाहता हूं। मैं वर्तमान में hibernate.cfg.xml है और वहाँ मैं यूआरएल JDBC सेट: PostgreSQL: // स्थानीय होस्ट: पोर्ट/इस तरह db। मैं इसे DATABASE_URL लेने के लिए कैसे बदल सकता हूं?मैं कैसे वातावरण चर
उत्तर
तरीकों में से एक Configuration की setProperty(String propertyName, String value) उपयोग करने के लिए स्पष्ट रूप से SessionFactory बनाने से पहले hibernate.connection.url
के मान को ओवरराइड करने के लिए है।
वातावरण चर पाने के लिए आपको System.getenv(String name) उपयोग कर सकते हैं।
/**Load the hibernate.cfg.xml from the classpath**/
Configuration cfg = new Configuration();
cfg.setProperty("hibernate.connection.url", System.getenv("DATABASE_URL"));
SessionFactory sessionFactory = cfg.buildSessionFactory();
मई इस मदद आप,
मैं JBoss के HSQL डीबी उपयोग कर रहा हूँ 5.x के रूप में और गतिशील तालिकाएं बनाने के लिए हाइबरनेट और * .cfg.xml फ़ाइल निम्न का उपयोग कर।
जो वातावरण चर के रूप में$
JBOSS_HOME उपयोग कर रहा है
।
<?xml version="1.0" encoding="UTF-8"?>
<session-factory>
<!-- Database connection settings -->
<property name="connection.driver_class">org.hsqldb.jdbcDriver</property>
<property name="connection.url">jdbc:hsqldb:$JBOSS_HOME/server/test/data/hypersonic/localDB</property>
<property name="connection.username">sa</property>
<property name="connection.password"></property>
<!-- JDBC connection pool (use the built-in) -->
<property name="connection.pool_size">1</property>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.HSQLDialect</property>
<!-- Enable Hibernate's automatic session context management -->
<property name="current_session_context_class">thread</property>
<!-- Disable the second-level cache -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">true</property>
<!-- Drop and re-create the database schema on startup -->
<property name="hbm2ddl.auto">update</property>
<!-- Mapping files -->
<mapping resource="friends_presence_log.hbm.xml" />
<mapping resource="profileuuid.hbm.xml" />
</session-factory>
तो, इसका मतलब है आप Jboss config में वातावरण चर का उपयोग करने के तो अपने सामान्य रूप से उपयोग कर सकते हैं, जो बाद में आंतरिक hibernate.jar उपयोगिता द्वारा उठाए चाहते हैं और आप जावा प्रोग्राम में सामान्य रूप से कनेक्शन या चीजें प्राप्त करते हैं।
मैंने जावा में किसी भी प्रोग्रामिंग के बिना किसी अन्य समाधान के लिए बहुत कुछ खोजा। मैं निष्कर्ष
निम्नलिखित<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.check_nullability">false</property>
<property name="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</property>
<property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
<property name="hibernate.connection.username">${hibernate_username}</property>
<property name="hibernate.connection.password">${hibernate_password}</property>
<property name="hibernate.connection.url">jdbc:postgresql://${hibernate_db_host}/${hibernate_db_name}</property>
<property name="hibernate.search.autoregister_listeners">false</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="hibernate.show_sql">${hibernate_show_sql}</property>
</session-factory>
</hibernate-configuration>
के लिए आया था और मैं निम्नलिखित vmargs साथ अपने आवेदन शुरू:
-Dhibernate_username=test-Dhibernate_password=testpassword -Dhibernate_db_host=localhost -Dhibernate_db_name=test -Dhibernate_show_sql=true
मैं इस पुराने पोस्ट के लिए इस समाधान पोस्ट, क्योंकि मैं एक पुराने मंच पोस्ट में इस पाया (Google खोज साइड 3+ ^^)। और मुझे लगता है कि यह बहुत उपयोगी है।
- 1. स्थापना/वातावरण चर
- 2. Makefile: वातावरण चर
- 3. उपयोगकर्ता वातावरण चर
- 4. MAVEN_OPTS वातावरण चर
- 5. पढ़ने बैश वातावरण चर
- 6. मैं सी पूर्वप्रक्रमक का उपयोग कैसे करूँ एक वातावरण चर
- 7. बहुपंक्ति पाठ फ़ाइल, कैसे एक वातावरण चर
- 8. यूनिक्स में नया वातावरण चर कैसे बनाएं ....?
- 9. Node.js हमेशा के लिए वातावरण चर
- 10. क्या एक प्रणाली संपत्ति और वातावरण चर
- 11. की स्थापना वातावरण चर को प्रोग्राम के
- 12. जावा क्लस्टर वातावरण में स्थिर चर
- 13. विम स्क्रिप्ट में विंडोज वातावरण चर का उपयोग कैसे करें?
- 14. कैसे वातावरण चर डॉट अलग निर्यात करने के लिए
- 15. सेट वातावरण चर SSH_ASKPASS या sudoers में askpass, resp
- 16. विंडोज बैच फ़ाइल से सिस्टम वातावरण चर सेट करना?
- 17. अजगर कपड़े के लिए वापस बैश वातावरण चर भेजें
- 18. । एकाधिक वातावरण में एचटीएसीएसी
- 19. टोमकैट उत्पादन/देव वातावरण
- 20. मैं साझा होस्टिंग वातावरण में RavenDB कैसे चला सकता हूं?
- 21. मैं रेल वातावरण में रूबी फ़ाइल कैसे चला सकता हूं?
- 22. Sitecore वातावरण
- 23. मैं Verilog/System Verilog में एक पर्यावरण चर कैसे पढ़ूं?
- 24. Grails वातावरण
- 25. कुकी-मुक्त वातावरण (ब्राइटस्क्रिप्ट)
- 26. मैं शेफ में टेम्पलेट्स, डाटाबेस और वातावरण का उपयोग कैसे करता हूं?
- 27. कैसे बैश के अंदर एक वातावरण चर डालने के लिए संकेत
- 28. जावा: विंडोज़ पर जेडीके स्थापित करने के बाद आवश्यक वातावरण चर क्या हैं और कैसे?
- 29. मैं स्कैला में एक चर कैसे डालूं?
- 30. मैं कैसे समारोह के चर नेस्टेड समारोह
बहुत बहुत हालांकि कुछ मिनट पहले यह पता लगा धन्यवाद। :) –
कृपया मुझे बताएं कि यह ठीक है या नहीं। शुभकामनाएं :) –
आपको System.getenv ("DATABASE_URL") से लौटाई गई स्ट्रिंग को ट्विक करने की आवश्यकता हो सकती है। –