Nginx 域名绑定与 HTTPS 配置指南

绑定域名主要分为 DNS 解析Nginx 配置 两个环节。

第一步:设置 DNS 解析

你需要登录你的域名注册商后台(如阿里云、腾讯云、Cloudflare、GoDaddy 等):

  1. 找到 DNS 解析设置 (DNS Management)

  2. 添加两条记录:

    • A 记录 :主机记录填 @,记录值填你的 服务器公网 IP

    • A 记录 :主机记录填 www,记录值填你的 服务器公网 IP

  3. 等待解析生效(通常几分钟到几小时不等)。

第二步:修改 Nginx 配置文件

进入Nginx配置文件

bash 复制代码
sudo nano /etc/nginx/sites-available/default
# 或者 sudo vim /etc/nginx/conf.d/default.conf

将你的 server_name_ 修改为你的实际域名。

复制代码
server {
    listen 80;
    listen [::]:80;

    # 替换为你的真实域名
    server_name yourdomain.com [www.yourdomain.com](https://www.yourdomain.com);

    include /etc/nginx/mime.types;
    root /var/www/hardware-personal-website;
    index index.html;

    location / {
        try_files $uri $uri/ /index.html;
    }
}

修改完成后,执行以下命令使配置生效:

复制代码
sudo nginx -t
sudo systemctl reload nginx

第三步:配置 HTTPS (推荐)

为了安全和搜索引擎友好,建议使用 Let's Encrypt 申请免费的 SSL 证书。最简单的方法是使用 certbot

  1. 安装 Certbot

    复制代码
    sudo apt update
    sudo apt install certbot python3-certbot-nginx
  2. 获取并安装证书

    执行以下命令,Certbot 会自动修改你的 Nginx 配置并配置好 HTTPS 强制跳转:

    复制代码
    sudo certbot --nginx -d yourdomain.com -d [www.yourdomain.com](https://www.yourdomain.com)
  3. 按照提示操作

    • 输入你的邮箱(用于接收证书到期通知)。

    • 同意服务协议。

    • 选择是否将 HTTP 流量重定向到 HTTPS(建议选 2: Redirect)。

第四步:最终配置预览

Certbot 运行成功后,你的 Nginx 配置文件会自动变成类似这样:

复制代码
server {
    server_name yourdomain.com [www.yourdomain.com](https://www.yourdomain.com);
    root /var/www/hardware-personal-website;
    index index.html;

    location / {
        try_files $uri $uri/ /index.html;
    }

    listen [::]:443 ssl ipv6only=on; # managed by Certbot
    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/[yourdomain.com/fullchain.pem](https://yourdomain.com/fullchain.pem); # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/[yourdomain.com/privkey.pem](https://yourdomain.com/privkey.pem); # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}

server {
    if ($host = [www.yourdomain.com](https://www.yourdomain.com)) {
        return 301 https://$host$request_uri;
    } # managed by Certbot

    if ($host = yourdomain.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot

    listen 80;
    listen [::]:80;
    server_name yourdomain.com [www.yourdomain.com](https://www.yourdomain.com);
    return 404; # managed by Certbot
}

💡 常见问题

  • 防火墙 :确保你的服务器防火墙(如 ufw 或云控制台的安全组)已开启 80 (HTTP)443 (HTTPS) 端口。

  • 证书续期 :Certbot 默认会配置自动续期,你可以通过 sudo certbot renew --dry-run 测试。

相关推荐
sagima_sdu2 小时前
Codex 使用指南(技术向):App、CLI 与工作流接入
linux·运维·语言模型·json
圆山猫2 小时前
[Linux] 用 Buildroot 为 RISC-V QEMU 构建最小根文件系统
linux·运维·risc-v
lars_lhuan2 小时前
K8s跨命名空间SSL认证解决方案:Reflector工具实战
容器·kubernetes·ssl
不做无法实现的梦~2 小时前
Linux 嵌入式开发完整入门:工具、配置和学习路线
linux·运维·学习
郝学胜-神的一滴2 小时前
Linux 高并发基石:epoll 核心原理 + LT/ET 触发模式深度剖析
linux·运维·服务器·开发语言·c++·网络协议
‎ദ്ദിᵔ.˛.ᵔ₎2 小时前
Linux 启动
linux·运维·服务器
shy^-^cky2 小时前
服务器高可用(HA)架构对比
运维·服务器·架构·双机热备·双机互备·双机双工
威迪斯特2 小时前
Ubuntu的apt命令详解:系统管理的核心工具
运维·服务器·ubuntu·apt·下载·包管理·维护
QuestLab3 小时前
【第20期】2026年4月23日 AI日报
运维·服务器·人工智能