主要内容:
分离解析介绍、NTP时间服务、基础邮件服务(MX记录)、部署postfix邮件服务器、自定义YUM仓库
实操提前准备:
① 设置SELinux、关闭防火墙服务(两台主机)
bash
[root@svr7 ~]# getenforce
Permissive
[root@svr7 ~]# systemctl stop firewalld
[root@svr7 ~]# systemctl disable firewalld
② 主机1:安装软件包,配置主配置文件及地址库文件,重启服务并验证服务
bash
[root@svr7 ~]# yum -y install bind bind-chroot.x86_64 //安装软件包
[root@svr7 ~]# cp /etc/named.conf /root/ //备份主配置文件
[root@svr7 ~]# vim /etc/named.conf //修改主配置文件
options { //全局配置
directory "/var/named";
};
zone "lol.com" IN { //区域配置
type master;
file "lol.com.zone";
};
[root@svr7 ~]# cd /var/named/
[root@svr7 named]# cp -p named.localhost lol.com.zone //复制模板建立地址库
[root@svr7 named]# vim lol.com.zone
...
lol.com. NS svr7
svr7 A 192.168.4.7
www A 1.1.1.1
vip A 2.2.2.2
[root@svr7 named]# named-checkconf /etc/named.conf
[root@svr7 named]# named-checkzone lol.com /var/named/lol.com.zone
zone lol.com/IN: loaded serial 0
OK
[root@svr7 named]# systemctl restart named //重启服务
[root@svr7 named]# nslookup www.lol.com
;; connection timed out; no servers could be reached
[root@svr7 named]# vim /etc/resolv.conf //指定解析主机
nameserver 192.168.4.7
[root@svr7 named]# nslookup www.lol.com
Server: 192.168.4.7
Address: 192.168.4.7#53
Name: www.lol.com
Address: 1.1.1.1
③ 主机2:安装软件包,指定解析主机,验证服务
bash
[root@pc207 ~]# yum -y install bind bind-chroot.x86_64
[root@pc207 ~]# vim /etc/resolv.conf //指定解析主机
nameserver 192.168.4.7
[root@pc207 ~]# nslookup www.lol.com //验证服务
Server: 192.168.4.7
Address: 192.168.4.7#53
Name: www.lol.com
Address: 1.1.1.1
一、分离解析概述(了解)
1)分离解析
当收到客户端的DNS查询请求的时候
- 能够区分客户端的来源地址;
- 为不同类别的客户端提供不同的解析结果(IP地址)
结论:不同客户的DNS查询请求,提供不同的解析结果,例如12306的访问,根据服务器就近原则,提供相应的解析结果。
2)典型适用场景
访问压力大的网站、购买CDN阿里云提供的内容分发服务
- 在全国各地/不同网络内部署大量镜像服务节点;
- 针对不同的客户端就近提供服务器;
二、NTP网络时间协议(Network Time Protocol)
作用:网络时间协议(NTP)用来同步网络上不同主机的系统时钟。所有受管理的主机可以与一台名为NTP服务器的指定时间服务器同步时间。
由于制造方面的差异,有些时钟走块走慢导致"时钟漂移"或"时间漂移"。为了尽量减小时钟漂移影响,使用NTP的主机定期可以与指定的NTP服务器进行联系,保持时钟同步。
国家授时中心服务器IP地址:210.72.145.39
NTP时钟以分层层次结构来加以组织。该层次结构中的每一层被称为层(stratum)。层这个概念描述了某机器距离权威时间源有多少个NTP跳,Stratum 0含有几乎没有时间漂移的时钟,比如原子钟。这些时钟无法通过网络直接使用。Stratum N服务器对照Stratum N-1服务器同步其时间。Stratum N时钟可以通过网络彼此连接。
(NTP最多可支持层次结构中的15层。Stratum 16被认为不同步、无法使用)
1)NTP服务端&客户端
所需软件包:ntp、chrony(提供标准时间服务)
主配置文件:/etc/chrony.conf
字段解析:
- [server 0.centos.pool.ntp.org iburst] //server用户客户端指向上层NTP服务器
- [allow 192.168.4.0/24(all)] //允许哪个IP或网络访问NTP
- [Deny 192.168.4.1] //拒绝哪个IP或网络访问NTP
- [local stratum 10] //设置NTP服务器的层数量,第10层
- [iburst] //快速同步时间
- 手动同步工具:ntpdata
主机1:
步骤1:检查并安装chrony软件包
bash
[root@svr7 ~]# yum -y install chrony //安装软件包
[root@svr7 ~]# rpm -q chrony
chrony-3.2-2.el7.x86_64
步骤2:修改配置文件
bash
[root@svr7 ~]# vim /etc/chrony.conf //修改主配置文件
3 #server 0.centos.pool.ntp.org iburst //注释原配置的上层NTP服务器
4 #server 1.centos.pool.ntp.org iburst
5 #server 2.centos.pool.ntp.org iburst
6 #server 3.centos.pool.ntp.org iburst
26 allow all //允许所有客户端
29 local stratum 10 //设置本机为第10层的时间服务器
...
步骤3:重启服务
bash
[root@svr7 ~]# systemctl restart chronyd.service
主机2:
步骤1:安装软件包
bash
[root@pc207 ~]# yum -y install chrony
[root@pc207 ~]# rpm -q chrony
chrony-3.2-2.el7.x86_64
步骤2:修改主配置文件
bash
[root@pc207 ~]# vim /etc/chrony.conf //修改配置文件
server 192.168.4.7 iburst //设置指定的服务器同步时间(iburst快速同步)
...
步骤3:重启时间服务
bash
[root@pc207 ~]# systemctl restart chronyd
步骤4:验证时间服务(客户端将时间修改错误)
bash
[root@pc207 ~]# date -s '2001-9-3' //修改日期
2001年 09月 03日 星期一 00:00:00 CST
[root@pc207 ~]# date
2001年 09月 03日 星期一 00:00:02 CST
[root@pc207 ~]# systemctl restart chronyd //重启服务,再查看是否同步
[root@pc207 ~]# date
2021年 03月 18日 星期四 15:44:25 CST
[root@pc207 ~]# date -s '5:20' //修改时间
2021年 03月 18日 星期四 05:20:00 CST
[root@pc207 ~]# date
2021年 03月 18日 星期四 05:20:03 CST
[root@pc207 ~]# systemctl restart chronyd //重启服务,再查看是否同步
[root@pc207 ~]# date
2021年 03月 18日 星期四 15:45:37 CST
三、基础邮件服务
邮件服务(Email Service)是一种用于发送、接收和管理电子邮件的系统。电子邮件是一种通过计算机网络进行信息交换的通信方式,它允许用户发送和接收文本消息、文件、图片和其他类型的数据。
邮件服务通常包括以下几个主要组件:
邮件用户代理(MUA):也称为电子邮件客户端,是用户用来撰写、发送、接收和管理电子邮件的软件。常见的MUA包括Microsoft Outlook、Mozilla Thunderbird、Apple Mail和基于Web的电子邮件服务如Gmail、Yahoo Mail等。
邮件传输代理(MTA):负责在邮件服务器之间传输电子邮件。MTA使用简单邮件传输协议(SMTP)来发送邮件。常见的MTA软件包括Postfix、Sendmail和Exim。
邮件投递代理(MDA):负责将邮件从MTA传递到用户的邮箱中。MDA通常在接收邮件的服务器上运行,并使用本地邮件传输协议(LMTP)或邮局协议(POP)/互联网消息访问协议(IMAP)将邮件投递到用户的邮箱。
邮件交换记录(MX记录):在域名系统(DNS)中,MX记录指定了一个域名的邮件服务器。当一封邮件发送到某个域名时,发送方的MTA会查询接收方域名的MX记录,以确定邮件应该发送到哪个邮件服务器。
邮件存储:用户的电子邮件通常存储在邮件服务器上,用户可以通过MUA使用POP或IMAP协议访问这些邮件。
邮件服务的工作流程大致如下:
- 用户使用MUA撰写邮件,并通过SMTP协议将邮件发送到发送方的邮件服务器。
- 发送方的邮件服务器(MTA)根据邮件的收件人地址查询接收方域名的MX记录,确定接收方的邮件服务器。
- 发送方的MTA通过SMTP协议将邮件传输到接收方的邮件服务器。
- 接收方的邮件服务器(MTA/MDA)将邮件投递到收件人的邮箱中。
- 收件人使用MUA通过POP或IMAP协议从邮件服务器上获取邮件。
1)基本功能
- 为用户提供电子邮箱存储空间(用户名@邮件域名)
- 处理用户发出的邮件,传递给收件服务器
- 处理用户收到的邮件,投递到邮箱
2)邮件通信的寻址
根据收件人地址找到目标邮件服务器;
- 邮件相关的DNS设置(本域和外域,例如qq.com、sina.com)
- 添加相应的MX记录、A记录(MX,Mali eXchange邮件交换)
- SMTP简单邮件传输协议,默认端口25
- POP3点对点协议版本3,默认端口110
案例:准备邮件案例环境(为lol.com域提供邮件相关解析)
bash
[root@svr7 ~]# vim /etc/named.conf //修改主配置文件
options {
directory "/var/named";
};
zone "qq.com" IN { //定义解析区域qq.com
type master;
file "qq.com.zone";
};
[root@svr7 ~]# cd /var/named/
[root@svr7 named]# cp -p named.localhost qq.com.zone
[root@svr7 named]# vim qq.com.zone //建立地址库文件
...
qq.com. NS svr7.qq.com.
qq.com. MX 10 mail.qq.com. //数字10为优先级,越小越优先
svr7.qq.com. A 192.168.4.7
mail.qq.com. A 192.168.4.7
www.qq.com. A 1.1.1.1
[root@svr7 named]# systemctl restart named //重启服务
[root@svr7 named]# cat /etc/resolv.conf
nameserver 192.168.4.7
[root@svr7 named]# nslookup mail.qq.com //解析测试
Server: 192.168.4.7
Address: 192.168.4.7#53
Name: mail.qq.com
Address: 192.168.4.7
[root@svr7 named]# host -t MX qq.com //测试qq.com区域邮件交换记录
qq.com mail is handled by 10 mail.qq.com.
[root@svr7 named]# host mail.qq.com //测试域名完整解析
www.qq.com has address 192.168.4.7
四、邮件服务基础
1)快速部署postfix邮件服务器
默认的标准配置即可为本机提供收/发邮件服务(若有必要,可扩大服务范围(邮件域))
配置文件:/etc/postfix/main.cf
- 字段解析:
- [myorigin = $mydomain] //默认补全的域名后缀
- [inet_interfaces = localhost] //只为本机使用邮件服务
- [mydestination = myhostname, localhost.mydomain, localhost] //判断目标是否为本域邮件
参考: https://blog.csdn.net/mycms5/article/details/78773308
步骤1:检查并安装postfix软件包
bash
[root@svr7 ~]# yum -y install postfix
[root@svr7 ~]# rpm -q postfix
postfix-2.10.1-6.el7.x86_64
步骤2:修改配置文件
bash
[root@svr7 ~]# vim /etc/postfix/main.cf
...
99 myorigin = qq.com //默认补全的域名后缀(比如anjian@域名后缀)
116 inet_interfaces = all //设置允许本机所有接口均提供邮件收发功能
164 mydestination = qq.com //判断是否为本域邮件的依据
...
步骤3:重启postfix服务
bash
[root@svr7 ~]# systemctl restart postfix.service
[root@svr7 ~]# netstat -anptu | grep :25
tcp 0 0 0.0.0.0:25 0.0.0.0:* LISTEN 6098/master
tcp6 0 0 :::25 :::* LISTEN 6098/master
2)使用mail命令收发邮件
Mail发信操作
-
格式:mail -s '邮件标题' [-r 发件人] 收件人[@收件域]...
-
选项:[-r] 指定发件人 //默认为root
Mail收信操作
- 格式:mail [-u 用户名] //不加用户名,则显示root用户的邮件
补充:postfix自带功能,当配置文件误操作或有报错时,服务将发邮件反馈通知root,查看命令:# mail -u root
例如1:
[root@svr7 ~]# useradd yg //添加用户yg和aj [root@svr7 ~]# useradd aj [root@svr7 ~]# mail -s 'test01' -r aj yg //mail发信操作 hello world . //一行只有一个点表示提交 EOT [root@svr7 ~]# mail -u yg //mail收信操作 Heirloom Mail version 12.5 7/5/10. Type ? for help. "/var/mail/yg": 1 message 1 new //存放在目录/var/mail/yg >N 1 aj@qq.com Thu Mar 18 14:34 18/500 "test01" & 1 //输入邮件编号,读取邮件内容 Message 1: From aj@qq.com Thu Mar 18 14:34:24 2021 Return-Path: <aj@qq.com> X-Original-To: yg Delivered-To: yg@qq.com Date: Thu, 18 Mar 2021 14:34:24 +0800 From: aj@qq.com To: yg@qq.com Subject: test01 //标题"test01" User-Agent: Heirloom mailx 12.5 7/5/10 Content-Type: text/plain; charset=us-ascii Status: R hello world //邮件内容 & quit //退出mail工具 Held 1 message in /var/mail/yg
例如2:利用管道非交互式发信操作
bash
[root@svr7 ~]# useradd yg //添加用户yg和aj
[root@svr7 ~]# useradd aj
[root@svr7 ~]# mail -s 'test01' -r aj yg //mail发信操作
hello world
. //一行只有一个点表示提交
EOT
[root@svr7 ~]# mail -u yg //mail收信操作
Heirloom Mail version 12.5 7/5/10. Type ? for help.
"/var/mail/yg": 1 message 1 new //存放在目录/var/mail/yg
>N 1 aj@qq.com Thu Mar 18 14:34 18/500 "test01"
& 1 //输入邮件编号,读取邮件内容
Message 1:
From aj@qq.com Thu Mar 18 14:34:24 2021
Return-Path: <aj@qq.com>
X-Original-To: yg
Delivered-To: yg@qq.com
Date: Thu, 18 Mar 2021 14:34:24 +0800
From: aj@qq.com
To: yg@qq.com
Subject: test01 //标题"test01"
User-Agent: Heirloom mailx 12.5 7/5/10
Content-Type: text/plain; charset=us-ascii
Status: R
hello world //邮件内容
& quit //退出mail工具
Held 1 message in /var/mail/yg
五、自定义YUM仓库
1.作为Yum源需要准备内容:
- 大量的RPM(.rpm)软件安装包文件
- 针对这些软件包的repodata仓库档案(仓库数据文件)
2.repodata仓库档案数据
- Filelists.xml.gz //软件包的文件安装清单
- Primary.xml.gz //软件包的基本/主要信息
- Other.xml.gz //软件包的其他信息
- Repomd.xml //提供.xml.gz下载和检验信息
示例:构建及配置自定义YUM仓库
步骤1:搜集.rpm包文件集中到指定目录
1)将真机准备的tools.tar.gz压缩包传递到虚拟机-主机1(互联网下载软件包)
bash
[root@localhost 桌面]# ls /linux-soft/1 //达内真机每阶段软件包存放目录
cobbler.zip podman tools.tar.gz
[root@localhost 桌面]# scp /linux-soft/1/tools.tar.gz root@192.168.4.7:/root
root@192.168.4.7's password:
tools.tar.gz 100% 766KB 34.8MB/s 00:00
2)查看虚拟机-主机1,检查tools.tar.gz压缩包
bash
[root@svr7 ~]# ls /root/
anaconda-ks.cfg named.conf 公共 视频 文档 音乐
initial-setup-ks.cfg tools.tar.gz 模板 图片 下载 桌面
[root@svr7 ~]# tar -tf /root/tools.tar.gz //查看tools.tar.gz压缩包内容
tools/
tools/other/
tools/other/ntfs-3g-2014.2.15-6.el6.x86_64.rpm
tools/other/boxes-1.1.1-4.el7.x86_64.rpm
tools/other/sl-5.02-1.el7.x86_64.rpm
tools/other/oneko-1.2-19.fc24.x86_64.rpm
tools/other/cmatrix-1.2a-1.i386.rpm
tools/inotify-tools-3.13.tar.gz
步骤2:释放压缩包并找到/tools/other目录作为仓库档案目录
bash
[root@svr7 ~]# tar -xf /root/tools.tar.gz -C / //释放压缩包到根目录(或其他目录)
[root@svr7 ~]# ls /
1.txt boot etc lib media mydvd proc run srv tmp usr
bin dev home lib64 mnt opt root sbin sys tools var
[root@svr7 ~]# ls /tools/
inotify-tools-3.13.tar.gz other
[root@svr7 ~]# ls /tools/other/
boxes-1.1.1-4.el7.x86_64.rpm oneko-1.2-19.fc24.x86_64.rpm
cmatrix-1.2a-1.i386.rpm sl-5.02-1.el7.x86_64.rpm
ntfs-3g-2014.2.15-6.el6.x86_64.rpm
步骤3:使用createrepo工具创建仓库档案(仓库数据文件)
bash
[root@svr7 ~]# createrepo /tools/other/ //生成仓库数据文件
Spawning worker 0 with 3 pkgs
Spawning worker 1 with 2 pkgs
Workers Finished
Saving Primary metadata
Saving file lists metadata
Saving other metadata
Generating sqlite DBs
Sqlite DBs complete
[root@svr7 ~]# ls /tools/other/
boxes-1.1.1-4.el7.x86_64.rpm oneko-1.2-19.fc24.x86_64.rpm
cmatrix-1.2a-1.i386.rpm repodata
ntfs-3g-2014.2.15-6.el6.x86_64.rpm sl-5.02-1.el7.x86_64.rpm
[root@svr7 ~]# ls /tools/other/repodata/
4510d89472a46087687deedb43b44038238c057d85b0acd4d792dd276752ec31-other.sqlite.bz2
5c773aae466acfbcb92fc88af147ae313998ef4afe649c1e8f9a4442fe382420-primary.xml.gz
679b3de7d30fe5d9d49fd83a847234b13e78704cc85d9e3023db5eae6ef4ff90-filelists.xml.gz
c7a3c785ad26f0c2aa64a252f0a16b5c1822fee51d133203c453686eddca898a-filelists.sqlite.bz2
d9ce0aa24483f8411915398b66e2c8000ec3c5e6f11a83f48efb6885cea57329-other.xml.gz
fe925dbab22913101e0c90af0af2a7ed5d10e202322a729cd222e2895753ef87-primary.sqlite.bz2
repomd.xml
步骤4:修改仓库配置文件
bash
[root@svr7 ~]# vim /etc/yum.repos.d/mydvd.repo //新建repo或修改原repo
[mydvd]
name=mydvd
baseurl=file:///mydvd
enable=1
gpgcheck=0
[myrpm] //修改唯一标识
name=myrpm
baseurl=file:///tools/other //指定Yum仓库的路径
enable=1
gpgcheck=0
[root@svr7 ~]# yum clean all
[root@svr7 ~]# yum repolist
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
mydvd | 3.6 kB 00:00
myrpm | 2.9 kB 00:00
myrpm/primary_db | 4.8 kB 00:00
源标识 源名称 状态
mydvd mydvd 9,911
myrpm myrpm 5
repolist: 9,916
测试YUM仓库:
bash
[root@svr7 ~]# yum -y install sl cmatrix
[root@svr7 ~]# sl //小火车程序
趣味示例如图:
bash
[root@svr7 ~]# cmatrix [-C red] //黑客帝国程序(该程序需要/dev/cdromd的依赖)
趣味示例如图:
扩展:createrepo 命令详解
链接:https://www.jianshu.com/p/59ca879584a1
createrepo 命令,用于创建yum源(软件仓库),即为存放于本地特定位置的众多rpm包建立索引,描述各包所需依赖信息,并形成元数据;
- 格式:createrepo [option]
参数选项说明:
- -u --baseurl 指定Base URL的地址
- -o --outputdir 指定元数据的输出位置
- -x --excludes 指定在形成元数据时需要排除的包
- -i --pkglist 指定一个文件,该文件内的包信息将被包含在即将生成的元数据中,格式为每个包信息独占一行,不含通配符、正则,以及范围表达式。
- -n --includepkg 通过命令行指定要纳入本地库中的包信息,需要提供URL或本地路径。
- -q --quiet 安静模式执行操作,不输出任何信息。
- -g --groupfile 指定本地软件仓库的组划分,范例如下:createrepo -g comps.xml /path/to/rpms
- 注意:组文件需要和rpm包放置于同一路径下。
- -v --verbose 输出详细信息。
- -c --cachedir 指定一个目录,用作存放软件仓库中软件包的校验和信息。当createrepo在未发生明显改变的相同仓库文件上持续多次运行时,指定cachedir会明显提高其性能。
- --update 如果元数据已经存在,且软件仓库中只有部分软件发生了改变或增减,则可用update参数直接对原有元数据进行升级,效率比重新分析rpm包依赖并生成新的元数据要高很多。
- -p --pretty 以整洁的格式输出xml文件。
- -d --database 该选项指定使用SQLite来存储生成的元数据,默认项。
小结:
本篇章节为 【第一阶段】SERVICES-DAY3的学习笔记,可以初步了解到 分离解析介绍、NTP时间服务、基础邮件服务(MX记录)、部署postfix邮件服务器、自定义YUM仓库。除此之外推荐参考相关学习网址:
Tip:毕竟两个人的智慧大于一个人的智慧,如果你不理解本章节的内容或需要相关笔记、视频,可私信小安,请不要害羞和回避,可以向他人请教,花点时间直到你真正的理解