如何配置Nginx服务器?Nginx配置详细步骤解析

安装Nginx

Ubuntu/Debian

sudo apt update
sudo apt install nginx -y
sudo systemctl start nginx
sudo systemctl enable nginx

CentOS/RHEL

sudo yum install epel-release -y
sudo yum install nginx -y
sudo systemctl start nginx
sudo systemctl enable nginx

核心目录结构

  • 主配置文件/etc/nginx/nginx.conf
  • 虚拟主机配置/etc/nginx/sites-available/ (存放配置) → 软链到 /etc/nginx/sites-enabled/ (生效配置)
  • 默认网页根目录/var/www/html/
  • 日志
    • 访问日志:/var/log/nginx/access.log
    • 错误日志:/var/log/nginx/error.log

基础配置示例

创建虚拟主机 (Server Block)

  1. 创建配置文件:

    服务器配置nginx实践

    sudo nano /etc/nginx/sites-available/your_domain.conf
  2. 基础模板:

    server {
        listen 80;
        server_name your-domain.com www.your-domain.com;
        root /var/www/your-domain.com/html;
        index index.html index.htm;
        location / {
            try_files $uri $uri/ =404;
        }
        # 静态文件缓存
        location ~* .(jpg|jpeg|png|gif|ico|css|js)$ {
            expires 30d;
            add_header Cache-Control "public, no-transform";
        }
        # 禁止访问隐藏文件
        location ~ /.ht {
            deny all;
        }
    }
  3. 启用配置:

    sudo ln -s /etc/nginx/sites-available/your_domain.conf /etc/nginx/sites-enabled/
    sudo nginx -t  # 测试配置语法
    sudo systemctl reload nginx

HTTPS配置(Let’s Encrypt)

安装Certbot

sudo apt install certbot python3-certbot-nginx -y  # Ubuntu
sudo certbot --nginx -d your-domain.com -d www.your-domain.com

自动更新证书:

sudo certbot renew --dry-run  # 测试续订

强制HTTP跳转HTTPS

server块中添加:

服务器配置nginx实践

server {
    listen 80;
    server_name your-domain.com;
    return 301 https://$host$request_uri;  # 重定向到HTTPS
}

安全优化配置

/etc/nginx/nginx.conf 全局优化

http {
    # 隐藏Nginx版本号
    server_tokens off;
    # 安全头部
    add_header X-Frame-Options "SAMEORIGIN";
    add_header X-Content-Type-Options "nosniff";
    add_header X-XSS-Protection "1; mode=block";
    add_header Content-Security-Policy "default-src 'self'";
    # 限制请求体大小(防DoS)
    client_max_body_size 10m;
    # 禁用非必要HTTP方法
    if ($request_method !~ ^(GET|HEAD|POST)$ ) {
        return 405;
    }
}

性能优化

http {
    # 开启Gzip压缩
    gzip on;
    gzip_types text/plain text/css application/json application/javascript;
    # 连接优化
    keepalive_timeout 30;
    keepalive_requests 1000;
    # 文件传输优化
    sendfile on;
    tcp_nopush on;
}

反向代理配置

代理到本地Node.js应用(端口3000):

location / {
    proxy_pass http://localhost:3000;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

常见问题排查

  1. 测试配置
    sudo nginx -t

  2. 检查端口占用
    sudo ss -tulpn | grep ':80'

  3. 查看错误日志
    tail -f /var/log/nginx/error.log

    服务器配置nginx实践

  4. 权限问题
    确保网站目录权限:
    sudo chown -R www-data:www-data /var/www/your-domain.com (Ubuntu)
    sudo chown -R nginx:nginx /var/www/your-domain.com (CentOS)


高级场景

负载均衡(4个后端服务器)

upstream backend {
    server backend1.example.com weight=3;
    server backend2.example.com;
    server backend3.example.com backup;
    server backend4.example.com;
}
server {
    location / {
        proxy_pass http://backend;
    }
}

WebSocket代理

location /ws/ {
    proxy_pass http://backend;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
}

常用命令

功能 命令
启动 sudo systemctl start nginx
停止 sudo systemctl stop nginx
重启 sudo systemctl restart nginx
重载配置 sudo systemctl reload nginx
查看状态 sudo systemctl status nginx

通过以上步骤,您已完成Nginx的基础配置到高级优化,根据实际需求调整参数,并始终通过nginx -t验证配置后再重载服务。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/293239.html

(0)
上一篇 2026年2月12日 06:51
下一篇 2026年2月12日 06:54

相关推荐

  • 服务器转让给其他账号怎么操作?服务器过户流程及注意事项

    服务器转让给其他账号的核心结论是:服务器所有权转移并非简单的后台数据修改,而是一项涉及账号权限重构、数据完整性校验、业务连续性保障及法律合规性确认的系统工程,在云原生时代,任何未经过严谨流程的转让操作都可能导致数据丢失、IP 封禁或业务中断,成功的转让必须建立在原账号彻底解绑、新账号权限即时生效、以及 DNS……

    2026年4月26日
    0982
  • 服务器网站安全如何保障,服务器网站安全漏洞修复

    2026 年服务器网站安全的核心结论是:必须构建“零信任架构 + 智能 WAF + 自动化合规审计”的立体防御体系,单纯依赖传统防火墙已无法抵御高级持续性威胁(APT),随着 2026 年人工智能生成内容(AIGC)的泛滥,网络攻击呈现出自动化、智能化特征,传统边界防御已全面失效,企业若想在激烈的市场竞争中保障……

    2026年5月6日
    01031
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 服务器通俗解释是什么?服务器有什么作用

    服务器本质上就是一台永不关机、性能更强、稳定性极高的“超级电脑”,它的核心作用是存储数据、处理请求并向其他电脑(客户端)提供服务,如果把互联网比作一个巨大的餐厅,服务器就是后厨的厨师兼仓库管理员,而我们的手机和电脑就是点菜的客户,每一次上网浏览、视频播放、游戏登录,本质上都是向服务器发送了一次“点菜”请求,服务……

    2026年3月12日
    01703
  • 服务器配置要求计算,如何精准计算硬件配置以匹配业务需求?

    服务器配置要求计算是IT基础设施规划的核心环节,直接影响系统性能、成本效益及业务稳定性,准确计算各配置参数(CPU、内存、存储、网络等)需结合业务负载、应用特性及未来扩展需求,遵循科学方法与行业经验,以下是详细的服务器配置计算方法、行业案例及优化建议,CPU配置计算:基于负载的核数与性能评估CPU是服务器性能的……

    2026年2月3日
    01900

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注