如何配置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

相关推荐

  • 服务器部署app怎么做?服务器部署app详细步骤教程

    服务器部署App是一项系统工程,核心结论在于:高效的App部署并非简单的代码上传,而是构建一个高可用、高并发、且具备弹性伸缩能力的运行环境,其关键在于服务器选型匹配业务需求、环境配置的标准化以及运维监控的自动化, 只有将基础设施与应用架构深度融合,才能确保App在用户量激增时依然保持流畅稳定,服务器选型:决定A……

    2026年3月10日
    0832
  • 服务器运行jsp卡顿怎么办,服务器运行jsp卡顿原因及解决方案

    服务器运行JSP:高效、稳定、可扩展的Java Web部署核心实践在当前企业级Web应用开发中,JSP(JavaServer Pages)凭借其与Java生态的深度集成、模板化开发优势及成熟的中间件支持,仍是构建高并发、高可用业务系统的重要技术路径,能否稳定高效地运行JSP,关键不在于“是否支持JSP”,而在于……

    2026年4月12日
    0552
  • 服务器部署自己的网站难吗?服务器搭建网站详细步骤教程

    服务器部署自己的网站是一项系统性的工程,其核心结论在于:构建一个高性能、高可用的网站,不仅需要选择合适的硬件资源,更依赖于环境配置、安全防护及运维监控的深度整合, 成功的部署并非简单地将文件上传至服务器,而是通过精细化的架构设计,确保用户访问的流畅度与数据的安全性,这一过程直接决定了网站在搜索引擎中的表现与用户……

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

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

      2026年1月10日
      020
  • 服务器速度快不快?服务器速度对SEO排名的影响

    服务器速度的快慢直接决定了业务的生命周期与用户体验,核心结论在于:服务器速度不仅取决于硬件配置的绝对值,更取决于网络链路质量、资源调度能力以及服务商的技术优化深度, 一台物理参数顶尖的服务器,若置身于拥堵的网络节点或遭受邻居资源的抢占,其表现甚至不如一台经过深度优化的入门级云主机,判断服务器速度快不快,必须从物……

    2026年3月12日
    0811

发表回复

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