Problem mit Courier und MySQL (failed connection)

Postfix, QMail, Sendmail, Dovecot, Cyrus, Courier, Anti-Spam
chaoskind
Posts: 80
Joined: 2003-05-20 10:47

Problem mit Courier und MySQL (failed connection)

Post by chaoskind » 2005-11-10 12:05

Problem ist, mein Courier will sich nicht am MySQL Server einlogen, sitze hier schon seit fast 3 stunden daran und probier alles mögliche,google hat mich leider nicht weiter gebracht, die suche vom forum auch nicht): ich bin am verzweifeln

folgende Config :
courier + exim4 + spamassassin + clamav nach debianhowto.de
MySQL 5.0.15 aus den quellen compiliert
PHP etc is egal, da nur Courier noch probleme macht,alles andere scheint zu laufen, maildelivery etc.

Folgende Fehlermeldung krieg ich im mail.err (Debuglevel auf 2 bereits):

Code: Select all

Nov 10 12:01:15 h692799 authdaemond.mysql: failed to connect to mysql server (server=localhost, userid=couriervexim)
Nov 10 12:01:20 h692799 courierpop3login: LOGIN FAILED, ip=[::ffff:84.133.208.151]
und im mail.log:

Code: Select all

Nov 10 12:00:39 h692799 authdaemond.mysql: modules="authmysql", daemons=5
Nov 10 12:01:15 h692799 courierpop3login: Connection, ip=[::ffff:84.133.208.151]
Nov 10 12:01:15 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], command=USER
Nov 10 12:01:15 h692799 authdaemond.mysql: failed to connect to mysql server (server=localhost, userid=couriervexim)
Nov 10 12:01:15 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], command=PASS
Nov 10 12:01:15 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], username=xxxxxxxxx@xxxxxxxx.de
Nov 10 12:01:15 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], password=xxxxxxx
Nov 10 12:01:15 h692799 courierpop3login: authdaemon: starting client module
Nov 10 12:01:15 h692799 courierpop3login: authdaemon: TEMPFAIL - no more modules will be tried
Nov 10 12:01:20 h692799 courierpop3login: LOGIN FAILED, ip=[::ffff:84.133.208.151]
Nov 10 12:06:25 h692799 courierpop3login: Connection, ip=[::ffff:84.133.208.151]
Nov 10 12:06:25 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], command=USER
Nov 10 12:06:25 h692799 authdaemond.mysql: failed to connect to mysql server (server=localhost, userid=couriervexim)
Nov 10 12:06:25 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], command=PASS
Nov 10 12:06:25 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], username=xxxxx@xxxxxxxxx.de
Nov 10 12:06:25 h692799 courierpop3login: LOGIN: DEBUG: ip=[::ffff:84.133.208.151], password=xxxxxxxxx
Nov 10 12:06:25 h692799 courierpop3login: authdaemon: starting client module
Nov 10 12:06:25 h692799 courierpop3login: authdaemon: TEMPFAIL - no more modules will be tried
Nov 10 12:06:31 h692799 courierpop3login: LOGIN FAILED, ip=[::ffff:84.133.208.151]

probiert hat ich es schon mit mysql root user + pw, mit dem original vexim user (wobei der n kryptisches passwort mit sonderzeichen hat...)
und dann mit couriervexim der gleiche rechte hat etc, aber kein cryptisches passwort hat

meine authmysqlrc:

Code: Select all

##VERSION: $Id: authmysqlrc,v 1.17 2004/04/20 01:38:17 mrsam Exp $
#
# Copyright 2000-2004 Double Precision, Inc.  See COPYING for
# distribution information.
#
# Do not alter lines that begin with ##, they are used when upgrading
# this configuration.
#
# authmysqlrc created from authmysqlrc.dist by sysconftool
#
# DO NOT INSTALL THIS FILE with world read permissions.  This file
# might contain the MySQL admin password!
#
# Each line in this file must follow the following format:
#
# field[spaces|tabs]value
#
# That is, the name of the field, followed by spaces or tabs, followed by
# field value.  Trailing spaces are prohibited.


##NAME: LOCATION:0
#
# The server name, userid, and password used to log in.

MYSQL_SERVER            localhost
MYSQL_USERNAME          couriervexim
MYSQL_PASSWORD          xxxxxxxxxxxxx

##NAME: MYSQL_SOCKET:0
#
# MYSQL_SOCKET can be used with MySQL version 3.22 or later, it specifies the
# filesystem pipe used for the connection
#
MYSQL_SOCKET            /tmp/mysqld.sock

##NAME: MYSQL_PORT:0
#
# MYSQL_PORT can be used with MySQL version 3.22 or later to specify a port to
# connect to.

MYSQL_PORT      0

##NAME: MYSQL_OPT:0
#
# Leave MYSQL_OPT as 0, unless you know what you're doing.

MYSQL_OPT               0

