LInux mkcert 制作本地ssl证书,配置nginx 支持https

一、安装前准备
  1. 安装依赖工具

    bash 复制代码
    # Ubuntu/Debian
    sudo apt install libnss3-tools wget
    # CentOS/RHEL
    sudo yum install nss-tools wget
二、安装方法选型
‌**方法 1:二进制直接安装(推荐)**‌
bash 复制代码
# 下载最新版二进制文件(以 v1.4.4 为例)
wget https://github.com/FiloSottile/mkcert/releases/download/v1.4.4/mkcert-v1.4.4-linux-amd64

# 赋予执行权限并全局安装
chmod +x mkcert-v1.4.4-linux-amd64
sudo mv mkcert-v1.4.4-linux-amd64 /usr/local/bin/mkcert

方法 2:Go 环境编译安装

bash 复制代码
# 安装 Golang
sudo apt install golang-go

# 通过 Go 安装 mkcert
go install filippo.io/mkcert@latest

# 添加环境变量
echo 'export PATH="$PATH:$(go env GOPATH)/bin"' >> ~/.bashrc
source ~/.bashrc
三、初始化证书颁发机构
bash 复制代码
# 安装本地根证书
sudo mkcert -install
# 验证根证书位置
mkcert -CAROOT

生成的根证书默认位于 /root/.local/share/mkcert 或当前用户目录 ‌45

四、生成 SSL 证书
bash 复制代码
mkcert 192.168.1.100 localhost  # 为指定 IP/域名生成证书

自动生成 192.168.1.100.pem192.168.1.100-key.pem,浏览器无警告‌

五、配置证书路径

bash 复制代码
sudo mkdir -p /etc/nginx/ssl
sudo cp 192.168.1.100.pem /etc/nginx/ssl/
sudo cp 192.168.1.100-key.pem /etc/nginx/ssl/

六、Nginx 配置

创建配置文件

配置nginx /etc/nginx/nginx.conf

bash 复制代码
server {
    listen 443 ssl;
    server_name 192.168.1.100 local.example;

    # 证书配置
    ssl_certificate /etc/nginx/ssl/192.168.1.100.pem;
    ssl_certificate_key /etc/nginx/ssl/192.168.1.100-key.pem;

    # 安全增强配置
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256;
    ssl_prefer_server_ciphers on;

    # 反向代理到本地服务(示例:FastAPI应用)
    location / {
        proxy_pass http://127.0.0.1:8000;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
}

重启nginx

bash 复制代码
#方法一 正常重启
nginx -s reload
#方法二 系统服务重启
systemctl restart nginx
相关推荐
ImAlex33 分钟前
Linux脚本实现自动化运维任务实战案例:系统自动备份、日志轮转、系统更新、资源监控、自动化定时任务调度
linux·运维
杨凯凡1 小时前
Linux日志分析:安全运维与故障诊断全解析
linux·运维·服务器
愚润求学2 小时前
【Linux】进程优先级和进程切换
linux·运维·服务器·c++·笔记
jianghx10242 小时前
Centos 7 ssh连接速度慢(耗时20秒+)
linux·centos·ssh
岁月不能老2 小时前
Linux-Part8-考试(学习Linux第8天)
linux·运维·学习
ImAlex3 小时前
如何使用gcc的-finstrument-functions特性通过打印函数调用栈辅助理解复杂C/C++项目的函数调用关系
linux·c语言
马大胡子3 小时前
Greenbone(绿骨)开源GVM容器docker部署和汉化介绍
linux·网络安全·docker
用户217516114383 小时前
【Linux】软硬连接与动静态库
linux
奶油话梅糖4 小时前
LS-Linux-004 误删 Python 和 yum、dnf 后的恢复步骤
linux
和煦的春风4 小时前
案例分析 | SurfaceFlinger 大片Runnable引起的卡顿
android·linux