热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Sendmail如何设置

25.1sendmail概述25.1.1sendmail基本概念发信服务器:smtp收信服务器:pop/imapMTA:邮件传输代理,邮件server的总称。MUA:邮件用户代理,收信的客户端软件的总称。(oe/foxmail)就是收受邮件主机的电子邮件,以及提供使用者浏览与编写邮件的功能。2
25.1 sendmail概述

25.1.1 sendmail基本概念
发信服务器:smtp
收信服务器: pop/imap
MTA:邮件传输代理,邮件server的总称。
MUA:邮件用户代理,收信的客户端软件的总称。(oe/foxmail) 就是收受邮件主机的电子邮件,以及提供使用者浏览与编写邮件的功能。

25.1.2 邮件格式
From:tom@koumm.com
To:jack@koumm.com
Subject to :hi
Body:welcome to here!

25.2 sendmail安装

25.2.1 rpm包安装sendmail

Sendmail默认已经安装好了,只能在主机上,以及主机上的用户之间收发电子邮件,不能通过邮件域名,以及pop3功能收发电子邮件,如果需要使用其它功能还需要对sendmail进行配置。
1.安装sendmail工具
rpm -q sendmail
rpm -q sendmail-cf
rpm -q sendmail-doc
rpm -qa |grep sasl
cyrus-sasl-lib-2.1.21-10
cyrus-sasl-devel-2.1.21-10
cyrus-sasl-plain-2.1.21-10
cyrus-sasl-2.1.21-10
2.M4工具安装
rpm -qa |grep m4   /*检查m4工具的安装*/
m4-1.4.4-1.2.1     /*默认情况下该工具没有安装,需要安装才能对sendmail进行其它配置,非常关键与重要。*/
3.准备dns资源记录
详细请见18.2.4自定义区域文件

25.2.2 pop3/imap安装
1.redhat linux9的pop3/imap安装
rpm -q dovecot
dovecot-1.0-0.beta2.7
#默认的情况下pop/imap服务的功能没有安装,需要另外安装才行,对于FC/Redhat服务器版式的pop服务器,需要安装以上文件包。由于以上文件包有一定的软件依赖性,需要先安装perl再安装mysql,才能无错误提示安装dovecot软件包。

25.2.3 sendmail服务启动
Sendmail服务是独立方式来进行启动的。Sendmail服务的启动需要可以通过以下方式来进行。
chkconfig sendmail on
service sendmail start
sendmail -bd ?q12h
后跟的参数解释如下:
-b:设定Sendmail服务运行于后台。
-d:指定Sendmail以Daemon(守护进程)方式运行。
-q:设定当Sendmail无法成功发送邮件时,就将邮件保存在队列里,并指定保存时间。上面的12h表示保留12小时。

25.3 sendmail邮件配置

25.3.1 sendmail配置文件介绍

rpm -qc sendmail
/etc/mail/access             /*允许转发的域名与IP地址*/
/etc/mail/local-host-names   /*域名后缀*/
/etc/mail/sendmail.cf        /*sendmail配置文件*/
/etc/mail/sendmail.mc        /*sendmail模板文件*/
/etc/rc.d/init.d/sendmail    /*sendmail服务启动脚本*/

25.3.2 /etc/mail/access
/etc/mail/access中加入允许sendmail进行中继或转发的邮件的域名与地址。否则sendmail不会把该邮件进行转发出去。默认只有127.0.0.1即是本地邮件进行转发,所以需要修改以下文件。
vi /etc/mail/access
192.168.1                      RELAY
mail.koumm.com            RELAY
koumm.com                   RELAY
localhost                        RELAY
127.0.0.1                       RELAY
localhost.localdomain     RELAY
修改完以后还需要对以上文件进行hash编码才行。
Makemap hash access.db
25.3.3 /etc/mail/local-host-names
/etc/mail/local-host-names是申明sendmail可以为哪几个域发送电子邮件。
vi /etc/mail/local-host-names
koumm.com
mail.koumm.com
abc.com
#sendmail可以为哪几个域服务。

