CentOS7.2部署邮件服务器(sendmail)

本文涉及的产品
云解析DNS,个人版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: CentOS7.2部署邮件服务器(sendmail)

实验要求:为了能够实际部署一个的电子邮件系统,需要使用到下面的软件:1)Sendmail:实现邮件的接收和中转,即SMTP;2)Dovecot:实现邮件的收取,即POP3和IMAP;3)Foxmail:客户端收发邮件的工具。硬件上需要两台主机:一台Linux主机,同时安装邮件服务器软件Sendmail、Dovecot和DNS服务器软件bind;一台Windows 7主机(192.168.100.12)作为电子邮件用户端,安装软件Foxmail。
注意事项:此次仅作为实验进行参考,所以关闭SELinux和firewalld,使得步骤更加精简
由于此次实验为最小化的centos,所以并无某些服务组件,提前在此处提出,并安装

#yum -y install vim net-tools telnet

安装并开启sendmail和Dovecot服务

1、安装sendmail服务以及相关组件

yum -y install sendmail* m4

在这里插入图片描述

postfix的产生是为了替代传统的sendmail.相较于sendmail,postfix在速度。性能和稳定性上都更胜一筹,由于linux中自带了postfix,为了postfix和sendmail两者间不产生冲突,需要切换MTA(mail transter agent,即邮件传输代理),禁用postfix,执行如下命令

alternatives --config mta //请按 2

显示内容如下
There are 2 programs which provide 'mta'. //共有 2 个提供“mta”的程序。

  Selection    Command
   1           /usr/sbin/sendmail.postfix
*+ 2           /usr/sbin/sendmail.sendmail

在这里插入图片描述

开启sendmail服务,设置开机自启,并禁用postfix服务

systemctl start sendmail

systemctl enable sendmail

systemctl mask postfix

在这里插入图片描述

2、安装dovecot服务,启动,并设置开机自启

yum -y install dovecot

systemctl start dovecot

systemctl enable dovecot


在这里插入图片描述

配置SMTP邮件服务器Sendmail

实验要求:在部署一台Sendmail服务器,为公司网络内部的客户端计算机提供邮件收发服务,具体参数要求如下:DNS域名为fl.com;DNS服务器IP地址为192.168.100.252;Sendmail服务器IP地址为192.168.100.20;Sendmail服务器MX记录为mail.cqcetli.net;公司网络为192.168.100.0/24;能够给公司全体员工群发邮件。

设置邮件服务器IP(本机ip:192.168.100.20)以及,DNS服务器IP 192.168.100.21
添加DNS服务器IP地址:
先安装net-tools

yum -y install net-tools

ifconfig eth0:1 192.168.100.21/24

在这里插入图片描述

安装DNS服务器

yum -y install bind*

编辑DNS服务器配置文件

vi /etc/named.conf

listen-on port 53 { 192.168.100.21; };
allow-query { any; };
在这里插入图片描述

编辑DNS正向解析文件

vi /etc/named.rfc1912.zones

在末尾添加
zone "fl.com" IN { //域自定义

    type master;
    file "fl.com.zone";//域解析文件名自定义,需要和后面的解析文件相对应
    allow-update { none; };

};

cd /var/named

cp -p named.localhost fl.com.zone

vi fl.com.zone //格式请以截图为准,由于排版模式,以下代码排版出现问题

$TTL 1D
@ IN SOA dns.fl.com. root.fl.com. (

                                    0       ; serial
                                    1D      ; refresh
                                    1H      ; retry
                                    1W      ; expire
                                    3H )    ; minimum

@ IN NS dns.fl.com.
dns IN A 192.168.100.21
mail IN A 192.168.100.20
@ IN MX 10 mail.fl.com.
在这里插入图片描述

重启DNS服务器

在这里插入图片描述

编辑DNS文件

vi /etc/resolv.conf

添加如下内容:
nameserver 192.168.100.21
在这里插入图片描述

验证邮件交换器设置:

host -t mx fl.com

在这里插入图片描述

测试DNS解析

nslookup -q=mx fl.com

在这里插入图片描述

nslookup dns.fl.com

在这里插入图片描述