##NAME: MYSQL_DATABASE:0
#
# The name of the MySQL database we will open:

#MYSQL_DATABASE         vexim
MYSQL_DATABASE          vexim

##NAME: MYSQL_USER_TABLE:0
#
# The name of the table containing your user data.  See README.authmysqlrc
# for the required fields in this table.

MYSQL_USER_TABLE        users

#MYSQL_USER_TABLE       users

##NAME: MYSQL_CRYPT_PWFIELD:0
#
# Either MYSQL_CRYPT_PWFIELD or MYSQL_CLEAR_PWFIELD must be defined.  Both
# are OK too. crypted passwords go into MYSQL_CRYPT_PWFIELD, cleartext
# passwords go into MYSQL_CLEAR_PWFIELD.  Cleartext passwords allow
# CRAM-MD5 authentication to be implemented.

MYSQL_CRYPT_PWFIELD     crypt

##NAME: MYSQL_CLEAR_PWFIELD:0
#
#
MYSQL_CLEAR_PWFIELD     clear

##NAME: MYSQL_DEFAULT_DOMAIN:0
#
# If DEFAULT_DOMAIN is defined, and someone tries to log in as 'user',
# we will look up 'user@DEFAULT_DOMAIN' instead.
#
#
# DEFAULT_DOMAIN                example.com

##NAME: MYSQL_UID_FIELD:0
#
# Other fields in the mysql table:
#
# MYSQL_UID_FIELD - contains the numerical userid of the account
#
MYSQL_UID_FIELD         uid

##NAME: MYSQL_GID_FIELD:0
#
# Numerical groupid of the account

MYSQL_GID_FIELD         gid

##NAME: MYSQL_LOGIN_FIELD:0
#
# The login id, default is id.  Basically the query is:
#
#  SELECT MYSQL_UID_FIELD, MYSQL_GID_FIELD, ... WHERE id='loginid'
#

MYSQL_LOGIN_FIELD       username

##NAME: MYSQL_HOME_FIELD:0
#

MYSQL_HOME_FIELD        pop

##NAME: MYSQL_NAME_FIELD:0
#
# The user's name (optional)

MYSQL_NAME_FIELD        realname

##NAME: MYSQL_MAILDIR_FIELD:0
#
# This is an optional field, and can be used to specify an arbitrary
# location of the maildir for the account, which normally defaults to
# $HOME/Maildir (where $HOME is read from MYSQL_HOME_FIELD).
#
# You still need to provide a MYSQL_HOME_FIELD, even if you uncomment this
# out.
#
# MYSQL_MAILDIR_FIELD   maildir

##NAME: MYSQL_DEFAULTDELIVERY:0
#
# Courier mail server only: optional field specifies custom mail delivery
# instructions for this account (if defined) -- essentially overrides
# DEFAULTDELIVERY from ${sysconfdir}/courierd
#
# MYSQL_DEFAULTDELIVERY defaultdelivery

##NAME: MYSQL_QUOTA_FIELD:0
#
# Define MYSQL_QUOTA_FIELD to be the name of the field that can optionally
# specify a maildir quota.  See README.maildirquota for more information
#
# MYSQL_QUOTA_FIELD     quota

##NAME: MYSQL_AUXOPTIONS:0
#
# Auxiliary options.  The MYSQL_AUXOPTIONS field should be a char field that
# contains a single string consisting of comma-separated "ATTRIBUTE=NAME"
# pairs.  These names are additional attributes that define various per-account
# "options", as given in INSTALL's description of the "Account OPTIONS"
# setting.
#
# MYSQL_AUXOPTIONS_FIELD        auxoptions
#
# You might want to try something like this, if you'd like to use a bunch
# of individual fields, instead of a single text blob:
#
# MYSQL_AUXOPTIONS_FIELD        CONCAT("disableimap=",disableimap,",disablepop3=",disablepop3,",disablewebmail=",disablewebmail,",sharedgroup=",sharedgroup)
#
# This will let you define fields called "disableimap", etc, with the end result
# being something that the OPTIONS parser understands.


##NAME: MYSQL_WHERE_CLAUSE:0
#
# This is optional, MYSQL_WHERE_CLAUSE can be basically set to an arbitrary
# fixed string that is appended to the WHERE clause of our query
#
# MYSQL_WHERE_CLAUSE    server='mailhost.example.com'

