当前位置: 首页 > news >正文

CentOS 7 基于 Nginx 的 HTML 部署全流程指南

一、Nginx 安装(两种主流方式)

1. YUM 安装(推荐新手)
# 安装 EPEL 扩展源(部分系统需要)
yum install epel-release -y# 安装 Nginx
yum install nginx -y# 启动并设置开机自启
systemctl start nginx
systemctl enable nginx

特点

  • 自动处理依赖关系,默认配置文件路径为 /etc/nginx/nginx.conf
  • 静态资源默认存储目录:/usr/share/nginx/html

2. 源码编译安装(定制化需求)
# 安装依赖库
yum -y install gcc pcre-devel zlib-devel openssl-devel# 下载源码包(以 1.25.3 为例)
wget https://nginx.org/download/nginx-1.25.3.tar.gz
tar -zxvf nginx-1.25.3.tar.gz
cd nginx-1.25.3# 配置与编译
./configure --prefix=/usr/local/nginx
make && make install# 启动服务
/usr/local/nginx/sbin/nginx

特点

  • 可自定义模块(如 --with-http_ssl_module 启用 HTTPS)
  • 配置文件路径:/usr/local/nginx/conf/nginx.conf

二、核心配置详解

1. 虚拟主机配置(多站点管理)

步骤一:创建专用配置目录

mkdir /etc/nginx/vhost  # YUM 安装路径
# 或 mkdir /usr/local/nginx/conf/vhost  # 源码安装路径

步骤二:新建站点配置文件
创建 /etc/nginx/vhost/my_site.conf(示例):

server {listen 80;server_name example.com www.example.com;  # 替换为实际域名或IProot /var/www/html/my_site;  # 自定义HTML存放路径index index.html;# 日志配置access_log /var/log/nginx/my_site_access.log;error_log /var/log/nginx/my_site_error.log;# 静态文件缓存(可选)location ~* \.(jpg|css|js)$ {expires 30d;add_header Cache-Control "public";}
}

说明

  • root 指定 HTML 文件根目录,需提前创建并赋予权限
  • server_name 支持多域名,用空格分隔

2. 主配置文件整合

编辑 /etc/nginx/nginx.conf,在 http {} 块内添加:

include /etc/nginx/vhost/*.conf;  # 包含所有虚拟主机配置

验证配置语法

nginx -t  # 显示 "syntax is ok" 表示无误

三、HTML 部署实战

1. 上传文件与权限设置
# 创建网站目录
mkdir -p /var/www/html/my_site# 上传 HTML 文件(如 index.html)
scp -r ./dist/* root@服务器IP:/var/www/html/my_site/# 设置权限(确保 Nginx 用户可读)
chown -R nginx:nginx /var/www/html/my_site
chmod -R 755 /var/www/html/my_site
2. 防火墙放行
# 开放 80 端口
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload# 若使用 SELinux
setsebool -P httpd_read_user_content 1  # 允许访问用户目录

四、服务重启与验证

1. 重启 Nginx
# YUM 安装方式
systemctl restart nginx# 源码安装方式
/usr/local/nginx/sbin/nginx -s reload
2. 访问测试
# 命令行验证
curl http://服务器IP# 浏览器访问
打开 http://服务器IP 或 http://域名

预期结果:显示自定义的 HTML 页面内容


五、进阶优化配置

1. Gzip 压缩

nginx.confhttp {} 块内添加:

gzip on;
gzip_types text/plain text/css application/json application/javascript;
gzip_min_length 1k;

效果:减少 60%-80% 的传输体积

2. 错误页面定制

在虚拟主机配置中添加:

error_page 404 /404.html;
location = /404.html {root /var/www/html/errors;internal;
}

六、常见问题排查

1. 403 Forbidden
  • 检查目录权限:确保 nginx 用户有读取权限
  • 确认 root 路径是否存在拼写错误
2. 端口占用
netstat -tulnp | grep :80  # 查看 80 端口占用进程
kill -9 <PID>  # 终止冲突进程
3. 静态资源加载失败
  • 检查文件路径大小写(Linux 区分大小写)
  • 确认文件权限是否为 644(chmod 644 *.css

总结

通过以上步骤,您已完成从 Nginx 安装到 HTML 部署的全流程。推荐使用 YUM 安装快速上手,生产环境建议源码编译以启用高级功能。部署时务必注意文件权限与防火墙配置,进阶优化可显著提升访问速度与安全性。如需实现 HTTPS 支持,可参考 Let’s Encrypt 免费证书配置方案。

相关文章:

  • 智能吸顶灯/摄影补光灯专用!FP7195双通道LED驱动,高效节能省空间 !
  • 保姆级教程:用EndNote 20让参考文献自动分组排序(中文在前,英文在后)
  • 【bug修复】一次诡异的接口数据显示 bug 排查之旅
  • Java高频面试之并发编程-07
  • Docker部署一款开源的极简服务器监控工具Ward内网穿透远程使用
  • 23种设计模式-行为型模式之策略模式(Java版本)
  • 记录学习的第三十一天
  • 基于PHP+Uniapp的互联网医院源码:电子处方功能落地方案
  • IDEA启动报错Failed to create JVM. JVM path的解决办法
  • 矩阵运算和线性代数操作开源库
  • 深入浅出学会函数(下)
  • 深入理解MVP架构:让UI层与业务逻辑完美分离的设计模式
  • Java 使用 RabbitMQ 消息处理(快速上手指南)
  • 【前端】【业务场景】【面试】在前端开发中,如何实现文件的上传与下载功能,并且处理可能出现的错误情况?
  • 大数据运维面试题
  • 蓝牙 LE:安全模式和程序说明(蓝牙中的网络安全)
  • 【数据可视化-27】全球网络安全威胁数据可视化分析(2015-2024)
  • 系统与网络安全------弹性交换网络(2)
  • Spring Boot常用注解详解:实例与核心概念
  • 5G/6G通信设备中的盲埋孔技术突破
  • “网红”谭媛去世三年:未停更的账号和困境中的家庭
  • 国家市场监管总局:民生无小事,严打民生领域侵权假冒违法行为
  • 央行上海总部答澎湃:上海辖内金融机构已审批通过股票回购增持贷款项目117个
  • “雷公”起诉人贩子王浩文案开庭:庭审前手写道歉信,庭审中不承认拐走川川
  • 神二十发射时间藏着两彩蛋:恰逢东方红一号发射55周年和第十个“中国航天日”
  • 从香料到文化,跟着陈晓卿寻味厦门