Dovecot: Операция запрещена

Я использую веб-панель centos6 и centos, postfix. Я могу отправлять сообщения и входить в систему Roundcube. Но я не могу получать сообщения. Журнал Dovecot:

9 сентября, 13:52:31 lda ( test@domain.su ): Неустранимый : ошибка setuid (101) с euid = 5000 (vmail): операция не разрешена (этот двоичный файл, вероятно, должен вызывается с пользователем процесса, установленным на 101 вместо 5000 (vmail)), пожалуйста посоветуйте мне эти настройки:

  • first_valid_uid
  • last_valid_uid
  • first_valid_gid
  • last_valid_gid

И какие разрешения у меня должны быть для dovecot-lda

##
## Dovecot config file
##
listen = *
disable_plaintext_auth = no

protocols = imap pop3 lmtp sieve
auth_mechanisms = plain login

passdb {
    driver = sql
    args = /etc/dovecot/dovecot-mysql.conf
}

#userdb {
#driver = prefetch
#}

userdb {
    driver = sql
    args = /etc/dovecot/dovecot-mysql.conf
}

mail_location = maildir:/var/vmail/%d/%n
first_valid_uid = 101
#last_valid_uid = 5000
first_valid_gid = 0
#last_valid_gid = 12
mail_plugins = quota
mailbox_idle_check_interval = 30 secs
maildir_copy_with_hardlinks = yes

service imap-login {
    inet_listener imap {
        port = 143
    }
    inet_listener imaps {
        port = 993
        ssl = yes
    }
}

service pop3-login {
    inet_listener pop3 {
        port = 110
    }
    inet_listener pop3s {
        port = 995
        ssl = yes
    }
}

service lmtp {
    unix_listener lmtp {
        #mode = 0666
    }
}

service imap {
    vsz_limit = 256M
}

service pop3 {
}

service auth {
    unix_listener auth-userdb {
        mode = 0666
        user = vmail
        group = mail
    }

    # Postfix smtp-auth
    unix_listener /var/spool/postfix/private/auth {
        mode = 0666
        user = postfix
        group = postfix
    }
}
service auth-worker {
}
service dict {
    unix_listener dict {
        mode = 0666
        user = vmail
        group = mail
    }
}
service managesieve-login {
    inet_listener sieve {
        port = 4190
    }
    service_count = 1
    process_min_avail = 0
    vsz_limit = 64M
}

service managesieve {
}

ssl = yes
ssl_cert = </etc/pki/tls/certs/gog.uk.to.crt
ssl_key = </etc/pki/tls/private/gog.uk.to.key
ssl_verify_client_cert = no
ssl_ca =

lda_mailbox_autocreate = yes
lda_mailbox_autosubscribe = yes
protocol lda {
    #mail_plugins = sieve
    mail_plugins = quota sieve
    postmaster_address = postmaster@your-domain.tld
}

protocol imap {
    mail_plugins = quota imap_quota trash
    #mail_plugins = trash
    imap_client_workarounds = delay-newmail
}

lmtp_save_to_detail_mailbox = yes

protocol lmtp {
    mail_plugins = quota sieve
    #mail_plugins = sieve
}

protocol pop3 {
    mail_plugins = quota
    #mail_plugins =
    pop3_client_workarounds = outlook-no-nuls oe-ns-eoh
}

protocol sieve {
    managesieve_max_line_length = 65536
    managesieve_implementation_string = Dovecot Pigeonhole
    managesieve_max_compile_errors = 5
}

dict {
    quotadict = mysql:/etc/dovecot/dovecot-dict-quota.conf
}

plugin {
    quota = dict:user::proxy::quotadict
    acl = vfile:/etc/dovecot/acls
    trash = /etc/dovecot/trash.conf
    sieve_global_path = /var/sieve/globalfilter.sieve
    sieve = ~/dovecot.sieve
    sieve_dir = ~/sieve
    sieve_global_dir = /var/sieve/
    #sieve_extensions = +notify +imapflags
    sieve_max_script_size = 1M
    #sieve_max_actions = 32
    #sieve_max_redirects = 4
}

log_path = /var/log/dovecot.log
info_log_path = /var/log/dovecot-info.log
debug_log_path = /var/log/dovecot-debug.log
mail_debug=no
-1
задан 10 September 2018 в 19:43
2 ответа

Я полагаю, вы столкнулись с той же проблемой, что и я:

Несколько UID
Если вы используете более одного UID для пользователей, у вас могут возникнуть проблемы с запуском dovecot-lda, поскольку большинство MTA не позволяют запускать dovecot-lda от имени пользователя root. Лучшее решение - использовать вместо этого LMTP, но если вы не можете этого сделать, есть два способа обойти эту проблему:

  1. Сделайте dovecot-lda setuid-root.
  2. Используйте sudo, чтобы обернуть вызов dovecot- lda.

Источник: https://wiki2.dovecot.org/LDA#line-100

Вот что я делаю после каждого обновления пакета dovecot:

sudo chgrp dovenull /usr/lib/dovecot/deliver
sudo chmod 04750 /usr/lib/dovecot/dovecot-lda
# optional: run postqueue to deliver queued mails immediately
postqueue -f

Я использую Ubuntu хотя, поэтому вам, скорее всего, придется использовать другую группу. У меня нет под рукой установки CentOS, чтобы ее найти.

0
ответ дан 5 December 2019 в 20:20

Для полноты картины похожие проблемы также возникают с несколькими GID (возможно, что приводит к чему-то вроде "Fatal: setresgid ...: Операция не разрешена"):

Если вам нужно несколько uid/gid, вам нужно установить dovecot-lda setuid root или вызвать его через sudo. См. LDA#multipleuids, чтобы узнать, как это сделать. это надежно.

источник: https://wiki2.dovecot.org/LDA/Postfix

Или используйте вместо этого LMTP, как указано в другом ответе.

1
ответ дан 14 April 2021 в 17:32

Теги

Похожие вопросы