40nginx从单节点 HTTPS 到集群负载均衡

配置DNS劫持

1配置web01为正确的网站

bash 复制代码
[root@web01 conf.d]# cat static.conf 
server {
  listen 80;
  server_name static.com;

    location / {
      root /code/test01;
      index index.html;
}
}


[root@web01 conf.d]# cd -
/code/test01
[root@web01 test01]# cat index.html 
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>我是title</title>
</head>
<body>
<article>
<header>
<h1>我是妹妹</h1>
<p>创建时间:<time pubdate="pubdate">2025/11/17</time></p>
</header>
<p>
<b>Aticle</b>第一次用h5写文章,好他*的紧张...
</p>
<footer>
<p><small>版权所有!</small></p>
</footer>
</article>
</body></html>

2.配置WEB02服务器为劫持网站,配置劫持内容 ,类似黑客劫持

bash 复制代码
[root@web02 conf.d]# cat static.conf 
server {
  listen 80;
  server_name static.com;

    location / {
      proxy_pass http://192.168.74.7;
      proxy_set_header Host $http_host;
      sub_filter '<h1>我是妹妹' '<h1>澳门赌场 德州扑克 牛牛 老虎机随时提现 ';
      sub_filter '<b>Aticle</b>第一次用h5写文章,好他*的紧张...' '<img src="https://img0.baidu.com/it/u=2001165379,4043770015&fm=253&fmt=auto&app=138&f=JPEG?w=634&h=356">';
      sub_filter '<small>版权所有' ' <small>开源';
}

}

配置https

1生成证书

bash 复制代码
[root@web01 nginx]# mkdir -p /etc/nginx/ssl_key
[root@web01 nginx]# cd ssl_key/
[root@web01 ssl_key]# openssl genrsa -idea -out server.key 2048
Generating RSA private key, 2048 bit long modulus
.............................................................+++
......+++
e is 65537 (0x10001)
Enter pass phrase for server.key:         #密码123456
Verifying - Enter pass phrase for server.key:      #密码123456

[root@web01 ssl_key]# openssl req -days 36500 -x509 -sha256 -nodes -newkey rsa:2048 -keyout server.key -out server.crt
Generating a 2048 bit RSA private key
-----
Country Name (2 letter code) [XX]:cn
State or Province Name (full name) []:js
Locality Name (eg, city) [Default City]:js
Organization Name (eg, company) [Default Company Ltd]:laoli
Organizational Unit Name (eg, section) []:laoli
Common Name (eg, your name or your server's hostname) []:static.com
Email Address []:123@qq.com
[root@web01 ssl_key]# pwd
/etc/nginx/ssl_key
[root@web01 ssl_key]# ll
total 8
-rw-r--r--. 1 root root 1367 Nov 16 22:39 server.crt
-rw-r--r--. 1 root root 1704 Nov 16 22:39 server.key

2配置证书

bash 复制代码
[root@web01 conf.d]# cat static.conf 
server {
    listen 80;
    server_name static.com; 
    return 302 https://$server_name$request_uri;  
}

server {
    listen 443 ssl;
    server_name static.com;  
    ssl_certificate /etc/nginx/ssl_key/server.crt;
    ssl_certificate_key /etc/nginx/ssl_key/server.key;  
    root /code/test01/; 
    
    location / {
        index index.html index.htm;  
    }

}

3配置成功

集群环境中实现 HTTPS

负载均衡器终结 HTTPS

1安装 Nginx 并准备 SSL 证书(放在/ssl_key目录)

bash 复制代码
[root@localhost ssl_key]# ls
server.crt  server.key  

2配置文件(/etc/nginx/conf.d/static.conf

bash 复制代码
[root@localhost conf.d]# cat static.conf 
upstream webs {
  server 192.168.74.7;
  server 192.168.74.8;
}
 
server {
listen 80;
server_name static.com;
return 302 https://$server_name$request_uri;} 

server {
  listen 443 ssl;
  ssl_certificate /ssl_key/server.crt;
  ssl_certificate_key /ssl_key/server.key;
  server_name static.com;

location / {
    proxy_pass http://webs;
    include proxy_params;
}

}

3后端 Web 节点(web01、web02)配置

无需 SSL 证书,仅需提供 HTTP 服务:

bash 复制代码
# web01和web02的配置(/etc/nginx/conf.d/static.conf)
server {
    listen 80;
    server_name static.com;  # 与负载均衡器域名一致
    root /code/test01;  # 静态文件目录(两台节点内容保持一致)
    location / {
        index index.html;
    }
}

这是我的个人学习笔记,主要用于记录自己对知识点的理解和梳理。由于目前仍在学习探索阶段,内容中难免存在理解偏差或表述疏漏,恳请各位大佬不吝赐教,多提宝贵意见~ 若有不同看法,欢迎理性交流探讨,感谢包容与指正!

相关推荐
忘了ʷºᵇₐ3 小时前
在IDEA 2024.1版本中如何打开Remote Host及连接linux
linux·运维·服务器
零K沁雪4 小时前
Linux 内核中与网络地址相关的函数
linux·内核
steins_甲乙6 小时前
# 从 0 做一个小型内存泄漏检测器:开篇与架构设计
linux
蒸蒸yyyyzwd7 小时前
后端学习笔记 day4
linux·笔记·学习
upp7 小时前
[最新版本centos 10系统制作与安装]
linux·运维·centos
一战成名9967 小时前
ToDesk全球节点 vs TeamViewer、AnyDesk延迟与稳定性对比
运维·服务器·teamviewer
ShineWinsu8 小时前
对于Linux:进程优先级、进程切换以及进程调度的解析
linux·面试·笔试·进程·进程切换·进程调度·进程优先级
Kira Skyler9 小时前
kprobe函数入口时的汇编跳板执行流程与栈帧机制
linux·汇编
桌面运维家9 小时前
VHD/VHDX 数据守护:BAT位图校验与修复
linux·服务器·网络
pupudawang9 小时前
Linux下安装Nginx服务及systemctl方式管理nginx详情
linux·运维·nginx