RHCE 练习二:通过 ssh 实现两台主机免密登录以及 nginx 服务通过多 IP 区分多网站

news2025/4/23 22:46:53

一、题目要求

1.配置ssh实现A,B主机互相免密登录

2.配置nginx服务,通过多ip区分多网站

二、实验

实验开始前需准备两台 linux 主机便于充当服务端以及客户端,两台主机 IP 如下图:

实验1:配置 ssh 实现 A,B 主机互相免密登录

第一种情况:192.168.96.142 为服务端,192.168.96.132 为客户端


1. 首先关闭服务端 142 的防火墙以及 selinux,我们可以通过查看防火墙以及 selinux 的状态来判断我们是否成功关闭这两个程序

[root@server ~]# systemctl stop firewalld   # 此次主机运行期间关闭防火墙
[root@server ~]# setenforce 0   # 关闭 selinux

2.在客户端 132 利用非对称算法 RSA 生成密钥

[root@client ~]# ssh-keygen -t RSA
[root@client ~]# ll /root/.ssh/

3.将当前主机公钥发送到目标主机 root 用户的家目录下的 .ssh/authorized_keys

[root@client ~]# ssh-copy-id  root@192.168.96.142

4.客户端 132 登录服务端142主机实现免密登录

第二种情况:192.168.96.142 为客户端,192.168.96.132 为服务端

注:第一种情况做法写的很清楚,第二种情况将第一种情况的主机客户端与服务端交换即可

1.我们还是先将服务端 132 的防火墙以及 selinux 关闭

2.在客户端 142 利用非对称算法 RSA 生成密钥

3.将当前主机公钥发送到目标主机 root 用户的家目录下的 .ssh/authorized_keys

4.客户端 142 登录服务端 132 主机实现免密登录

至此,咱们实现了两台 linux 主机之间的免密互联!

实验2:配置nginx服务,通过多ip区分多网站

1.关闭服务器 142 的防火墙以及 selinux

[root@server ~]# systemctl stop firewalld
[root@server ~]# setenforce 0

2.通过 mount 将光盘挂载,如若失败可检查 CD/DVD 光盘是否正常连接

[root@server ~]# mount /dev/sr0 /mnt

3.通过 ll 命令查看 yum 源仓库配置文件,之后利用 vim 编辑该文件

① 查看文件

[root@server ~]# ll /etc/yum.repos.d/base.repo

② 编辑文件

[root@server ~]# vim /etc/yum.repos.d/base.repo
[BaseOS]    # 路径的标识名
name=BaseOS    # 描述名
baseurl=file:///mnt/BaseOS    # 定义yum源的统一资源定位符,路径
gpgcheck=0    # 关闭软件包的 GPG 签名验证
enabled=1    # 是否开启该仓库 1为开启,0为关闭
[AppStream]
name=AppStream
baseurl=file:///mnt/AppStream
gpgcheck=0
enabled=1

4.dnf 安装软件包,这里因为已经下载过,所以显示已安装

[root@server ~]# dnf install nginx -y

5.安装完成后启动 nginx 程序并查看该程序状态,显示 Active: active (running) 则表示程序启动成     功

[root@server ~]# systemctl start nginx
[root@server ~]# systemctl status nginx

