Linux学习之电子邮件系统

2023-10-09 15:30

本文主要是介绍Linux学习之电子邮件系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、电子邮件的简介

电子邮件,英文称作Electronic Mail,简称E-mail,是—种用电子手段提供信息交换的通信方式,是互联网应用最广的服务。通过网络的电子邮件系统,用户可以以非常低廉的价格、非常快速的方式,与世界上任何一个角落的网络用户联系。
电子邮件可以是文字、图像、声音等多种形式。同时,用户可以得到大量免费的新闻、专题邮件,并实现轻松的信息搜索。电子邮件的存在极大地方便了人与人之间的沟通与交流,促进了社会的发展。

二、常见邮件协议

电子邮件系统既有邮件协议来完成电子邮件的传输
简单邮件传输协议(Simple Mail Transfer Protocol,SMTP):用于发送和中转发出的电子邮件,占用服务器的25/TCP端口。
邮局协议版本3(Post Office Protocol 3):用于将电子邮件存储到本地主机,占用服务器的110/TCP端口。
Internet消息访问协议版本4(Internet Message Access Protocol 4):用于在本地主机上访问邮件,占用服务器的143/TCP端口。

三、电子邮件的传输原理

在这里插入图片描述

发件人注明收件人的姓名与地址(即邮件地址),发送方服务器把邮件传到收件方服务器,收件方服务器再把 邮件发到收件人的邮箱中。

解释该原理需要用的几个概念:

1、发件人:MUA -- Mail User Agent, 邮件用户代理,帮助用户读写邮件;2、服务器:MTA -- Mail Transport Agent, 邮件传输代理,负责把邮件由一个服务器传到另一个服 务器或邮件投递代理; 3、收件人:MDA -- Mail Delivery Agent, 邮件投递代理,把邮件放到用户的邮箱里。

四、电子邮件的传输过程

在这里插入图片描述
发送方:lisi@sina.com 接收方:wangwu@sohu.com

主要实现过程: 
1、lisi@sina.com的邮件客户端程序与sina的SMTP服务器建立网络连接,并登录账号,使用SMTP协议把 邮件发送给sina的SMTP服务器。 
2、sina的SMTP服务器收到lisi@sina.com提交的电子邮件后,首先根据收件人的地址后缀判断接收者的邮 件地址是否属于该SMTP服务器的管辖范围,如果是的话就直接把邮件存储到收件人的邮箱中;否则,sina 的 SMTP服务器向DNS服务器查询收件人的邮件地址后缀(sohu.com) 所表示的域名,从而得到sohu的SMTP服 务器信息,然后与sohu的SMTP服务器建立连接并采用SMTP协议把邮件发送给sohu的SMTP服务器。
3、sohu的SMTP服务器收到sina的SMTP服务器发来的电子邮件后,也将根据收件人的地址判断该邮件是否属于该SMTP服务器的管辖范围,如果是的话就直接把邮件存储到收件人的邮箱中。 
4、拥有wangwu@sohu.com账户的用户通过邮件客户端程序与sohu的POP3服务器建立网络连接,并登录账号,就可以通过POP3协议查看邮件。

五、部署电子邮件环境

一般而言,我们的邮箱地址类似于“root@lx.com”这样,也就是按照“用户名@主机地址(域名)”格式来规范的。要想更好地检验电子邮件系统的配置效果,需要先部署bind服务程序,为电子邮件服务器和客户端提供DNS域名解析服务。
centos环境:192.168.25.100 电子邮件服务器
win7环境: 192.168.25.140 客户端测试
邮件服务器基本配置
第1步:配置服务器主机名称,需要保证服务器主机名称与发信域名保持一致:

[root@mail ~]# hostname 
mail.lx.com

第2步:清空iptables防火墙默认策略,并保存策略状态(防止防火墙策略影响了dns解析和收发邮件的效果)

[root@mail ~]# iptables -F 
[root@mail ~]# service iptables saveiptables: Saving firewall rules to /etc/sysconfig/iptables:[ 确定 ]

第3步:为电子邮件系统提供域名解析。
主配置文件

[root@mail ~]# cat /etc/named.conf 
options { 
listen-on port 53 { any; }; 
listen-on-v6 port 53 { ::1; }; 
directory "/var/named"; 
dump-file "/var/named/data/cache_dump.db"; 
statistics-file "/var/named/data/named_stats.txt"; 
memstatistics-file "/var/named/data/named_mem_stats.txt"; 
recursing-file "/var/named/data/named.recursing"; 
secroots-file "/var/named/data/named.secroots"; 
allow-query { any; }; 
recursion yes; 
dnssec-enable yes; 
dnssec-validation yes;/* Path to ISC DLV key */ bindkeys-file "/etc/named.root.key"; managed-keys-directory "/var/named/dynamic";
pid-file "/run/named/named.pid"; 
session-keyfile "/run/named/session.key"; };
logging {
channel default_debug { 
file "data/named.run"; 
severity dynamic; 
}; 
};
zone "." IN { 
type hint; 
file "named.ca"; 
};
include "/etc/named.root.key"; 
include "/etc/named.rfc1912.zones";

