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 / 问题 / 898804
Accepted
TitanFighter
TitanFighter
Asked: 2018-02-26 10:57:44 +0800 CST2018-02-26 10:57:44 +0800 CST 2018-02-26 10:57:44 +0800 CST

如何为 2 台服务器正确配置 DNS:一台用于 Web,另一台用于邮件?

  • 772

对于我使用的电子邮件服务器iredmail。我有具有以下设置的电子邮件服务器:

# /etc/hostname
mail

# /etc/hosts
127.0.1.1 mail.mydomain.com mail
127.0.0.1 localhost

所以 FQDN 是mail.mydomain.com.

在这里我找到了我使用的示例,但是通过这些示例,我的服务器可以发送电子邮件,但无法接收:

Type     Name                Value                                  TTL
A         @                  195.201.40.1                           1 hour  # Web server
A         mail               195.201.40.2                           1 hour  # Mail server
MX        @                  mail.mydomain.com (Priority: 10)       1 hour
TXT       @                  v=spf1 ip4:195.201.40.2 -all           1 hour
TXT       @                  v=DMARC1; p=reject; sp=reject;...      1 hour
TXT       _adsp._domainkey   dkim=all
TXT       dkim._domainkey    v=DKIM1; k=rsa; p=MIGfMA0GCSq...

然后我改变了:

MX        @   mail.mydomain.com (Priority: 10)  1 hour

至

MX        mail    mail.mydomain.com (Priority: 10)  1 hour

并且邮件服务器开始接收电子邮件。

我有两个问题:

1)据我了解,外部电子邮件服务(例如 gmail)将邮件发送到mydomain.com,而不是mail.mydomain.com,因为我的电子邮件地址看起来像[email protected]而不像[email protected]。为什么要更改@以mail解决接收电子邮件的问题?

我将记录理解MX @ mail.mydomain.com为:“外部电子邮件服务,如果您向 [email protected] (@ = mydomain.com) 发送电子邮件,则使用 FQDN mail.mydomain.com 向服务器发送电子邮件”,但我的逻辑似乎没有工作。为什么?

在这里我们可以看到主机名可以@使用不同的 FQDN。为什么在我的情况下它不起作用?

2) 对于 TXT 记录,我应该提供什么名称?@或者mail,即域名或主机名?如果mail,是否意味着如果我有 10 台邮件服务器,我需要为所有这些服务器创建自己的 TXT 记录?

domain-name-system
  • 2 2 个回答
  • 115 Views

2 个回答

  • Voted
  1. Elvis Plesky
    2018-02-26T12:56:17+08:002018-02-26T12:56:17+08:00

    1) 邮件将被发送到 MX 记录中为电子邮件地址的主机名部分指定的主机名。例如,当邮件发送到某人@gmail.com 时,会发生以下情况:

    为 gmail.com 获取配置的 MX 记录之一:

    # dig mx gmail.com +short | head -n 1
    5 gmail-smtp-in.l.google.com.
    

    邮件投递到对应邮件服务器的IP地址:

    # dig gmail-smtp-in.l.google.com +short
    173.194.221.27
    

    在您的情况下,由于初始配置看起来不错,因此尚不清楚问题是如何解决的。尝试使用公共 DNS 检查哪个 MX 服务器负责您的域名以及它引用的 IP 地址:

    # dig mx mydomain.com @8.8.8.8 +short
    mail.mydomain.com
    # dig mail.mydomain.com @8.8.8.8 +short
    

    mail.2) SPF 记录应提供域名(不包括部分)。对于 DKIM 和 DMARC,还应在域名中添加前缀(不带mail.部分),例如:

    TXT       _dmarc             v=DMARC1; p=reject; sp=reject;...
    TXT       dkim._domainkey    v=DKIM1; k=rsa; p=MIGfMA0GCSq...
    
    • 1
  2. Best Answer
    BillThor
    2018-02-26T16:56:55+08:002018-02-26T16:56:55+08:00

    我已将您的 DNS 记录翻译成绑定格式。除非您要更改条目,否则您不需要为条目指定 TTL。

    我已将 SPF 记录转换为最简单的形式。A记录规则mail用于 SPF-helo检查。的规则www指示不应从www子域发送电子邮件。

    您的域,子域的条目如下。(注意 MX 记录末尾的点。如果丢失,您应该使用mail)。

     @       IN  A    195.201.40.1
             IN  MX   mail.mydomain.com.
             IN  TXT  "v=spf1 mx -all"
    

    标准服务邮件和 www(即使条目中未提供 www,某些浏览器也会尝试使用 www)。

     mail    IN  A    195.201.40.2 
             IN  TXT  "v=spf1 a -all"
     www     IN  A    195.201.40.1 
             IN  TXT  "v=spf1 -all"
    

    带有报告的 DMARC 配置。在报告表明您没有问题之前,我不会使用reject策略。您可能希望从none您的政策开始。

     _dmarc  IN  TXT  "v=DMARC1; p=reject; sp=reject;..."
     *._report.dmarc  IN TXT "v=DMARC1"
    

    DKIM 的配置。_adsp似乎不再在标准轨道上。替换dkim为您在签名时使用的密钥名称。

     _adsp._domainkey IN  TXT dkim=all
     dkim._domainkey  IN  TXT  v=DKIM1; k=rsa; p=MIGfMA0GCSq...
    
    • 1

相关问题

  • Solaris DNS

  • resolv.conf 在经过一段时间后被更改

  • 为什么有些网站的网址中没有“www”就无法显示?[关闭]

  • 为本地网络中的名称解析添加自定义 dns 条目

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