【RHCE实验】搭建主从DNS、WEB等服务器

目录

需求

环境搭建

配置nfs服务器

配置web服务器

配置主从dns服务器

主dns服务器

从dns服务器

 配置客户端

客户端测试


需求

客户端通过访问 www.nihao.com 后,能够通过 dns 域名解析,访问到 nginx 服务中由 nfs 共享的首页文件,内容为:Very good, you have successfully set up the system. 各个主机能够实现时间同步,并且都开启防火墙来保证服务安装。

 

环境搭建

准备五台redhat9.5虚拟机,并配置IP、修改主机名、安装相应软件。

虚拟机统一操作

//搭建本地仓库
[root@localhost ~]# cat > /etc/yum.repos.d/bendi.repo << EOF
> [base]
> name=base
> baseurl=/mnt/BaseOS
> gpgcheck=0
> [app]
> name=app
> baseurl=/mnt/AppStream
> gpgcheck=0
> EOF[root@localhost ~]# mount /dev/sr0 /mnt//安装部分常用软件
[root@localhost ~]# yum install vim make gcc tree net-tools tar -y//tab补全执行这个文件后才生效
[root@localhost ~]# source /usr/share/bash-completion/bash_completion//永久修改selinux为宽容模式
[root@localhost ~]# sed -i 's/^SELINUX=enforcing$/SLEINUX=permissive/' /etc/selinux/config

WEB服务器

[root@localhost ~]# hostnamectl hostname web-server[root@localhost ~]# nmcli connection modify ens160 ipv4.addresses 192.168.239.8/24 ipv4.gateway 192.168.239.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes[root@web-server ~]# dnf install -y nginx

 NFS服务器

[root@localhost ~]# hostnamectl hostname nfs-server[root@localhost ~]# nmcli connection modify ens160 ipv4.addresses 192.168.239.9/24 ipv4.gateway 192.168.239.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes[root@nfs-server ~]# dnf install -y nfs-utils

主DNS服务器

[root@localhost ~]# hostnamectl hostname dns-master-server[root@localhost ~]# nmcli connection modify ens160 ipv4.addresses 192.168.239.18/24 ipv4.gateway 192.168.239.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes[root@dns-master-server ~]# dnf install -y bind

从DNS服务器

[root@localhost ~]# hostnamectl hostname dns-slave-server[root@localhost ~]# nmcli connection modify ens160 ipv4.addresses 192.168.239.28/24 ipv4.gateway 192.168.239.2 ipv4.dns 223.5.5.5 ipv4.method manual connection.autoconnect yes[root@dns-slave-server ~]# dnf install -y bind

客户机

[root@localhost ~]# hostnamectl hostname client[root@localhost ~]# nmcli connection modify ens160 ipv4.addresses 192.168.239.7/24 ipv4.gateway 192.168.239.2 ipv4.dns "192.168.239.18 192.168.239.28" ipv4.method manual connection.autoconnect yes

 至此,基本环境已搭建完毕。

 

配置nfs服务器

[root@nfs-server ~]# mkdir /nfs/data -p[root@nfs-server ~]# cat > /etc/exports << EOF
> /nfs/data 192.168.239.8(rw)
> EOF[root@nfs-server ~]# chmod o+w /nfs/ -R
# 给共享的文件增加些权限[root@nfs-server ~]# firewall-cmd --permanent --add-service=nfs[root@nfs-server ~]# firewall-cmd --reload[root@nfs-server ~]# systemctl enable --now nfs-server[root@nfs-server ~]# showmount -e 192.168.239.9
Export list for 192.168.239.9:
/nfs/data 192.168.239.8

题目没有特别要求,这里将192.168.239.9也作为ntp服务器

[root@nfs-server ~]# vim /etc/chrony.conf

 

服务器端修改配置文件的26行和50行,第三行看情况修改

[root@nfs-server ~]# systemctl restart chronyd[root@nfs-server ~]# firewall-cmd --permanent --add-service=ntp[root@nfs-server ~]# firewall-cmd --reload

