AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 732285
Accepted
TommyPeanuts
TommyPeanuts
Asked: 2015-10-29 08:07:43 +0800 CST2015-10-29 08:07:43 +0800 CST 2015-10-29 08:07:43 +0800 CST

Dovecot 不创建 /var/spool/postfix/private/auth

  • 772

我正在将 Ubuntu 14.04 postfix 邮件安装从一台机器移动到另一台机器。当前设置与 Ubuntu 的默认 postfix 和 dovecot 设置配合得很好,因此用户可以使用 SMTP auth 等。

因此,我将相关配置文件复制到新机器(也运行 Ubuntu 14.04)并在进行必要的 DNS 更改后在那里启动 postfix。

但是我在新机器的邮件日志中得到了这个:

10 月 28 日 14:18:50 lorina postfix/smtpd[13445]:警告:SASL:连接到私有/身份验证失败:没有这样的文件或目录

10 月 28 日 14:18:50 lorina postfix/smtpd[13445]:致命:没有 SASL 身份验证机制

10 月 28 日 14:18:51 lorina postfix/master[13440]:警告:进程 /usr/lib/postfix/smtpd pid 13445 退出状态 1

10 月 28 日 14:18:51 lorina postfix/master[13440]:警告:/usr/lib/postfix/smtpd:错误的命令启动 -- 节流

Postfix 设置为使用以下内容:

smtpd_sasl_type = dovecot
smtpd_sasl_path = 私有/授权

在 dovecot 配置中我有:

  # 后缀 smtp-auth
  unix_listener /var/spool/postfix/private/auth {
    模式 = 0666
  }

但是,我看到 /var/spool/postfix/private/auth 在新机器上不存在。

我已尝试重新启动机器,以防任何服务无法正常工作。这个文件什么时候制作?我怎样才能把它装箱?

postfix
  • 2 2 个回答
  • 8530 Views

2 个回答

  • Voted
  1. brokkr
    2015-10-30T05:07:07+08:002015-10-30T05:07:07+08:00

    要回答您的问题:

    • 套接字是通过运行 dovecot 来制作的。为 postfix 提供服务的是 dovecot,所以 dovecot 应该创建它。鸽舍一开始就应该做好。如果重新启动 dovecot 后没有套接字,请检查 dovecot 日志,而不是 postfix。
    • 你怎么能创造它?您肯定不应该手动创建它。

    我认为您的设置缺少一些设置(Postfix 和 Dovecot)并且依赖于默认设置。这可能已从一台机器更改为另一台机器。

    鸽棚

    我想说最大的问题是你没有告诉 dovecot 谁应该拥有套接字。它通常分配给后缀用户和组,如下所示:

    # Postfix smtp-auth
    unix_listener /var/spool/postfix/private/auth {
    mode = 0660
    user = postfix
    group = postfix
    }
    

    检查套接字父目录的所有权('private')它分配给什么用户和组?如果要在目录中写入,您需要 dovecot 使用相同的用户。

    后缀

    smtpd_sasl_path 设置与 queue_directory 设置相关。默认情况下 queue_directory 应该是 /var/spool/postfix 但让它显式化也没有什么坏处。

    queue_directory = /var/spool/postfix
    

    从日志中可以看出,您已经在 postfix 中启用了 sasl,尽管您的配置没有这么说。但是在什么代理上?如果您在 main.cf 中设置 smtpd_sasl_auth_enable=yes,它适用于所有代理,包括端口 25 上的 smtpd。我认为仅在 master.cf(在端口 587 上运行)中的提交代理上使用它被认为是更好的做法。如果您编辑现有的 master.cf,只需取消注释提交行和您需要的任何选项行。

    submission inet n        -       -       -       -       smtpd
    -o syslog_name=postfix/submission
    -o smtpd_sasl_auth_enable=yes
    
    • 2
  2. Best Answer
    TommyPeanuts
    2015-10-30T05:06:28+08:002015-10-30T05:06:28+08:00

    看起来报告的错误具有误导性。事实上,dovecot 没有找到 SSL 证书的路径,因此它没有正确启动,因此没有在 /var/spool/postfix/private/auth 中创建套接字。

    • 1

相关问题

  • Postfix 在特定端口上接受邮件

  • 让 Postfix 以两种方式处理垃圾邮件

  • Postfix 或 exim:自动/程序化和转发电子邮件设置

  • 后缀电子邮件地址

  • 什么是最好的开源电子邮件解决方案包

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve