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

相关推荐

  • 服务器密码忘记后如何重置?重置密码的具体操作步骤与注意事项

    {服务器重置密码的操作方法}服务器密码重置是服务器运维中的常见且关键操作,尤其在账户管理、安全审计、系统维护或紧急故障处理场景下至关重要,正确的密码重置流程不仅能保障系统安全,还能避免因密码错误导致的业务中断,本文将系统阐述不同类型服务器(Linux、Windows、数据库)的密码重置方法,结合实际操作步骤与安……

    2026年1月14日
    0460
  • 服务器镜像安装软件后如何优化系统配置?详细操作步骤与常见问题解答。

    服务器镜像安装软件的深度解析与实践指南服务器镜像作为预先配置好的操作系统及软件环境文件,是服务器部署的核心基础,通过安装软件,可将镜像转化为可运行的服务器实例,支撑各类业务系统(如Web服务、数据库、应用平台等)的快速上线,本文将从专业角度系统阐述服务器镜像安装软件的全流程,结合行业实践与酷番云的独家经验,为用……

    2026年1月22日
    0360
  • 如何高效管理服务器配置文件?掌握服务器配置管理最佳实践

    企业IT架构的隐形守护者想象这样一个场景:一次看似普通的配置更新后,核心数据库服务器突然宕机,整个电商平台陷入瘫痪,每分钟损失数以万计,事后追查,原因竟是一位工程师误将测试环境的参数部署到了生产服务器,这并非虚构,而是众多企业曾面临的真实困境,服务器配置文件管理服务器(Configuration Managem……

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

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

      2026年1月10日
      020
  • 服务器重启卡住了怎么办?是什么原因导致无法启动?

    深度解析、解决方法与实战案例服务器重启卡住是一种典型的IT运维故障,指服务器在执行重启操作后,启动进度卡在某阶段(如“正在启动服务”“加载驱动程序”或“正在完成”等)长时间无响应,严重影响业务连续性,本文从现象、原因、解决方法到实战案例,结合酷番云云产品经验,全面解析该问题,并提供权威参考,现象与常见表现服务器……

    2026年1月20日
    0440

发表回复

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