配置web服务器

[root@web-server ~]# mkdir /var/www[root@web-server ~]# mount -t nfs 192.168.239.9:/nfs/data /var/www//测试nfs网络文件挂载
[root@web-server ~]# df -h
...
192.168.239.9:/nfs/data   35G  1.8G   33G   6% /var/www//修改nginx配置文件
[root@web-server ~]# cat > /etc/nginx/conf.d/nihao.conf << EOF
> server {
> server_name www.nihao.com;
> root /var/www/nihao/;
> access_log /var/log/nginx/access.log;
> error_log /var/log/nginx/error.log;
> }
> EOF[root@web-server ~]# mkdir /var/www/nihao[root@web-server ~]# echo "Very good, you have successfully set up the system." > /var/www/nihao/index.html[root@web-server ~]# systemctl enable --now nginx//放行防火墙
[root@web-server ~]# firewall-cmd --permanent --add-service=http[root@web-server ~]# firewall-cmd --reload[root@web-server ~]# vim /etc/chrony.conf //修改第3行与第50行
3 server 192.168.239.9 iburst
50 log measurements statistics tracking[root@web-server ~]# systemctl restart chronyd

时间同步测试

 网页测试

 

配置主从dns服务器

主dns服务器

[root@dns-master-server ~]# vim /etc/named.conf//修改dns主配置文件为以下内容:options {listen-on port 53 { 192.168.239.18; };directory       "/var/named";
};
zone "nihao.com" IN {type master;file "named.nihao";
};//无返回值说明无语法错误
[root@dns-master-server ~]# named-checkconf[root@dns-master-server ~]# vim /var/named/named.nihao//写入dns区域配置文件为以下内容:
$TTL 1D
@       IN      SOA     @       admin.nihao.com.        ( 0 1D 2H 3W 2D )IN      NS      ns1IN      NS      ns2
ns1     IN      A       192.168.239.18
ns2     IN      A       192.168.239.28
www     IN      A       192.168.239.8//检查区域文件有无语法错误
[root@dns-master-server ~]# named-checkzone nihao.com /var/named/named.nihao 
zone nihao.com/IN: loaded serial 0
OK[root@dns-master-server ~]# systemctl enable --now named[root@dns-master-server ~]# firewall-cmd --permanent --add-service=dns[root@dns-master-server ~]# firewall-cmd --reload[root@dns-master-server ~]# vim /etc/chrony.conf//修改第3行与第50行
3 server 192.168.239.9 iburst
50 log measurements statistics tracking[root@dns-master-server ~]# systemctl restart chronyd

时间同步测试 

dig测试 

 

从dns服务器

[root@dns-slave-server ~]# vim /etc/named.conf//修改主配置文件为以下内容:
options {listen-on port 53 { 192.168.239.28; };directory       "/var/named";
};
zone "nihao.com" IN {type slave;masters { 192.168.239.18; };file "slaves/named.nihao";
};[root@dns-slave-server ~]# firewall-cmd --permanent --add-service=dns[root@dns-slave-server ~]# firewall-cmd --reload//启动服务后自动会自动生成区域文件
[root@dns-slave-server ~]# systemctl enable --now named[root@dns-slave-server ~]# ls /var/named/slaves/
named.nihao[root@dns-slave-server ~]# vim /etc/chrony.conf//修改第3行与第50行
3 server 192.168.239.9 iburst
50 log measurements statistics tracking[root@dns-slave-server ~]# systemctl restart chronyd

 时间同步测试

dig测试

 配置客户端

[root@client ~]# vim /etc/chrony.conf//修改第3行与第50行
3 server 192.168.239.9 iburst
50 log measurements statistics tracking[root@client ~]# systemctl restart chronyd

时间同步测试 

 

客户端测试

至此实验完成!! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/73733.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Shell条件判断

