2015-05-12 5 views
10

Sto provando a utilizzare dbd con mysql come autenticazione con Apache 2.4.Apache dbd Errore interno: AH00629: Impossibile connettersi a mysql

Quando Apache si avvia, ho questo errore:

[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> 
[...] 

Se cambio la password per mettere uno non valido, ho ricevuto l'eccezione

Internal error: AH00629: Can't connect to mysql: Access denied for user... 

Debian: 7.8 Apache: 2.4.10 libapr1: 1.5.1-3 (ho cercato di downgrade, ma non posso)

Nota: Il server non hanno né PHP MySQL + PHP (libphpmysql) installato

Edit:

my.cnf (parte client)

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

Edit (2):

Ho anche cercato di utilizzare il "ODBC" per mysql

ODBC.ini:

dbd_mysql.conf

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

/etc/odbc.ini (Ho modificato la configurazione per rimuovere sensibile dati)

[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= 

se uso:

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

E 'perfettamente funzionante .. ma sul error.log apache:

[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! 

Edit (3):

ho scoperto che non ha registrato il conducente:

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

Quindi modificato "dbd_mysql.conf" con:

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 

Ma ancora lo stesso problema (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 è in esecuzione e/o è la posizione corretta per il file socket? perché Apache sta provando ad usare il file socket, mentre la tua configurazione sta cercando di dirgli di usare una connessione TCP. –

+0

Il server Mysql è in esecuzione su un altro server. Non ho impostato alcun file socket .. – Joshua

+0

beh, Apache sta cercando di connettersi tramite il socket, quindi qualcosa nella tua configurazione è sbagliato. –

risposta

4

DBDParams devono essere separati da virgola: DBDParams param1=value1[,param2=value2] http://httpd.apache.org/docs/2.4/mod/mod_dbd.html

+0

Ho cambiato il ";" a "," 'DBDParams" DRIVER = {Driver MySQL ODBC 5.3}, SERVER = 192.168.1.2, DATABASE = MY_DATABASE, UID = MY_USER, PWD = MY_PASSWORD "', ancora lo stesso errore: 'Parametri DBD non validi - apri SQL_ERROR restituito (-1) ' – Joshua

+0

La mia risposta ti aiuterà con il tuo primo caso con' DBDriver mysql' Nel secondo caso sembra che dbd non riesca a trovare il driver ODBC con un nome specifico. –

+0

Grazie, funziona! configurazione: 'DBDriver mysql DBDParams "host = 192.168.1.2, user = mioutente, pass = MY_PASSWORD, dbname = MY_DATABASE" DBDMin 1 DBDKeep 1 DBDMax 10 DBDExptime 300 DBDPersist On' – Joshua

0

nel mio.conf cercano

[client] 
protocol=tcp 

Il riferimento Connecting to the MySQL Server fornisce una spiegazione di come ignorare la metodologia connessione predefinita.

Il riferimento Using Option Files spiega vagamente quali valori possono essere inseriti nel file my.conf. Essenzialmente un argomento che può essere passato al comando mysql sulla riga di comando (ad esempio --protocol) può essere specificato, senza i trattini, nel file di opzioni.