Nginx HTTPS服务搭建实验

实验目的

  • 配置Nginx服务器支持HTTPS访问

  • 实现HTTP到HTTPS的自动重定向

  • 配置基本的HTTP认证功能

  • 配置防火墙开放相应端口

实验步骤

1、创建SSL证书和密钥

命令

bash 复制代码
openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout lyh.key -out lyh.crt

openssl 是一个强大的加密工具包

req 表示创建或处理证书请求

-x509 说明我们要创建自签名证书,不需要CA签名

-nodes 表示生成的私钥不加密,这样Nginx读取时就不需要密码

-days 365 设置证书有效期为365天,也就是一年

-newkey rsa:2048 同时生成新的证书请求和2048位RSA私钥

-keyout lyh.key 指定私钥文件的保存路径和名称

-out lyh.crt 指定证书文件的保存路径和名称

2. 创建密码文件用于HTTP认证

在当前目录创建密码文件,用户名为admin,密码为admin123

bash 复制代码
echo "admin:`openssl passwd -apr1 admin123`" > passwd

验证密码文件是否成功创建

bash 复制代码
cat passwd

3. 将密码文件复制到Nginx配置目录并设置权限

将密码文件复制到/etc/nginx/passwd

bash 复制代码
cp passwd /etc/nginx/passwd

设置密码文件权限为644

bash 复制代码
chmod 644 /etc/nginx/passwd

验证密码文件是否成功复制

bash 复制代码
ls -la /etc/nginx/passwd

4. 创建完整的Nginx HTTPS配置文件

创建文件:nginx_https.conf,内容如下:

bash 复制代码
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

    server {
        listen       80;
        server_name  _;
        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location / {
        }

        error_page 404 /404.html;
            location = /40x.html {
        }

        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
    }

    # HTTPS server configuration
    server {
        listen 443 ssl http2;
        server_name www.haqimi.com www.manbo.com;
        root /usr/share/nginx/html;

        # SSL certificate configuration
        ssl_certificate /etc/nginx/ssl/lyh.crt;
        ssl_certificate_key /etc/nginx/ssl/lyh.key;

        # SSL protocol and cipher configuration
        ssl_protocols TLSv1.2 TLSv1.3;
        ssl_prefer_server_ciphers on;
        ssl_ciphers "ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-CHACHA20-POLY1305";
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout 10m;

        # HTTP Basic Authentication
        auth_basic "input your passwd";
        auth_basic_user_file /etc/nginx/passwd;

        location / {
            index index.html index.htm;
        }
    }

    # HTTP to HTTPS redirect
    server {
        listen 80;
        server_name www.haqimi.com www.manbo.com;
        return 301 https://$host$request_uri;
    }
}

5. 创建SSL证书目录并复制证书文件

创建SSL证书目录

bash 复制代码
mkdir -p /etc/nginx/ssl

复制证书和密钥到SSL目录

bash 复制代码
cp lyh.crt /etc/nginx/ssl/
cp lyh.key /etc/nginx/ssl/

6.重启Nginx服务且防火墙配置

重启Nginx服务以应用新配置

bash 复制代码
systemctl restart nginx

检查Nginx服务状态

bash 复制代码
systemctl status nginx

测试Nginx配置文件语法是否正确

bash 复制代码
nginx -t

开放80端口(HTTP)

bash 复制代码
firewall-cmd  --add-port=80/tcp

开放443端口(HTTPS)

bash 复制代码
firewall-cmd  --add-port=443/tcp

重新加载防火墙配置

bash 复制代码
firewall-cmd --reload

验证防火墙规则

bash 复制代码
firewall-cmd --list-ports

7.配置本地域名解析

添加域名解析记录到/etc/hosts

bash 复制代码
echo "127.0.0.1 www.haqimi.com www.manbo.com" >> /etc/hosts

验证域名解析配置

bash 复制代码
tail -n 5 /etc/hosts

验证

简单用命令测试

bash 复制代码
curl -I http://www.haqimi.com

接着用浏览器打开看看

这时候就会弹登陆窗出来,完成验证就证明配置没有问题。

相关推荐
森焱森11 小时前
详解 Spring Boot、Flask、Nginx、Redis、MySQL 的关系与协作
spring boot·redis·python·nginx·flask
70asunflower11 小时前
用Docker创建不同的容器类型
运维·docker·容器
2501_9336707911 小时前
中专学财务,2026年就业方向全解析:从出纳到财务BP的进阶路
运维·服务器
Dovis(誓平步青云)11 小时前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
迎仔11 小时前
05-计算设备运维进阶:算力中心的设备医生
运维
石去皿12 小时前
【嵌入式就业10】Linux内核深度解析:从启动流程到驱动框架的工业级实践
linux·运维·服务器
Wpa.wk12 小时前
接口自动化 - 多环境统一文件配置 +多响应统一转换处理
运维·服务器·测试工具·自动化·接口自动化·统一配置
Trouvaille ~12 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层
是枚小菜鸡儿吖12 小时前
从 0 到 1 生成自定义算子:CANN + AIGC 的自动化工作流
运维·自动化·aigc
考琪12 小时前
Nginx打印变量到log方法
java·运维·nginx