一、使用if选择结构 if单分支的语法组成&#xff1a; if 条件测试;then 命令序列 fi if双分支的语法组成&#xff1a; if 条件测试;then 命令序列1 else 命令序列2 fi if多分支的语法组成&#xff1a; if 条…

理解langchain langgraph 官方文档示例代码中的MemorySaver

以下是langchain v0.3官方示例代码 from langgraph.checkpoint.memory import MemorySaver from langgraph.graph import START, MessagesState, StateGraph# 可以理解为&#xff1a;定义一个流程&#xff0c;这个流程中用到的数据类型是Messages。 <---定义一个有向图&…

【HarmonyOS Next之旅】DevEco Studio使用指南(三)

目录 1 -> 一体化工程迁移 1.1 -> 自动迁移 1.2 -> 手动迁移 1.2.1 -> API 10及以上历史工程迁移 1.2.2 -> API 9历史工程迁移 1 -> 一体化工程迁移 DevEco Studio从 NEXT Developer Beta1版本开始&#xff0c;提供开箱即用的开发体验&#xff0c;将SD…

vuex持久化存储,手动保存到localStorage

vuex持久化存储&#xff0c;手动保存到localStorage 一、vue21. 手动存储到localStoragestore/index.js 2. 使用持久化存储插件store/index.jsstore/modules/otherData.js保存到localStorage 二、vue31. index.ts2. store/modules/globalData.ts3. 在组件中使用App.vue 一、vue…

nodejs使用 mysql2 模块获取 mysql 中的 json字段,而不是 mysql

mysql 模块获取的 json 字段&#xff0c;是字符串mysql2 模块获取的 json 字段&#xff0c;是符合预期的 json 对象 mysql mysql2 最后编辑于&#xff1a;2025-02-24 22:16:53 © 著作权归作者所有,转载或内容合作请联系作者 喜欢的朋友记得点赞、收藏、关注哦&#xff01;…

鸿蒙(OpenHarmony)开发实现 息屏/亮屏 详情

官网参考链接 实现点击关闭屏幕&#xff0c;定时5秒后唤醒屏幕 权限 {"name": "ohos.permission.POWER_OPTIMIZATION"}代码实现 import power from ohos.power;Entry Component struct Page3 {private timeoutID: number | null null; // 初始化 timeout…

【网工第6版】第1章 计算机网络概论

目录 1计算机网络形成和发展 ■计算机网络 ■我国互联网发展 ■计算机网路分类 ■计算机网络应用 2 OSI和TCP/IP参考模型 ■网络分层的意义 ■OSI参考模型 ■TCP/IP参考模型 ■TCP/IP参考模型协议 3 数据封装与解封过程 ■封装 ■解封 1计算机网络形成和发展 ■计…

理解我们单片机拥有的资源

目录 为什么要查询单片机拥有的资源 所以&#xff0c;去哪些地方可以找数据手册 一个例子&#xff1a;STM32F103C8T6 前言 本文章隶属于项目&#xff1a; Charliechen114514/BetterATK: This is a repo that helps rewrite STM32 Common Repositorieshttps://github.com/C…

《我的Python觉醒之路》之转型Python(十五)——控制流