##NAME: MYSQL_SELECT_CLAUSE:0
#
# (EXPERIMENTAL)
# This is optional, MYSQL_SELECT_CLAUSE can be set when you have a database,
# which is structuraly different from proposed. The fixed string will
# be used to do a SELECT operation on database, which should return fields
# in order specified bellow:
#
# username, cryptpw, clearpw, uid, gid, home, maildir, quota, fullname, options
#
# The username field should include the domain (see example below).
#
# Enabling this option causes ignorance of any other field-related
# options, excluding default domain.
#
# There are two variables, which you can use. Substitution will be made
# for them, so you can put entered username (local part) and domain name
# in the right place of your query. These variables are:
#               $(local_part), $(domain), $(service)
#
# If a $(domain) is empty (not given by the remote user) the default domain
# name is used in its place.
#
# $(service) will expand out to the service being authenticated: imap, imaps,
# pop3 or pop3s.  Courier mail server only: service will also expand out to
# "courier", when searching for local mail account's location.  In this case,
# if the "maildir" field is not empty it will be used in place of
# DEFAULTDELIVERY.  Courier mail server will also use esmtp when doing
# authenticated ESMTP.
#
# This example is a little bit modified adaptation of vmail-sql
# database scheme:
#
# MYSQL_SELECT_CLAUSE   SELECT CONCAT(popbox.local_part, '@', popbox.domain_name),                      
#                       CONCAT('{MD5}', popbox.password_hash),          
#                       popbox.clearpw,                                 
#                       domain.uid,                                     
#                       domain.gid,                                     
#                       CONCAT(domain.path, '/', popbox.mbox_name),     
#                       '',                                             
#                       domain.quota,                                   
#                       '',                                             
#                       CONCAT("disableimap=",disableimap,",disablepop3=",    
#                              disablepop3,",disablewebmail=",disablewebmail, 
#                              ",sharedgroup=",sharedgroup)             
#                       FROM popbox, domain                             
#                       WHERE popbox.local_part = '$(local_part)'       
#                       AND popbox.domain_name = '$(domain)'            
#                       AND popbox.domain_name = domain.domain_name


##NAME: MYSQL_ENUMERATE_CLAUSE:0
#
# {EXPERIMENTAL}
# Optional custom SQL query used to enumerate accounts for authenumerate,
# in order to compile a list of accounts for shared folders.  The query
# should return the following fields: name, uid, gid, homedir, maildir
#
# Example:
# MYSQL_ENUMERATE_CLAUSE        SELECT CONCAT(popbox.local_part, '@', popbox.domain_name),                      
#                       domain.uid,                                     
#                       domain.gid,                                     
#                       CONCAT(domain.path, '/', popbox.mbox_name),     
#                       ''                                              
#                       FROM popbox, domain                             
#                       WHERE popbox.local_part = '$(local_part)'       
#                       AND popbox.domain_name = '$(domain)'            
#                       AND popbox.domain_name = domain.domain_name



##NAME: MYSQL_CHPASS_CLAUSE:0
#
# (EXPERIMENTAL)
# This is optional, MYSQL_CHPASS_CLAUSE can be set when you have a database,
# which is structuraly different from proposed. The fixed string will
# be used to do an UPDATE operation on database. In other words, it is
# used, when changing password.
#
# There are four variables, which you can use. Substitution will be made
# for them, so you can put entered username (local part) and domain name
# in the right place of your query. There variables are:
#       $(local_part) , $(domain) , $(newpass) , $(newpass_crypt)
#
# If a $(domain) is empty (not given by the remote user) the default domain
# name is used in its place.
# $(newpass) contains plain password
# $(newpass_crypt) contains its crypted form
#
# MYSQL_CHPASS_CLAUSE   UPDATE  popbox                                  
#                       SET     clearpw='$(newpass)',                   
#                               password_hash='$(newpass_crypt)'        
#                       WHERE   local_part='$(local_part)'              
#                       AND     domain_name='$(domain)'
#
hab alles durchgeschaut damit keine leerstellen mit drinstehen , es war nirgends eine leerstelle zuviel

braucht ihr sonst noch infos, dann sagts und ich post es


soo hab noch aus m mysql log rausgefischt :

Code: Select all

Client does not support authentication protocol requested by server; consider upgrading MySQL client

User avatar
Joe User
Project Manager
Project Manager
Posts: 11583
Joined: 2003-02-27 01:00
Location: Hamburg

Re: Problem mit Courier und MySQL (failed connection)

Post by Joe User » 2005-11-10 14:58

Hast Du Courier-[IMAP|Authlib] rekompiliert? Falls nicht -> Nachholen.
PayPal.Me/JoeUserFreeBSD Remote Installation
Wings for LifeWings for Life World Run

„If there’s more than one possible outcome of a job or task, and one
of those outcomes will result in disaster or an undesirable consequence,
then somebody will do it that way.“ -- Edward Aloysius Murphy Jr.

chaoskind
Posts: 80
Joined: 2003-05-20 10:47

Re: Problem mit Courier und MySQL (failed connection)

Post by chaoskind » 2005-11-12 14:59

mittlerweile hab ich das problem durchzufall lösen können,

MySQL auf "old-passwords" und dann von dem benutzer für courier (extra angelegt) einfach auf "old password" bei passwort gesetzt und sein passwort neu eingegeben und schwupp gings