区域配置文件
在这里插入图片描述
正向解析文件
在这里插入图片描述
重启dns服务
在这里插入图片描述
这样电子邮件系统所对应的服务器主机名即为mail.lx.com,而邮件域为@lx.com
第4步:把服务器的DNS地址修改成本地IP地址
在这里插入图片描述
Postfix服务程序配置
第1步:安装postfix(centos7自带此服务程序)
第2步:禁用iptables防火墙(防止外部无法访问电子邮件系统)
在这里插入图片描述
第3步:配置postfix服务程序(/etc/ postfix/main.cf),此处我们修改的内容有5处
第76行名为myhostname的变量(邮件系统的主机名)

myhostname = mail.lx.com 

第83行名为mydomain的变量(邮件系统的域名)

mydomain = lx.com

第99行名为 myorigin的变量(本机发出邮件的域名名称)

myorigin = $mydomain

第116行名为inet_interfaces的变量(指定要使用服务器的哪些IP地址对外提供电子邮件服务)

inet_interfaces = all

此处的all表示所偶的IP地址都能提供电子邮件服务
第164行名为mydestination的变量(可接收邮件的主机名或域名)

mydestination = $myhostname , $mydomain

同时我们还要注意2个变量分别为:
mynetworks(设置可转发哪些主机的邮件)
relay_domains(设置可转发哪些网域的邮件)
第4步:创建登录账户并启动postfix服务
在这里插入图片描述
在centos安装dovecot服务程序
第1步:安装dovecot服务
第2步:配置postfix服务程序(/etc/dovecot/dovecot.conf)

[root@mail ~]# vim /etc/dovecot/dovecot.confp 
protocols = imap pop3 lmtp 
//把Dovecot服务程序支持的电子邮件协议修改为imap、pop3和lmtp 
disable_plaintext_auth = no 
//允许用户使用明文进行密码验证 login_trusted_networks = 192.168.25.0/24 //设置允许登录的网段地址

第3步:配置邮件格式与存储路径(/etc/dovecot/conf.d/10-mail.conf)
在这里插入图片描述
然后切换到配置Postfix服务程序时创建的lei账户,并在家目录中建立用于保存邮件的目录。
记得要重启Dovecot服务并将其添加到开机启动项中。至此,对Dovecot服务程序的配置部署步骤全部结束。
在这里插入图片描述
客户端测试
第1步:配置win7的ip地址为192.168.25.140和dns服务器为192.168.25.100
在这里插入图片描述
第2步:安装outlook软件
在这里插入图片描述
在这里插入图片描述
邮件地址为lx@lx.com,即用户名+域名
第3步:客户端测试
在这里插入图片描述
此时我们在电子邮件服务器上使用mail命令查看邮件
在这里插入图片描述
设置用户别名邮箱
我们向bin用户发送一封邮件,内容信息如下:
在这里插入图片描述
在邮件发送后登录到服务器,然后尝试以bin账户的身份登录。由于bin账户在Linux系统中是系统账户,默认的Shell终端是/sbin/nologin,因此在以bin账户登录时,系统会提示当前账户不可用。但是,在电子邮件服务器上使用mail命令后,却看到这封原本要发送给bin账户的邮件已经被存放到了root账户的信箱中。
在这里插入图片描述
这就是使用用户别名技术来实现的。在aliases邮件别名服务的配置文件中可以看到,里面定义了大量的用户别名,这些用户别名大多数是Linux系统本地的系统账户,而在冒号(:)间隔符后面的root账户则是用来接收这些账户邮件的人。用户别名可以是Linux系统内的本地用户,也可以是完全虚构的用户名字。
在这里插入图片描述
aliases邮件别名服务的配置文件是专门用来定义用户别名与邮件接收人的映射。除了使用本地系统中系统账户的名称外,我们还可以自行定义一些别名来接收邮件。

这篇关于Linux学习之电子邮件系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/173811

相关文章

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

Linux之UDP和TCP报头管理方式

《Linux之UDP和TCP报头管理方式》文章系统讲解了传输层协议UDP与TCP的核心区别:UDP无连接、不可靠,适合实时传输(如视频),通过端口号标识应用;TCP有连接、可靠,通过确认应答、序号、窗... 目录一、关于端口号1.1 端口号的理解1.2 端口号范围的划分1.3 认识知名端口号1.4 一个进程

Linux权限管理与ACL访问控制详解

《Linux权限管理与ACL访问控制详解》Linux权限管理涵盖基本rwx权限(通过chmod设置)、特殊权限(SUID/SGID/StickyBit)及ACL精细授权,由umask决定默认权限,需合... 目录一、基本权限概述1. 基本权限与数字对应关系二、权限管理命令(chmod)1. 字符模式语法2.

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方