6.在 Windows 系统下任意浏览器进行网址访问(http://192.168.96.142,网址为 linux 服务端 IP)

7.利用 nmtui 图形化的命令来配置多个 IP 地址

   ① 首先进入到选项中选择编辑连接

[root@server ~]# nmtui

   ② 选择欲编辑的以太网点击编辑

   ③ 这里需要强调的都在图中说明,编辑完成即可退出;如果网关未显示,可在 linux 终端查询本机默认网关,这里默认网关为 192.168.96.2;还有一点为记得将 IPV4 配置从自动改为手动

[root@server ~]# ip route show default

   ④ 确认退出后需激活网卡信息,可以看到我们添加的多个 IP 都已经成功激活

[root@server ~]# nmcli connection up ens33    # 激活网卡
[root@server ~]# ip a    # 查看当前所有网络接口的详细信息

8. 通过多 IP 区分多网站,需要注意的是每行代码写完都要加分号!

[root@server ~]# vim /etc/nginx/conf.d/ip.conf   # 进入nginx配置文件
server {
        listen 80;
        server_name 192.168.96.142;
        root /www;
        location / {
                index  index.html;
        }
}
server {
        listen 80;
        server_name 192.168.96.100;
        root /www/100;
        location / {
                index  index.html;
        }
}
server {
        listen 80;
        server_name 192.168.96.200;
        root /www/200;
        location / {
                index  index.html;
        }
}

9. 修改配置文件后需重启程序,重启后什么都不显示说明配置没有问题,但不一定能访问成功

[root@server ~]# systemctl restart nginx

10.配置后访问网页发现403错误,此时我们虽然配置了 /www 路径以及 index.html 文件,但是我们没有创建该路径和文件

11.创建 /www 路径以及 index.html 文件,创建好后可刷新页面即可看到我们写入的内容

[root@server ~]# mkdir -pv /www/{100,200}
mkdir: 已创建目录 '/www'
mkdir: 已创建目录 '/www/100'
mkdir: 已创建目录 '/www/200'
[root@server ~]# echo this is 142 > /www/index.html
[root@server ~]# echo this is 100 > /www/100/index.html
[root@server ~]# echo this is 200 > /www/200/index.html

12.访问这三个网页可以看到对应写入的内容

http://192.168.96.142
http://192.168.96.100
http://192.168.96.200

注:查看哪里出问题了可以查看我们的 nginx 服务状态

[root@server ~]# systemctl status nginx.service 

查找文件多少行出现问题,可以在命令模式下输入“:set nu”

查看日志信息排错,最新日志在最后

[root@server ~]# journalctl -xeu nginx.service

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

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

相关文章

瑞吉外卖-分页功能开发中的两个问题

1.分页功能-前端页面展示显示500 原因:项目启动失败 解决:发现是Category实体类中,多定义了一个删除字段,但是我数据库里面没有is_deleted字段,导致查询数据库失败,所以会导致500错误。因为类是从网上其他帖…

工业物联网安全网关 —— 安全OTA升级签名验证

这里写目录标题 工业物联网安全网关 —— 安全OTA升级签名验证一、项目背景与简介1.1 背景介绍1.2 OTA升级的安全挑战1.3 项目目标二、理论基础与关键技术2.1 数字签名基础2.2 OTA升级签名验证原理2.3 关键技术与安全算法三、系统架构设计3.1 系统模块划分3.2 系统架构图(Merm…

探索 Flowable 后端表达式:简化流程自动化

什么是后端表达式? 在 Flowable 中,后端表达式是一种强大的工具,用于在流程、案例或决策表执行期间动态获取或设置变量。它还能实现自定义逻辑,或将复杂逻辑委托…… 后端表达式在 Flowable 的后端运行,无法访问前端…

HDFS入门】HDFS安全与权限管理解析:从认证到加密的完整指南

目录 引言 1 认证与授权机制 1.1 Kerberos认证集成 1.2 HDFS ACL细粒度控制 2 数据加密保护 2.1 传输层加密(SSL/TLS) 2.2 静态数据加密 3 审计与监控体系 3.1 操作审计流程 3.2 安全监控指标 4 权限模型详解 4.1 用户/组权限模型 4.2 umask配置原理 5 安全最佳实…

性能比拼: Go vs Java

本内容是对知名性能评测博主 Anton Putra Go (Golang) vs Java: Performance Benchmark 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准 在本视频中,我们将比较 Go 和 Java。 我们将基于 Golang 的 Fiber 框架和 Java 的 Spring Boot 创建几个简单的应用…

ElMessageBox消息弹框(vue3总结)

一 展示各种内容 const checkCheckbox (check: any, formEl: any) > {ElMessageBox({title: "服务协议及隐私权政策",message: h("p", null, [h("span", null, "我已阅读并同意 "),h("span",{style: "color: #477F…

Jupyter Notebook 中切换/使用 conda 虚拟环境的方式(解决jupyter notebook 环境默认在base下面的问题)

使用 nb_conda_kernels 添加所有环境 一键添加所有 conda 环境 conda activate my-conda-env # this is the environment for your project and code conda install ipykernel conda deactivateconda activate base # could be also some other environment conda in…

Tailwind CSS 开发入门:掌握基础语法要点

在前端开发中,Tailwind CSS 以原子化设计和实用类系统,构建精美页面的得力工具,摒弃传统 CSS 繁琐写法。掌握其基础语法是熟练运用它的关键,下面将详细介绍核心基础语法。 一、核心基础语法 1. 颜色类 Tailwind CSS 提供了丰富…

Java八股 深入理解Spring的AOP 面向切面编程 底层 保姆级教程 手写例子

目录 概念 AOP 术语 1. 连接点(Jointpoint): 2. 切入点(Pointcut): 3. 通知(Advice): 4. 方面/切面(Aspect): 5. 引入&#xff…

C++std::map

1. 概述​​ ​​定义​​:std::map 是C标准模板库(STL)中的关联容器,以键值对(key-value pairs)形式存储元素,支持快速查找和有序访问。 ​​- 头文件​​:#include ​​底层实现​…

dispaly: inline-flex 和 display: flex 的区别

display: inline-flex 和 display: flex 都是 CSS 中用于创建弹性盒子布局(Flexbox)的属性值,但它们之间有一些关键的区别,主要体现在元素如何在页面上被渲染和它们对周围元素的影响。 主要区别 1,块级 vs 行内块级 d…

性能比拼: Elixir vs Go(第二轮)

本内容是对知名性能评测博主 Anton Putra Elixir vs Go (Golang) Performance Benchmark (Round 2) 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准 这是第二轮关于 Elixir 和 Go 的对比测试。我收到了一份来自 Elixir 创作者的 Pull Request ,并且我认为…

【数字图像处理】立体视觉信息提取

双目立体视觉原理 设一个为参考平面,一个为目标平面。增加了一个摄像头后,P与Q在目标面T上有分别的成像点 双目立体视觉:从两个不同的位置观察同一物体,用三角测量原理计算摄像机到该物体的距离的 方法 原理:三角测量…

【漏洞复现】Struts2系列

【漏洞复现】Struts2系列 1. 了解Struts21. Struts2 S2-061 RCE (CVE-2020-17530)1. 漏洞描述2. 影响版本3. 复现过程 1. 了解Struts2 Apache Struts2是一个基于MVC设计模式的Web应用框架,会对某些标签属性(比如 id)的…

Sentinel源码—5.FlowSlot借鉴Guava的限流算法二

大纲 1.Guava提供的RateLimiter限流使用示例 2.Guava提供的RateLimiter简介与设计 3.继承RateLimiter的SmoothBursty源码 4.继承RateLimiter的SmoothWarmingUp源码 3.继承RateLimiter的SmoothBursty源码 (1)SmoothBursty的初始化流程 (2)SmoothBursty的初始化完成后的变量…

重构未来智能:Anthropic 解码Agent设计哲学三重奏

第一章 智能体进化论:从工具到自主体的认知跃迁 1.1 LLM应用范式演进图谱 阶段技术形态应用特征代表场景初级阶段单功能模型硬编码规则执行文本摘要/分类进阶阶段工作流编排多模型协同调度跨语言翻译流水线高级阶段自主智能体动态决策交互编程调试/客服对话 1.1.…

Gradle与Idea整合

文章目录 1. Groovy 简介2. Groovy 安装[非必须]3. 在idea中创建java工程 1. Groovy 简介 在某种程度上,Groovy可以被视为Java的一种脚本化改良版,Groovy也是运行在JVM上,它可以很好地与Java代码及其相关库进行交互操作。它是一种成熟的面向对象编程语言…

基于springboot+vue的校园二手物品交易平台

开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…

OpenCV图像上加数字水印示例

OpenCV计算机视觉开发实践:基于Qt C - 商品搜索 - 京东 14.1 基本概念 当今,生成式人工智能(Artificial Intelligence Generated Content,AIGC)的火爆引燃了数字水印,说实话数字水印并不是一项新的技术&…

Python爬虫从入门到实战详细版教程Char01:爬虫基础与核心技术

1.1 什么是网络爬虫? 1.1.1 定义与分类 网络爬虫:互联网世界的“信息捕手” 网络爬虫(Web Crawler),又称网络蜘蛛或网络机器人,是一种通过预设规则自动访问网页、提取数据的程序系统。从技术视角看,其核心任务是通过模拟浏览器行为向目标服务器发起请求,解析网页内容…