2015-05-12 6 views
10

से कनेक्ट नहीं हो सकता है मैं अपाचे 2.4 के साथ प्रमाणीकरण के रूप में mysql के साथ dbd का उपयोग करने का प्रयास कर रहा हूं।अपाचे डीबीआई आंतरिक त्रुटि: एएच 00629: mysql

जब अपाचे शुरू होता है, मैं इस त्रुटि है:

[Tue May 12 13:07:18.789021 2015] [mpm_event:notice] [pid 10625:tid 140410697815936] AH00489: Apache/2.4.10 (Debian) configured -- resuming normal operations 
[Tue May 12 13:07:18.789118 2015] [core:notice] [pid 10625:tid 140410697815936] AH00094: Command line: '/usr/sbin/apache2' 
[Tue May 12 13:07:18.789469 2015] [dbd:error] [pid 10628:tid 140410697815936] (20014)Internal error: AH00629: Can't connect to mysql: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) 
[Tue May 12 13:07:18.789560 2015] [dbd:error] [pid 10628:tid 140410697815936] (20014)Internal error: AH00633: failed to initialise 
[Tue May 12 13:07:18.790282 2015] [dbd:error] [pid 10629:tid 140410697815936] (20014)Internal error: AH00629: Can't connect to mysql: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) 
[Tue May 12 13:07:18.790441 2015] [dbd:error] [pid 10629:tid 140410697815936] (20014)Internal error: AH00633: failed to initialise 
[Tue May 12 13:07:18.792481 2015] [dbd:crit] [pid 10628:tid 140410697815936] (20014)Internal error: AH00636: child init failed! 
[Tue May 12 13:07:18.792595 2015] [dbd:crit] [pid 10629:tid 140410697815936] (20014)Internal error: AH00636: child init failed! 

dbd_mysql.conf:

DBDriver mysql 
DBDParams "host=192.168.1.2 port=3306 user=MY_USERNAME pass=MY_PASSWORD dbname=MY_DATABASE" 
DBDMin 2 
DBDKeep 4 
DBDMax 10 
DBDExptime 300 
DBDPersist On 

000-default.conf

[...] 
DBDParams "dbname=DATABASENAME" 
<IfModule authnz_ldap_module> 
    <Directory /var/www/test/> 
     AuthName "Authentication" 
     AuthType Basic 
     AuthBasicProvider dbd 
     AuthDBDUserPWQuery "SELECT SHA2(password, 256) AS password FROM users WHERE username = %s" 
     require valid-user 
    </Directory> 
</IfModule> 
[...] 

तो मैं पासवर्ड बदलने डाल करने के लिए एक अवैध, मुझे अपवाद

प्राप्त हुआ
Internal error: AH00629: Can't connect to mysql: Access denied for user... 

डेबियन: 7.8 अपाचे: 2.4.10 libapr1: 1.5.1-3 (i डाउनग्रेड करने की कोशिश की, लेकिन मैं नहीं कर सकता)

नोट: सर्वर php और न ही php + mysql (libphpmysql की जरूरत नहीं है) स्थापित

संपादित करें:

my.cnf (क्लाइंट भाग)

[client] 
port   = 3306 
socket   = /var/run/mysqld/mysqld.sock 

संपादित करें (2):

मैं भी mysql के लिए

odbc.ini "ODBC" का उपयोग करने की कोशिश की:

dbd_mysql.conf

DBDriver odbc 
DBDParams "datasource=MYSERVER_MYSQL_MYDATABASE" 
DBDMin 1 
DBDKeep 1 
DBDMax 10 
DBDExptime 300 

/etc/odbc.ini (i संवेदनशील दूर करने के लिए config संपादित डेटा)

[MYSERVER_MYSQL_MYDATABASE] 
Driver=/usr/local/lib/libmyodbc5a.so 
Description=MYSERVER_MYSQL_MYDATABASE 
SERVER=192.168.1.2 
PORT= 
USER=MY_USER 
Password=MY_PASSWORD 
Database=MY_DATABASE 
OPTION=3 
SOCKET= 

तो मैं का उपयोग करें:

# isql MYSERVER_MYSQL_MYDATABASE 
+---------------------------------------+ 
| Connected!       | 
|          | 
| sql-statement       | 
| help [tablename]      | 
| quit         | 
|          | 
+---------------------------------------+ 

यह पूरी तरह से काम कर रहे .. लेकिन अपाचे error.log पर:

[Thu May 14 09:07:51.323638 2015] [mpm_event:notice] [pid 1605:tid 140068309481344] AH00489: Apache/2.4.10 (Debian) configured -- resuming normal operations 
[Thu May 14 09:07:51.323725 2015] [core:notice] [pid 1605:tid 140068309481344] AH00094: Command line: '/usr/sbin/apache2' 
[Thu May 14 09:07:51 2015] [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Thu May 14 09:07:51.323827 2015] [dbd:error] [pid 1608:tid 140068309481344] (20014)Internal error: AH00629: Can't connect to odbc: [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Thu May 14 09:07:51.323870 2015] [dbd:error] [pid 1608:tid 140068309481344] (20014)Internal error: AH00633: failed to initialise 
[Thu May 14 09:07:51 2015] [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Thu May 14 09:07:51.324332 2015] [dbd:error] [pid 1609:tid 140068309481344] (20014)Internal error: AH00629: Can't connect to odbc: [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Thu May 14 09:07:51.324430 2015] [dbd:error] [pid 1609:tid 140068309481344] (20014)Internal error: AH00633: failed to initialise 
[Thu May 14 09:07:51.331767 2015] [dbd:crit] [pid 1608:tid 140068309481344] (20014)Internal error: AH00636: child init failed! 
[Thu May 14 09:07:51.331823 2015] [dbd:crit] [pid 1609:tid 140068309481344] (20014)Internal error: AH00636: child init failed! 

