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 测试。

相关推荐
三十..6 小时前
Ceph 三大存储接口深度实践与数据保护指南
运维·ceph
蝶豆花7 小时前
基于商城系统的功能,自动化,性能-测试报告
运维·自动化
袋鼠云数栈7 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
黎阳之光7 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
志栋智能7 小时前
AI驱动无代码:降低巡检超自动化的门槛
大数据·运维·网络·人工智能·自动化
AOwhisky8 小时前
Ceph系列第六期:Ceph 文件系统(CephFS)精讲
linux·运维·网络·笔记·ceph
Land03298 小时前
RPA网页自动化:元素定位失效的7种根因与XPath鲁棒性改造方案
运维·selenium·自动化·rpa
zh_yt9 小时前
auto-connect remote ssh server
运维·ssh
Lumbrologist9 小时前
【零基础部署】Docker 部署 AutoGen 多 Agent 对话框架保姆级教程
运维·docker·容器
feng145610 小时前
OpenSREClaw - AI 本体论思维
运维·人工智能