25.3.4 /etc/mail/sendmail.cf
/etc/mail/sendmail.cf是sendmail的配置文件,该文件是由sendmail.mc模板文件创建而成的,为了实现非本机的SMTP/POP/IMAP收发功能。需要修改该模板文件,然后再由模板文件创建配置文件。
vi /etc/mail/sendmail.mc
1. 用户邮件的大小限制
原来限制为2MB,建议改为20MB,注意这里容量单位为字节,2000000=2M,20000000=20M
define(`UUCP_MAILER_MAX', `20000000')dnl
2. 邮箱接收邮件的地址范围
原来该命令行中地址为127.0.0.1,这样只能收本机系统产生的邮件,改为通配地址0.0.0.0,表示允许任意地址的计算机通过此邮件服务器发送邮件,或根据具体情况修改,必须要修改,否则pop发送功能不能实现。
DAEMON_OPTIONS(`Port=smtp,Addr=0.0.0.0,Name=MTA' )dnl
3. 设置本地邮箱的域名
默认是localhost.localdomain,在outlook中输入用户邮箱时会自动显示本域名信息,需要修改为本地域名地址。
LOCAL_DOMAIN(`koumm.com')dnl
dnl MASQUERADE_AS(`koumm.com')dnl
m4 sendmail.mc > sendmail.cf /*通过模板生成配置文件*/

25.3.5 邮件别名
一般情况下,电子邮件出现问题的时候,我们需要把出错的邮件头发送到本机的postmaster用户,但是也许你的系统上有多个系统管理员,因此每个人都需要得到一份这个邮件头的拷贝。这种情况下就需要使用用户别名文件了。
创建别外文件,也就是可以为哪些用户代收邮件的功能。
makemap hash aliases.db #生成数据库文件,以后面添加别名用户做准备。
1.一般别名
aliases文件的格式是 邮件别名:实际用户名
如果一个别名有多个用户就用逗号分开,每个别名一行。
postmaster:supervisor,manager
2.自动转发
别名还可以用在这样的情况,即定义自动的邮件转发。例如,某个用户以前在你的系统上接受电子邮件,现在他有了一个新的电子邮件,希望发到你的机器上的邮件自动被转发到他新的电子邮件地址上,那么,可以使用类似这样的别名方式:(假设你的机器是joe@koumm.com)
joe: joe@abc.com
以后发给joe@koumm.com的电子邮件就自动中转到joe@abc.com。注意左边自动加上你的机器名字,所以左边只能是账号名字,不能是全限定邮件地址。
3. 重定向
另一个常用的办法是重定向。如果你在模板文件中定义了REDIRECT特性,那么可以使用这个功能。例如,某个人在你的机器上开了一个账户tom,后来迁移到redhat@koumm.com。那么,你可以将其别名写成
tom: redhat@koumm.com.REDIRECT
示例:
vi /etc/mail/aliases
root:redhat
joe: joe@abc.com
tom: redhat@koumm.com.REDIRECT
newaliases  将以上别名初始化。
/etc/aliases: 76 aliases, longest 10 bytes, 765 bytes total

25.3.6 用户认证
要实现用户认证的功能,需要修改sendmail配置文件,FC5 linux sendmail默认已经开启了认证功能,但是认证服务没有开启,需要手动开启。
如果发送的邮件是对linux主机上的用户发的,是不需要经过认证的。对于发送到非本域的电子邮件是需要进行发送前的认证的,如发送到互联网上的电子邮件。

1.开启认证服务
chkconfig --list |grep sasl
saslauthd       0:关闭  1:关闭  2:关闭  3:关闭  4:关闭  5:关闭  6:关闭
chkconfig saslauthd on   /*开机自动开启认证服务*/
service saslauthd start  /*运行认证服务*/

2.配置认证服务
vi /etc/mail/sendmail.mc
#修改以下内容,如果前面有dnl把前面的dnl删除掉,才能成功。
dnl # The following allows relaying if the user authenticates, and disallows
dnl # plaintext authentication (PLAIN/LOGIN) on non-TLS links
#注,这里要把原来的p改成y
define(`confAUTH_OPTIONS', `A y')dnl
#是使sendmail不管access文件中如何设置,都能 relay 那些通过EXTERNAL
#LOGIN, PLAIN, CRAM-MD5或DIGEST-MD5等方式验证的邮件。
TRUST_AUTH_MECH(`EXTERNAL DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
#confAUTH_MECHANISMS"是确定系统的认证方式,OE只支持login
define(`confAUTH_MECHANISMS', `EXTERNAL GSSAPI DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
#注释掉这一行,这一行作用是在25口发送电子邮件。
#dnl DAEMON_OPTIONS(`Port=smtp,Addr=0.0.0.0, Name=MTA')dnl
#修改以下内容,把认证口也改在25口。
#dnl DAEMON_OPTIONS(`Port=submission, Name=MSA, M=Ea')dnl
#去掉行首的注释符,并且将内容修改成Port=25:
DAEMON_OPTIONS(`Port=25, Name=MSA')dnl
m4 sendmail.mc > sendmail.cf
#以下配置一定要做。思路就是通过模板文件生成配置文件。

3.检测认证开启
#如果出现250-AUTH LOGIN PLAIN说明认证服务开始成功。
netstat -tnl|grep 25
telnet koumm.com 25
Trying 192.168.1.3...
Connected to koumm.com (192.168.1.3).
Escape character is '^]'.
220 localhost.localdomain ESMTP Sendmail 8.13.5/8.13.5; Tue, 3 Feb 2009 21:42:34 +0800
ehlo koumm.com         /*手动输入内容*/
250-localhost.localdomain Hello redhat.koumm.com [192.168.1.3], pleased to meet you
250-ENHANCEDSTATUSCODES
250-PIPELINING
250-8BITMIME
250-SIZE
250-DSN
250-ETRN
250-AUTH LOGIN PLAIN
250-DELIVERBY
250 HELP
25.3.7 smtp命令测试发信

1.测试邮件发送
telnet koumm.com 25
Trying 192.168.1.3...
Connected to koumm.com (192.168.1.3).
Escape character is '^]'.
220 localhost.localdomain ESMTP Sendmail 8.13.5/8.13.5; Tue, 3 Feb 2009 21:42:34 +0800
mail from:root@koumm.com     /*从哪里发的*/
rcpt to:redhat@koumm.com     /*发到哪里去*/
data                         /*内容区域标志,下面为正文内容*/
subject:hello                /*邮件主题,可以没有主题。*/
hello!
.                  /*点号结束邮件内容*/
quit               /*退出*/

2.Smtp其它命令补充
HELO:<地址>
MAIL FROM:<发件人Email地址>
RCPT TO:<收信人的E-mail地址>
VRFY: 验证其后的电子邮件地址的正确性
DATA
Subject:<主题内容><回车>,
.<回车> 结束邮件的编辑
RSET  中止发信操作,删除输入内容。
QUIT

3.用户接收
收信可以用以下方式进行,也可以用pop命令直接接收也可以。
su - redhat
mail               /*收信*/

25.4 pop3服务配置
pop3服务,不同的版本的linux中POP程序都不相同。Fc5与redhat企业版采用是dovecot程序来实现pop/imap服务。
redhat linux9中采用的是imap来实现pop/smtp服务。

25.4.1 dovecot程序pop/imap配置
dovecot中安装好后,就可以提供pop3/imap服务了,不需要单独配置,dovecot配置文件/etc/dovecot.conf
vi /etc/dovecot.conf
#只需要修改以下内容,其它不需要动。
protocols = imap imaps pop3 pop3s
listen = *

25.4.2 imap程序pop/imap配置
imap程序的安装配置主要是在redhat linux9系统中,其中安装好imap程序后,pop/imap服务的配置文件就已经安装好了,需要对其进行配置才能使用。注明:linux9中的pop服务的启动是采用超级守护程序xinetd来进行启动的。
1.安装imap
rpm -ivh imap-2001a-18.i386.rpm
2.配置pop3
vi /etc/xinetd.d/ipop3
default: on
# description: The telnet server serves telnet sessions; it uses \
#       unencrypted username/password pairs for authentication.
service ipop3
{
        disable = no    把原来的yes改成no就OK
flags           = REUSE
....       
wait            = no
}
/etc/rc.d/init.d/xinetd restart
注:对于redhat linux9的配置可能与现在的新系统不一样,但是相关原理一致,可以在不同的环境中采用不同的方法来实现。

25.4.3 outlook测试收发信
打开Outlook Express,修改你的账号属性,在服务器选项,选取我的smtp服务器需要认证,其它配置根据向导进行。
对于sendmail配置认证功能,找了很多的文章,进行实践,但是在oe中怎么就不能够实现,因为验不验证都可以实现收发邮件,是不是sendmail本身的问题还是怎么回事,这个问题留待以后再解决了。
解决:已经更新了配置。对于发送到互联网的邮件需要选择身份验证。Linux主机上用户之间的邮件发送不需要认证。
 
25.4.5 pop命令测试收信
1.测试邮件发送
#红色为命令,后面为参数
telnet koumm.com 110
Trying 192.168.129.20...
Connected to 192.168.129.20.
Escape character is '^]'.
+OK POP3 [192.168.129.20] v2001.78rh server ready
user redhat   /*邮箱的用户名*/
+OK User name accepted, password please
pass redhat   /*邮箱的密码*/
+OK Mailbox open, 1 messages
list          /*显示信件个数、序号和每个信件的大小*/
+OK Mailbox scan listing follows
1 608         /*邮件序号,以及邮件占用的字节数*/
.
stat          /*用户共有多少封信件在信箱中*/
+OK 1 608
retr 1        /*返回第一封信的全部内容*/
+OK 608 octets
Return-Path:
Received: from localhost.localdomain (redhat [127.0.0.1])
        by localhost.localdomain (8.12.8/8.12.8) with SMTP id 31812
        for ; Wed, 11 Feb 2009 20:31:03 +0800
Received: (from root@localhost)
        by localhost.localdomain (8.12.8/8.12.8) with SMTP id 31812
        for redhat@koumm.com; Wed, 11 Feb 2009 20:31:03 +0800
Date: Wed, 11 Feb 2009 20:31:03 +0800
From: root
Message-Id: <200902111231.n1BCV3F4001810@localhost.localdomain>
To: redhat@koumm.com
Subject: book
Status:  
book
book
book
yes
.
quit
+OK Sayonara
Connection closed by foreign host.
2.其它命令
USER <用户名>
PASS <密码>
STAT     将告诉用户共有多少封信件在信箱中。
LIST     显示信件个数、序号和每个信件的大小。
TOP n m  显示第n个信件前m行的内容。
RETR n  可以显示第n个信件的全部内容。
DELE n  删除指定的第n个信件。
REST n  恢复被删除的n个信件。
LAST   显示下一个信件的编号。
NOOP   不执行任何操作,仅用来测试服务器的响应是否正常。
QUIT   退出POP3服务器,结束信件查阅过程。

25.5 sendmail配置总结
想配置sendmail已经很久了,但是总由于对电子邮件的服务不是很了解,或者是对sendmail的介绍太少,对其不是很了解,结果托了很长的时间。只到2009年2月3号才配置完成,但是当时对smtp的认证的配置不成功,结果第二天在网上找资料才发现原因,还好,没有走多少的弯路。
在配置的过程中,一定要了解相关的知识,其中系统管理中的内容的深入了解对网络服务的配置以及排错起了很大的作用,所以对相关知识还需要深入了解。
邮件系统中sendmail由于是默认安装,并且使用广泛,而且配置复杂。对它的了解具体有一定的意义。
通过outlook向系统中用户发送的电子邮件,用户通过mail命令接收到显示为烂码,可以通过修改“工具/选项/发送/电子邮件格式/选择纯文本方式”,可以解决。
推荐阅读
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文将深入探讨PHP编程语言的基本概念,并解释PHP概念股的含义。通过详细解析,帮助读者理解PHP在Web开发和股票市场中的重要性。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • CentOS 7 磁盘与文件系统管理指南
    本文详细介绍了磁盘的基本结构、接口类型、分区管理以及文件系统格式化等内容,并提供了实际操作步骤,帮助读者更好地理解和掌握 CentOS 7 中的磁盘与文件系统管理。 ... [详细]
  • 本周信息安全小组主要进行了CTF竞赛相关技能的学习,包括HTML和CSS的基础知识、逆向工程的初步探索以及整数溢出漏洞的学习。此外,还掌握了Linux命令行操作及互联网工作原理的基本概念。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • MongoDB的核心特性与架构解析
    本文深入探讨了MongoDB的核心特性,包括其强大的查询语言、灵活的文档模型以及高效的索引机制。此外,还详细介绍了MongoDB的体系结构,解释了其文档、集合和数据库的层次关系,并对比了MongoDB与传统关系型数据库(如MySQL)的逻辑结构。 ... [详细]
  • 深入解析BookKeeper的设计与应用场景
    本文介绍了由Yahoo在2009年开发并于2011年开源的BookKeeper技术。BookKeeper是一种高效且可靠的日志流存储解决方案,广泛应用于需要高性能和强数据持久性的场景。 ... [详细]
author-avatar
井然洞中别样天
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有