संपादित करें (3):

मैंने पाया कि मैं ड्राइवर पंजीकृत नहीं किया:

./myodbc-installer -d -a -n "MySQL ODBC 5.3 Driver" -t "DRIVER=/usr/local/lib/libmyodbc5a.so" 

फिर "dbd_mysql.conf" को बदल दिया:

DBDriver odbc 
DBDParams "CONNECT='DRIVER={MySQL ODBC 5.3 Driver};SERVER=192.168.1.2;DATABASE=MY_DATABASE;UID=MY_USER;PWD=MY_PASSWORD;'" 
DBDMin 1 
DBDKeep 1 
DBDMax 10 
DBDExptime 300 

लेकिन फिर भी एक ही समस्या (error.log):

[Fri May 15 09:38:31.905733 2015] [core:notice] [pid 5215:tid 140452627486592] AH00094: Command line: '/usr/sbin/apache2' 
[Fri May 15 09:38:31 2015] [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Fri May 15 09:38:31.905842 2015] [dbd:error] [pid 5218:tid 140452627486592] (20014)Internal error: AH00629: Can't connect to odbc: [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Fri May 15 09:38:31.905888 2015] [dbd:error] [pid 5218:tid 140452627486592] (20014)Internal error: AH00633: failed to initialise 
[Fri May 15 09:38:31 2015] [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Fri May 15 09:38:31.906424 2015] [dbd:error] [pid 5219:tid 140452627486592] (20014)Internal error: AH00629: Can't connect to odbc: [dbd_odbc] Invalid DBD Parameters - open returned SQL_ERROR (-1) at /tmp/buildd/apr-util-1.5:1146 
[Fri May 15 09:38:31.906528 2015] [dbd:error] [pid 5219:tid 140452627486592] (20014)Internal error: AH00633: failed to initialise 
[Fri May 15 09:38:31.915211 2015] [dbd:crit] [pid 5218:tid 140452627486592] (20014)Internal error: AH00636: child init failed! 
[Fri May 15 09:38:31.915578 2015] [dbd:crit] [pid 5219:tid 140452627486592] (20014)Internal error: AH00636: child init failed! 
+0

क्या mysql चल रहा है और/या सॉकेट फ़ाइल के लिए सही स्थान है? क्योंकि अपाचे सॉकेट फ़ाइल का उपयोग करने की कोशिश कर रहा है, जबकि आपकी कॉन्फ़िगरेशन इसे एक टीसीपी कनेक्शन का उपयोग करने के लिए कहने की कोशिश कर रही है। –

+0

MySQL सर्वर किसी अन्य सर्वर पर चल रहा है। मैंने कोई सॉकेट फ़ाइल सेट नहीं की है .. – Joshua

+0

अच्छी तरह से, अपाचे सॉकेट के माध्यम से कनेक्ट करने का प्रयास कर रहा है, इसलिए आपकी कॉन्फ़िगरेशन में कुछ गलत है। –

उत्तर

4

DBDParams अल्पविराम से अलग किया जाना चाहिए: DBDParams param1=value1[,param2=value2] http://httpd.apache.org/docs/2.4/mod/mod_dbd.html

+0

मैंने ";" "," डीबीडीपीएआरएम्स "ड्राइवर = {माईएसक्यूएल ओडीबीसी 5.3 चालक}, सर्वर = 1 9 2.168.1.2, डाटाबेस = MY_DATABASE, UID = MY_USER, PWD = MY_PASSWORD" ', अभी भी वही त्रुटि:' अवैध डीबीडी पैरामीटर - खोलें SQL_ERROR (-1) ' – Joshua

+0

मेरा उत्तर 'डीबीड्राइवर mysql' के साथ आपके पहले मामले में मदद करेगा, दूसरे मामले में ऐसा लगता है कि डीबीआई को' ओडीबीसी ड्राइवर को दिए गए नाम से नहीं मिला। –

+0

धन्यवाद, यह काम करता है! विन्यास: 'DBDriver mysql DBDParams" मेजबान = 192.168.1.2, उपयोगकर्ता = MY_USER, पारित = MY_PASSWORD, dbname = MY_DATABASE " DBDMin 1 DBDKeep 1 DBDMax 10 DBDExptime 300 DBDPersist On' – Joshua

0
मेरी में

।conf कोशिश

[client] 
protocol=tcp 

संदर्भ Connecting to the MySQL Server कैसे डिफ़ॉल्ट कनेक्शन पद्धति ओवरराइड करने के लिए की एक विवरण प्रदान करता है।

संदर्भ Using Option Files अस्पष्ट रूप से बताता है कि my.conf फ़ाइल में कौन से मूल्य रखे जा सकते हैं। अनिवार्य रूप से एक तर्क जो कमांड लाइन (यानी --protocol) पर mysql कमांड को पास किया जा सकता है, विकल्प फ़ाइल में, डैश के बिना निर्दिष्ट किया जा सकता है।

संबंधित मुद्दे