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

相关推荐

  • 服务器里建一个ftp

    在现代企业级数据交互与文件分发场景中,尽管对象存储和网盘技术日益普及,但FTP(文件传输协议)凭借其高效、稳定及广泛的兼容性,依然是服务器运维中不可或缺的基础服务,在服务器里建一个FTP不仅仅是安装一个软件那么简单,它涉及到权限管理、网络传输模式的选择、安全加固以及云环境下的网络策略配置,是一项需要综合考量系统……

    2026年2月4日
    0790
  • 服务器配置怎么看,服务器配置分析主要看哪些参数?

    服务器配置分析的核心在于资源与业务负载的精准匹配,而非盲目追求高参数,科学的配置方案应当基于业务类型、并发量、数据吞吐量以及未来扩展性进行综合评估,从而在性能稳定性与成本控制之间找到最佳平衡点,只有深入理解CPU计算模型、内存I/O瓶颈以及磁盘读写机制,才能构建出既高效又经济的服务器架构,CPU计算资源的深度解……

    2026年2月21日
    0585
  • 服务器选哪的?国内服务器哪家好速度快

    服务器选址直接决定了业务的生命周期与用户体验,核心结论在于:服务器选址必须遵循“用户就近原则”与“业务合规属性”相结合的双重逻辑,对于面向国内用户的业务,首选国内节点(需备案)以保证极速访问;若业务涉及跨境贸易或免备案需求,则应选择CN2优化线路的香港或海外节点,切忌盲目追求“大区域”而忽视“网络线路质量”,线……

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

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

      2026年1月10日
      020
  • 服务器长期闲置会带来哪些风险?如何科学管理闲置服务器资源避免浪费?

    服务器闲置的现状、影响与优化策略随着云计算技术的普及与数字化转型加速,企业对服务器资源的依赖日益增长,服务器闲置现象在众多组织中普遍存在,不仅导致资源浪费与成本增加,更引发安全风险与运维效率低下等问题,据中国信息通信研究院(以下简称“信通院”)发布的《中国云计算发展白皮书》(2023年版),国内企业服务器平均利……

    2026年1月17日
    0990

发表回复

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