Linux如何配置SMTP发邮件?

SMTP服务核心方案

方案1:配置本地SMTP服务器(以Postfix为例)

  1. 安装Postfix

    sudo apt update && sudo apt install postfix  # Debian/Ubuntu
    sudo yum install postfix                     # CentOS/RHEL

    安装时选择 Internet Site,根据提示设置域名(如 example.com)。

  2. 基础配置
    编辑主配置文件:

    sudo nano /etc/postfix/main.cf

    修改以下参数:

    myhostname = mail.example.com     # 服务器主机名
    mydomain = example.com            # 域名
    myorigin = $mydomain              # 发件人域名
    inet_interfaces = all             # 监听所有网络接口
    mydestination = $myhostname, localhost.$mydomain, $mydomain  # 接收域
  3. 启动服务

    sudo systemctl restart postfix
    sudo systemctl enable postfix
  4. 防火墙放行SMTP端口

    sudo ufw allow 25/tcp  # 标准SMTP端口

方案2:使用外部SMTP中继(如Gmail)

  1. 安装邮件客户端工具

    sudo apt install mailutils   # Debian/Ubuntu
    sudo yum install mailx       # CentOS/RHEL
  2. 配置Postfix使用Gmail SMTP
    编辑 /etc/postfix/main.cf,添加:

    relayhost = [smtp.gmail.com]:587
    smtp_sasl_auth_enable = yes
    smtp_sasl_password_maps = hash:/etc/postfix/sasl_passwd
    smtp_sasl_security_options = noanonymous
    smtp_tls_CAfile = /etc/ssl/certs/ca-certificates.crt
    smtp_use_tls = yes
  3. 创建认证文件

    sudo nano /etc/postfix/sasl_passwd
    [smtp.gmail.com]:587 your-email@gmail.com:app-password

    :使用Google两步验证的应用专用密码。

  4. 应用配置

    sudo postmap /etc/postfix/sasl_passwd
    sudo chmod 600 /etc/postfix/sasl_passwd*
    sudo systemctl restart postfix

验证SMTP功能

测试邮件发送

echo "Test email body" | mail -s "SMTP Test" recipient@example.com
  • 检查收件箱(包括垃圾邮件夹)。
  • 查看日志:
    tail -f /var/log/mail.log  # Debian/Ubuntu
    tail -f /var/log/maillog   # CentOS/RHEL

Telnet手动测试

telnet localhost 25

依次输入:

EHLO example.com
MAIL FROM: test@example.com
RCPT TO: recipient@example.com
DATA
Subject: Test
This is a test email.
.  # 英文句点结束
QUIT

安全加固措施

  1. 启用TLS加密
    /etc/postfix/main.cf 中增加:

    smtpd_tls_cert_file = /etc/ssl/certs/ssl-cert-snakeoil.pem
    smtpd_tls_key_file = /etc/ssl/private/ssl-cert-snakeoil.key
    smtpd_use_tls = yes
  2. 防止开放中继
    确保配置中不含:

    mynetworks = 127.0.0.0/8 [::1]/128  # 仅允许本地发送
  3. SPF/DKIM/DMARC配置

    • SPF:在DNS添加 v=spf1 mx ~all
    • DKIM:使用 opendkim 生成密钥并签名
    • DMARC:DNS记录 v=DMARC1; p=quarantine; rua=mailto:admin@example.com

常见问题解决

  • 邮件被拒收:检查域名反向解析(PTR记录)是否匹配主机名。
  • 端口25被屏蔽:联系云服务商解封,或改用端口587(提交端口)。
  • 认证失败
    • 确认SASL配置:sudo postconf -n | grep sasl
    • 检查日志:grep "SASL" /var/log/mail.log

替代方案

  • 轻量级工具
    • ssmtp:仅发送邮件的微型客户端。
    • msmtp:支持多账户的命令行SMTP客户端。
  • 容器化部署
    使用Docker运行Mailcow或Mailu集成套件。

引用说明

  • Postfix官方文档:http://www.postfix.org/documentation.html
  • Google SMTP使用指南:https://support.google.com/a/answer/176600
  • Let’s Encrypt证书申请:https://letsencrypt.org/docs/

重要提示:自建SMTP服务器需严格遵循反垃圾邮件规范(如RFC 5321),避免IP被列入黑名单,生产环境建议使用专业邮件服务(如SendGrid、Mailgun)或配置SPF/DKIM/DMARC三件套。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/4335.html

(0)
酷番叔酷番叔
上一篇 2025年6月13日 03:13
下一篇 2025年6月13日 04:04

相关推荐

  • 副业月入过万可能吗

    人工智能是模拟人类智能的技术系统;应用于医疗、交通、制造等领域;正深刻改变人类生活和工作方式。

    2025年7月5日
    1000
  • 如何快速设置IP和子网掩码?

    在Linux系统中设置IP地址是网络管理的基础操作,可通过命令行或配置文件实现,以下是详细方法,适用于主流发行版(如Ubuntu、CentOS):临时设置IP地址(重启失效)方法1:使用 ip 命令(推荐)# 设置默认网关sudo ip route add default via 192.168.1.1# 重启……

    2025年6月28日
    900
  • wget如何让下载更简单可靠?

    在Linux系统中下载文件是日常操作,无论是管理服务器、开发软件还是处理数据都离不开它,Linux提供了多种高效、灵活的命令行工具,每种工具都有其适用场景,以下详细介绍最常用的方法,涵盖基础操作到高级技巧,确保安全性和效率,wget 是Linux最常用的下载工具,支持HTTP、HTTPS和FTP协议,具备断点续……

    5天前
    700
  • Linux如何正确退出程序?

    终端中运行的前台程序正常退出(推荐)多数程序内置退出命令:输入 q 或 quit 后按回车(如nano编辑器),按 Ctrl + D(发送EOF信号,适用于Python交互模式等),通用快捷键:Ctrl + C:强制终止当前命令(适用于无退出命令的程序,如ping),强制终止无响应程序按 Ctrl + Z 暂停……

    6天前
    1200
  • Linux如何用wget/curl高效下载文件?

    基础下载工具wget – 全能下载器安装(若未预装):# Debian/Ubuntusudo apt install wget# CentOS/RHELsudo yum install wget基础用法:wget https://example.com/file.zip # 下载文件到当前目录wget -O c……

    2025年7月12日
    1000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信