java - com.mysql.jdbc.exceptions.jdbc4.CommunicationsException:Communications link failure -
इस सवाल का पहले से ही एक उत्तर है: < / P>
- 23 उत्तर
मेरा प्रोग्राम जो एक से कनेक्ट करता है MySQL डाटाबेस ठीक काम कर रहा था फिर, कनेक्शन सेट अप करने के लिए किसी भी कोड को बदलने के बिना, मुझे यह अपवाद मिलता है:
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: संचार लिंक विफलता आखिरी पैकेट को सफलतापूर्वक भेजा गया सर्वर 0 मिलीसेकंड पहले था। ड्राइवर को सर्वर से कोई भी पैकेट नहीं मिला है।
क्या हुआ?
कनेक्शन प्राप्त करने के लिए उपयोग किया गया कोड:
निजी स्थिर कनेक्शन getDBConnection () SQLException फेंकता है, InstantiationException, IllegalAccessException, ClassNotFoundException {स्ट्रिंग उपयोगकर्ता नाम = "उपयोगकर्ता"; स्ट्रिंग पासवर्ड = "पास"; स्ट्रिंग url = "jdbc: mysql: //www.domain.com: 3306 / dbName? कनेक्टटैमआउट = 3000"; Class.forName ( "com.mysql.jdbc.Driver"); कनेक्शन conn = DriverManager.getConnection (यूआरएल, यूज़रनेम, पासवर्ड); वापसी कनन; }
यह एक लिपटे अपवाद है और वास्तव में दिलचस्प नहीं है यह मूलभूत कारण के बारे में हमें बताए गए अपवाद के मूल कारण है कृपया स्टैक्सट्र्रेस में थोड़ा आगे देखें। मौका बड़ा है कि आपको SQLException का सामना करना होगा: कनेक्शन से इनकार कर दिया गया
या SQLException: कनेक्शन का समय समाप्त हो गया
।
यदि यह आपके मामले में सच है साथ ही, सभी संभव कारण हैं:
- जेडीबीसी यूआरएल में आईपी पता या होस्टनाम गलत है।
- JDBC यूआरएल में होस्ट नाम स्थानीय DNS सर्वर द्वारा मान्यता प्राप्त नहीं है। < / Li>
- पोर्ट नंबर गुम या गलत है JDBC यूआरएल में।
- डीबी सर्वर डाउन है।
- डीबी सर्वर टीसीपी / आईपी कनेक्शन स्वीकार नहीं करता है।
- जावा और डीबी के बीच कुछ कनेक्शन कनेक्शन अवरुद्ध कर रहा है, उदा एक फ़ायरवॉल या प्रॉक्सी।
एक या दो को हल करने के लिए, निम्न सलाहों का पालन करें:
- उन्हें
ping ।
- DNS को रीफ्रेश करें या इसके बजाय JDBC URL में आईपी पते का उपयोग करें।
- इसे MySQL DB के
my.cnf
पर आधारित सत्यापित करें।- इसे प्रारंभ करें।
- अगर mysqld
- skip-networking
विकल्प के बिना शुरू किया गया है, तो सत्यापित करें।- फ़ायरवॉल और / या फ़ायरवॉल / प्रॉक्सी को कॉन्फ़िगर करें पोर्ट की अनुमति / अग्रेषित करने के लिए।
वैसे (और वास्तविक समस्या से असंबंधित), आपको जरूरी नहीं कि हर मिलन कनेक्शन ()
कॉल करें स्टार्टअप के दौरान केवल एक बार ही पर्याप्त है।
Comments
Post a Comment