如何轻松掌握bash提升工作效率?

在Linux系统中开启SMTP服务器是搭建邮件服务的关键步骤,常用于网站通知、事务邮件等场景,以下是基于Postfix(Linux最常用的邮件传输代理)的详细操作流程,兼顾安全性与易用性,所有命令需以root权限执行。
sudo apt update && sudo apt upgrade # Debian/Ubuntu
sudo yum update # CentOS/RHEL

**检查主机名**  
   确保主机名解析正确(邮件服务依赖域名):
   ```bash
   hostname -f  # 输出应为完整域名(如 mail.example.com)

若未设置,编辑/etc/hostname/etc/hosts文件。


安装与配置Postfix

安装Postfix

sudo apt install postfix mailutils  # Debian/Ubuntu
sudo yum install postfix cyrus-sasl-plain  # CentOS/RHEL

安装过程中选择 “Internet Site”,并输入邮件域名(如 example.com)。

基础配置

编辑主配置文件:

sudo nano /etc/postfix/main.cf

修改以下参数:

myhostname = mail.example.com     # 服务器完整域名
mydomain = example.com            # 邮件域名
myorigin = $mydomain              # 外发邮件域名
inet_interfaces = all             # 监听所有网络接口
mydestination = $myhostname, localhost.$mydomain, localhost, $mydomain
relayhost =                       # 留空(直接发送邮件)

启动服务

sudo systemctl restart postfix
sudo systemctl enable postfix

测试SMTP服务

本地发送测试邮件

echo "Test email body" | mail -s "SMTP Test" your-email@example.com

检查邮件是否送达(查看收件箱或垃圾箱)。

使用Telnet手动测试

telnet localhost 25

依次输入(替换your-email@example.com):

EHLO localhost
MAIL FROM: test@example.com
RCPT TO: your-email@example.com
DATA
Subject: Telnet Test
This is a manual SMTP test.
.  # 单独一行输入英文句点结束
QUIT

安全加固(必做步骤)

防火墙放行SMTP

sudo ufw allow 25/tcp  # 开放SMTP端口
sudo ufw allow 587/tcp # 提交端口(TLS加密)

启用SASL认证(防未授权转发)

安装SASL工具:

sudo apt install libsasl2-modules   # Debian/Ubuntu
sudo yum install cyrus-sasl-plain   # CentOS/RHEL

编辑SASL配置:

sudo nano /etc/postfix/sasl/smtpd.conf

添加:

pwcheck_method: auxprop
auxprop_plugin: sasldb
mech_list: PLAIN LOGIN

创建认证用户:

sudo saslpasswd2 -c -u `postconf -h mydomain` username  # 按提示设置密码
sudo chown postfix /etc/sasldb2      # 授权Postfix访问

main.cf中启用认证:

smtpd_sasl_auth_enable = yes
smtpd_sasl_security_options = noanonymous
smtpd_relay_restrictions = permit_sasl_authenticated, reject_unauth_destination

配置TLS加密(Let’s Encrypt证书示例)

安装Certbot:

sudo apt install certbot   # Debian/Ubuntu
sudo yum install certbot   # CentOS/RHEL

申请证书:

sudo certbot certonly --standalone -d mail.example.com

main.cf中启用TLS:

smtpd_use_tls = yes
smtpd_tls_cert_file = /etc/letsencrypt/live/mail.example.com/fullchain.pem
smtpd_tls_key_file = /etc/letsencrypt/live/mail.example.com/privkey.pem

常见问题解决

  • 邮件被拒收
    检查域名SPF/DKIM记录(需在DNS添加TXT记录),使用工具如dig TXT example.com验证。
  • 端口25被屏蔽
    联系云服务商解封(如AWS、阿里云需提交工单)。
  • SASL认证失败
    检查/var/log/mail.log日志,确认sasldb2文件权限为640
  • 高延迟发送
    main.cf添加disable_dns_lookups = yes(关闭反向DNS验证)。

维护建议

  1. 日志监控
    tail -f /var/log/mail.log  # 实时查看邮件日志
  2. 定期更新
    sudo apt upgrade postfix    # Debian/Ubuntu
    sudo yum update postfix     # CentOS/RHEL
  3. 备份配置
    备份/etc/postfix目录,避免配置丢失。

引用说明

  • Postfix官方文档:http://www.postfix.org/documentation.html
  • Let’s Encrypt证书指南:https://certbot.eff.org/instructions
  • SASL配置参考:Cyrus SASL Library Documentation
  • 安全实践依据:RFC 3207 (SMTP over TLS), RFC 4954 (SMTP Authentication)
    本文基于Ubuntu 22.04/CentOS 7实测,适用于主流Linux发行版。

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

(0)
酷番叔酷番叔
上一篇 8小时前
下一篇 8小时前

相关推荐

  • 少了这一步安装准出错?

    选择Linux发行版新手推荐:Ubuntu(用户友好)、Linux Mint(类Windows界面)、Zorin OS(无缝过渡)中阶用户:Fedora(前沿技术)、Debian(稳定性优先)权威数据参考:根据DistroWatch近一年排名,Ubuntu、Mint、Debian为最受欢迎发行版前三(2023数……

    2025年7月13日
    1400
  • Linux如何查看tmp目录内容

    查看Linux的/tmp目录内容,基础方法是使用ls -l /tmp命令列出文件,高级技巧包括利用find命令按条件搜索文件、结合grep过滤结果,或使用inotifywait实时监控目录变化。

    2天前
    400
  • Ubuntu升级24.04卡住?速解方案

    在Linux系统中,使用telnet测试服务器端口连通性是网络故障排查的常用手段,以下为详细操作指南,所有步骤均基于主流Linux发行版(如Ubuntu、CentOS)验证,确保专业性和可靠性:Telnet的作用与原理功能:telnet是TCP/IP协议族中的终端仿真协议,通过建立TCP连接测试目标服务器的端口……

    2025年7月1日
    1700
  • Windows装Linux双系统会冲突吗?

    准备工作(关键步骤)数据备份使用外部硬盘或云存储备份 Windows 的重要数据(文档/照片/系统镜像),创建 Windows 恢复驱动器(控制面板 → 恢复 → 创建恢复驱动器),选择 Linux 发行版新手推荐:Ubuntu 22.04 LTS(长期支持版)或 Linux Mint官网下载 ISO 文件(示……

    2025年7月21日
    900
  • 如何将进程名设为my-service?

    将进程名称修改为”my-service”通常通过修改程序启动命令或配置文件实现,便于在系统进程列表(如ps/top)中清晰识别和管理该特定服务进程。

    2025年7月1日
    1600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信