修改sendmail.mc并重新生成sendmail.cf,修改/etc/mail/sendmail.mc,
将DAEMON_OPTIONS(`Port=smtp,Addr=127.0.0.1, Name=MTA') dnl和
LOCAL_DOMAIN(`localhost.localdomain')dnl指定邮件服务器的侦听地址范围以及邮件服务器所在的本地域,也可以设置为0.0.0.0表示侦听所有IP地址。

vi /etc/mail/sendmail.mc

在这里插入图片描述

**第118行和157行
请注意,这里的192.168.100.20为你的邮件服务器IP,也就是本机IP,并非DNS服务器IP**

在这里插入图片描述
在这里插入图片描述

将文件写入

m4  /etc/mail/sendmail.mc  >  /etc/mail/sendmail.cf

在这里插入图片描述
修改access文件设置邮件中继

vi /etc/mail/access

在这里插入图片描述

添加如下内容
fl.com RELAY
mail.fl.com RELAY
192.168.100.0/24 RELAY
在这里插入图片描述

将文件写入access.db
在这里插入图片描述
修改local-host-names文件
vi /etc/mail/local-host-names
在这里插入图片描述

添加如下内容:
fl.com
mail.fl.com在这里插入图片描述

修改host文件

vi /etc/hosts

在这里插入图片描述

添加如下内容:
192.168.100.20 base mail.fl.com
在这里插入图片描述

修改/etc/aliases设置群发别名

vi /etc/aliases

添加如下内容:可在配置文件末尾添加
test:fl,fly //此处test为用户组,fl和fly为用户
在这里插入图片描述

再执行

newaliases

在这里插入图片描述

重启sendmail服务进行生效
在这里插入图片描述
创建邮件用户,此处使用密码为 000000

groupadd test

useradd fl -g test -s /sbin/nologin

useradd fly -g test -s /sbin/nologin

passwd fl

passwd fly

在这里插入图片描述

测试发送Sendmail邮件
先安装telnet命令

yum -y install telnet

telnet 192.168.100.20 25

键入如下内容:

helo mail.fl.com

mail from:"test"root@fl.com //设置邮件主题是test,发件人是root@fl.com

rcpt to:fly@fl.com //设置收件人地址是fl@fl.com

data //data表示开始写邮件的内容。

This is a test mail. //邮件内容的正文。

. //这里的点号表示邮件正文结束。

在这里插入图片描述

mailq //检查所传送的电子邮件是否送出或滞留在邮件服务器中。

在这里插入图片描述

修改Dovecot程序主配置文件

vi /etc/dovecot/dovecot.conf

第24行,30行,33行,48行
protocols = imap pop3 lmtp //支持的邮局协议,第24行
listen = 192.168.100.20, :: //设置dovecot监听的邮件服务器IP地址,默认为所有地址,第30行。
base_dir = /var/run/dovecot/ //设置存储dovecot运行时数据的目录,第33行。
login_trusted_networks = 192.168.100.0/24 //允许登录的网段地址,0.0.0.0/0为全部允许,第48行。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
配置邮件的格式与存储路径

vi /etc/dovecot/conf.d/10-mail.conf

第25行,去掉前面注释,并顶格
在这里插入图片描述

/var/mail/文件夹下的文件默认权限为0660,需要修改为0600

chmod 0600 /var/mail/*

在这里插入图片描述

systemctl restart dovecot //重启dovecot服务在这里插入图片描述

配置邮件客户端并收发邮件
使用Linux邮件客户端
1、修改/etc/resolv.conf,添加配置行“nameserver 192.168.100.21”,指定DNS服务器为192.168.100.21
在这里插入图片描述
安装 mailx

yum -y install mailx

编辑mail配置文件

vi /etc/mail.rc

添加如下内容
set from=fl@fl.com
set smtp=mail.fl.com
set smtp-auth-user=fl@fl.com
set smtp-auth-password=000000
在这里插入图片描述

使用mail命令给用户发送邮件

mail fly@fl.com

Subject: hello //输入邮件主题。
test
@@@@@@@
EOT //按CTR+D键退出内容编辑。

此处会直接提示发信失败,似乎是一个bug,又或者是我哪里出问题,查阅了国内外对此问题的描述,并未给出正面解决方案,如果有解决的,请在文章末尾留言回复

请直接跳到windows发信部分,发信之后,再进行下一步:mail命令接受邮件

使用mail命令接收邮件,请先执行windows收发邮件测试

mail -u fly

Heirloom Mail version 12.5 7/5/10.  Type ? for help.
"/var/mail/fly": 2 messages 1 new
    1 "fl-testmail"root@fl  Fri Jun 21 20:18  14/513   
>N  2 fly@fl.com            Fri Jun 21 20:37  42/1525  "群发测试"
& t 1              //请输入 t 1 查看第一条。t 2查看第二条“42/1525”表示邮件的行号和字符数。“N”表示新邮件。
Message  1:
From "fl-testmail"root@fl.com  Fri Jun 21 20:18:03 2019
Return-Path: <"fl-testmail"root@fl.com>
Date: Fri, 21 Jun 2019 20:16:14 -0400
From: "fl-testmail"root@fl.com
X-IMAPbase: 1561163143 0000000001
X-UID: 1                                                 
Status: RO

this is a test mail from fly

& t 2
Message  2:
From fly@fl.com  Fri Jun 21 20:37:00 2019
Return-Path: <fly@fl.com>
Date: Fri, 21 Jun 2019 23:37:00 +0800
From: "fly@fl.com" <fly@fl.com>
To: test <test@fl.com>
Cc: test <test@fl.com>
Subject: 群发测试
X-Priority: 3
X-Has-Attach: no
X-Mailer: Foxmail 7.2.11.303[cn]
Content-Type: multipart/alternative;
        boundary="----=_001_NextPart785125888636_=----"
Status: R

Content-Type: text/plain;
        charset="GB2312"


this is a group test from fly


fly@fl.com

在这里插入图片描述

配置Windows邮件客户端并收发邮件

Windows 7 需要添加一张和linux处于同一网段的网卡,并确定Winodws 7 虚拟主机和Linux虚拟主机之间能够互通
在这里插入图片描述

进入foxmail官网下载foxmail
https://www.foxmail.com/
在这里插入图片描述

安装fixmail
在这里插入图片描述

双击打开,选择其他邮箱
在这里插入图片描述

选择手动设置
在这里插入图片描述

设置相关选项
在这里插入图片描述
**编辑WIN7和Linux使用相同的一张网卡的具体配置VM1,这里的win7系统使用IP地址192.168.100.12,此处的IP地址自行设置,不要冲突就行
设置完之后请进行linux和windows的ping测试,以确保2者网络互通**
若不通,请更换windows7的IP地址
建议在设置之后,请在windows7上面使用nslookup命令对Linux的DNS服务器进行测试

nslookup mail.fl.com
以确保你的Windows 7 虚拟机能够解析到 mail服务器
在这里插入图片描述

点击创建
在这里插入图片描述

可以重复以上步骤登陆第二个账号fl@fl.com

邮件群发测试
以fly@fl.com向test@fl.com发送一封群发测试邮件
再使用fl@fl.com测试接收邮件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

目录
相关文章
|
5天前
|
弹性计算 JavaScript 应用服务中间件
在一台ECS服务器上优雅部署多环境:实践攻略
在ECS上部署多环境应用,通过Nginx反向代理实现。规划端口或子域名区分开发、测试和生产环境。配置应用监听不同端口,如Node.js应用修改启动脚本。【6月更文挑战第21天】
125 3
|
4天前
|
Java Maven
springboot项目打jar包后,如何部署到服务器
springboot项目打jar包后,如何部署到服务器
16 1
|
14天前
|
域名解析 弹性计算 监控
使用云效将项目代码部署到云服务器ECS的体验评测
本文详述了使用阿里云云效和ECS搭建企业门户网站的解决方案,包括引导文档、部署流程、一键与手动部署的优缺点以及部署中可能遇到的问题。文中建议阿里云改进文档更新及时性,增强流程指引清晰度,提供更具体的错误信息,并增加实时监控、报警功能及性能优化建议。此外,呼吁建立更多用户交流平台以提升用户体验。
51 1
|
21天前
|
NoSQL 关系型数据库 应用服务中间件
jdk1.8、mysql、redis、nginx centos云服务器安装配置
jdk1.8、mysql、redis、nginx centos云服务器安装配置
|
2天前
|
JavaScript Java 应用服务中间件
打包前后端程序并在阿里云服务器上部署,只需几步就能实现!
打包前后端程序并在阿里云服务器上部署,只需几步就能实现!
|
4天前
|
弹性计算 缓存 监控
云效将项目代码部署到云服务器ECS
云效支持一键和手动部署,一键部署因其高效、一致性和可重复性而受青睐,但也存在灵活性不足和初期设置复杂的挑战。优化方向包括简化脚本、提供选项、完善文档、集成监控和回滚机制。一键部署步骤概括为:准备云效项目和ECS,配置项目和环境,编写部署脚本,设置一键部署,测试脚本,审核发布,监控结果,及后续维护。实际操作应参照云效最新文档。
14 0
|
4天前
|
Java Linux
IDEA远程调试Centos部署的jar包
IDEA远程调试Centos部署的jar包
7 0
|
8天前
|
Java Linux
杨校老师课堂之CentOS7部署开发环境Jdk1.8【Linux】
杨校老师课堂之CentOS7部署开发环境Jdk1.8【Linux】
13 0
|
8天前
|
安全 Java Linux
从零开始搭建服务器之更加优雅地部署项目(2)
从零开始搭建服务器之更加优雅地部署项目
|
8天前
|
应用服务中间件 Linux nginx
从零开始搭建服务器之更加优雅地部署项目(1)
从零开始搭建服务器之更加优雅地部署项目