[今天是2025年3月17日&#xff0c;继续复习第一章节、第二章节的内容 ] 《我的Python觉醒之路》之转型Python&#xff08;十四&#xff09;——控制流

AndroidStudio+Android8.0下的Launcher3 导入,编译,烧录,调试

文章目录 编译完成搜索输出文件Android.mk配置gradle编译环境报错一报错二报错三输出文件下载INSTALL_FAILED_TEST_ONLY查找系统签名查找签名工具开始签名查看签名签名问题重新生成秘钥解决方案生成成功挽救错误:重新刷机更换testkey秘钥keystore生成keystoreINSTALL_FAILED_S…

Linux--gdb/cgdb

ok&#xff0c;我们今天学习gdb的安装和使用 调试器-gdb/cgdb使用 VS、VScode编写的代码一般都是release格式的&#xff0c;gdb 的格式一般是debug 换成debug模式命令 :-g gdb会记录最新的一条命令&#xff0c;直接回车就是默认执行该命令 一个调试周期下&#xff0c;断点…

Oracle GoldenGate 全面解析

Oracle GoldenGate 全面解析 Oracle GoldenGate 是一种实时数据集成和复制解决方案,广泛应用于数据同步、数据库迁移、高可用性和灾难恢复等场景。以下将详细解答您提出的关于 Oracle GoldenGate 的一系列问题。 1. Oracle GoldenGate 的架构组成及其核心组件的作用 架构组成…

ModBus TCP/RTU互转(主)(从)|| Modbus主动轮询下发的工业应用 || 基于智能网关的串口服务器进行Modbus数据收发的工业应用

目录 前言 一、ModBus TCP/RTU互转&#xff08;从&#xff09;及应用|| 1.1 举栗子 二、ModBus TCP/RTU互转&#xff08;主&#xff09; 2.1 举栗子 三、ModBus 主动轮询 3.1 Modbus主动轮询原理 3.2 Modbus格式上传与下发 3.2.1.设置Modbus主动轮询指令 3.2.2 设…

场景题:一个存储IP地址的100G 的文件, 找出现次数最多的 IP ?

和大文件中存id&#xff0c;然后要求排序问题一样的处理思路 使用MapReduce的思想解决&#xff0c;加上哈希分割&#xff0c;先将大文件中的IP地址按照哈希函数进行分割&#xff0c;存到多个文件上&#xff0c;接着每个分片单独处理&#xff0c;用Hashmap统计IP出现频次&#…

【操作系统安全】任务2:用户与用户组

目录 一、用户与用户组介绍 1.1 用户 1.2 用户组 1.3 用户与用户组的关系 二、用户与用户组管理 2.1 用户管理 2.1.1 创建用户 2.1.2 设置用户密码 2.1.3 删除用户 2.2 用户组管理 2.2.1 创建用户组 2.2.2 删除用户组 2.2.3 将用户添加到用户组 三、影子账户创建…

OpenCV计算摄影学(20)非真实感渲染之增强图像的细节函数detailEnhance()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 此滤波器增强特定图像的细节。 cv::detailEnhance用于增强图像的细节&#xff0c;通过结合空间域和频率域的处理&#xff0c;提升图像中特定细节…

Git 使用指南

Git 是一种分布式版本控制系统&#xff0c;可以追踪文件的变化并协助多人协作开发项目。下面是 Git 的基本概念和使用方式&#xff1a; 仓库&#xff08;Repository&#xff09;&#xff1a;Git 用来存储项目的地方&#xff0c;可以理解为项目的文件夹&#xff0c;包含项目的所…

java 中散列表(Hash Table)和散列集(Hash Set)是基于哈希算法实现的两种不同的数据结构

在 Java 中&#xff0c;散列表&#xff08;Hash Table&#xff09;和散列集&#xff08;Hash Set&#xff09;是两种不同的数据结构&#xff0c;但它们都基于哈希表的原理来实现。下面是它们的联系与区别、实现类以及各自的优缺点&#xff0c;并用表格进行对比整理。 联系与区…

vue2自定义指令实现 el-input 输入数字,小数点两位 最高10位,不满足则截取符合规则的值作为新值

步骤 1&#xff1a;创建自定义指令 // 处理输入值&#xff0c;确保符合规则 function processValue(value) {// 过滤非数字和小数点let filtered value.replace(/[^\d.]/g, );const firstDotIndex filtered.indexOf(.);// 处理多个小数点&#xff0c;保留第一个if (firstDot…

10、基于osg引擎生成热力图高度图实现3D热力图可视化、3D热力图实时更新(带过渡效果)

1、结果 2、完整C代码 #include <sstream> #include <iomanip> #include <iostream> #include <vector> #include <random> #include <cmath> #include <functional> #include <osgViewer/viewer> #include <osgDB/Read…