ubuntu上用nginx部署前端项目

项目上需要在ubuntu部署前端应用,我梳理了完整流程,希望对你也有用。

下图清晰地展示了从规划到上线的完整步骤与检查点,你可以按此流程操作:


📝 第一步:规划------确定三个关键参数

在开始前,先明确以下信息(以"项目B"为例):

建议 示例(请替换为你的实际内容) 必须确保
1. 端口 选一个未被占用的端口。 3003 不能与现有应用(3001, 3002)或系统服务冲突。
2. 访问域名/方式 本地测试可用自定义域名或IP直连。 project-b.local 或直接用 服务器IP:3003 若用域名,需在本机hosts文件添加映射。
3. 网站根目录 /var/www/ 下创建独立新目录 /var/www/project-b 目录名清晰,与项目对应。

检查端口是否被占用 (以3003为例):

bash 复制代码
sudo ss -tulpn | grep :3003

无输出则表示端口可用。


📁 第二步:准备应用文件与目录

  1. 创建项目根目录

    bash 复制代码
    sudo mkdir -p /var/www/project-b
  2. 上传前端文件 :将你构建好的前端文件(如 dist 目录下的所有内容)上传至此目录。可以使用 scp 命令(从你的本地电脑执行):

    bash 复制代码
    scp -r ./dist/* your_username@你的服务器IP:/var/www/project-b/
  3. 设置正确的权限

    bash 复制代码
    sudo chown -R www-data:www-data /var/www/project-b
    sudo chmod -R 755 /var/www/project-b

这一步至关重要,不设置的话会有403错误。


⚙️ 第三步:创建Nginx配置文件

  1. sites-available 目录下创建新配置文件

    bash 复制代码
    sudo nano /etc/nginx/sites-available/project-b
  2. 复制并修改以下配置模板请重点关注注释行,根据你的规划进行修改:

    nginx 复制代码
    server {
        # 【修改点1】监听端口:改为你规划的端口,例如3003
        listen 3003;
        # 监听IPv6的相同端口(可选)
        listen [::]:3003;
    
        # 【修改点2】设置域名:本地测试可用自定义域名(如 project-b.local)
        # 如果不需要域名,用下划线 _ 作为通配符,通过 IP:端口 访问
        server_name project-b.local;
    
        # 【修改点3】网站根目录:指向你刚创建的目录
        root /var/www/project-b;
        index index.html index.htm;
    
        location / {
            # 此指令对Vue/React等单页应用路由至关重要
            try_files $uri $uri/ /index.html;
        }
    
        # (可选)静态资源缓存,提升性能
        location ~* \.(jpg|jpeg|png|gif|ico|css|js|svg)$ {
            expires 1y;
            add_header Cache-Control "public, immutable";
        }
    
        # (可选)禁止访问隐藏文件(如.git、.env)
        location ~ /\. {
            deny all;
        }
    }

    nginx的配置跟在windows中是一样的。

  3. Ctrl+O 保存,Enter 确认,再按 Ctrl+X 退出 nano

这一步跟vim操作差不多。


🔗 第四步:启用站点配置

创建从 sites-availablesites-enabled 的符号链接(即"启用"该站点):

bash 复制代码
sudo ln -s /etc/nginx/sites-available/project-b /etc/nginx/sites-enabled/

这一步相当于在sites-enabled目录建立一个快捷方式,代表此项目可用。


✅ 第五步:测试配置并重载Nginx

这是必须且关键的步骤,任何配置修改后都要执行。

  1. 测试语法

    bash 复制代码
    sudo nginx -t

    如果输出 syntax is oktest is successful,说明配置无误。

  2. 重载Nginx(应用新配置)

    bash 复制代码
    sudo systemctl reload nginx

🌐 第六步:验证与访问

  1. 确认Nginx正在监听新端口

    bash 复制代码
    sudo ss -tulpn | grep :3003

    应有输出,显示 nginx 进程在监听 3003

  2. 在服务器上本地测试

    bash 复制代码
    curl -I http://127.0.0.1:3003

    应返回 HTTP/1.1 200 OK

  3. 在客户端电脑访问

    • 方案A(通过IP:端口) :直接在浏览器输入 http://你的服务器IP:3003就可以访问了。
    • 方案B(通过自定义域名,如project-b.local
      • 如果你想自定义域名,可先在客户端电脑的 hosts 文件中添加一行:你的服务器IP project-b.local
      • 然后在浏览器输入 http://project-b.local:3003

⚠️ 如果无法访问,请检查

  • 防火墙 :如果服务器开启了防火墙(如UFW),需放行新端口:

    bash 复制代码
    sudo ufw allow 3003/tcp
    sudo ufw reload
  • 错误日志 :查看具体错误信息:

    bash 复制代码
    sudo tail -f /var/log/nginx/error.log

📦 总结:一套清晰的标准化流程

未来部署第N个应用,只需重复此流程,并确保:

  1. 端口不重复
  2. 目录独立
  3. server_name 或端口在配置中唯一
  4. 每次修改配置后,必执行 sudo nginx -t && sudo systemctl reload nginx
相关推荐
张雨zy2 小时前
Pinia 与 TypeScript 完美搭配:Vue 应用状态管理新选择
vue.js·ubuntu·typescript
么么...8 小时前
在 Ubuntu 上安装 Docker 并部署 MySQL 容器
linux·运维·经验分享·笔记·mysql·ubuntu·docker
誰能久伴不乏10 小时前
Linux `epoll` 学习笔记:从原理到正确写法(含 ET 经典坑总结)
linux·服务器·网络·c++·ubuntu
像名字一样难取的昵称11 小时前
Linux学习笔记:十八、Linux文件的压缩,解压缩一站式学习
linux·运维·笔记·学习·ubuntu·ssh
weixin_4454766811 小时前
Docker 在 Ubuntu(国内网络)安装及问题解决总结
网络·ubuntu·docker
知识分享小能手15 小时前
Ubuntu入门学习教程,从入门到精通, Ubuntu 22.04 文件和目录管理完全指南(7)
linux·学习·ubuntu
人工智能训练16 小时前
Ubuntu 系统安装 VSCode 超全指南(3 种方法,适配 20.04/22.04 LTS)
linux·运维·服务器·vscode·ubuntu
Ribou16 小时前
Ubuntu 24.04.2安装配置k8s 1.35.0
linux·ubuntu·kubernetes
明月满西楼16 小时前
在Ubuntu 20.04实现ROS1 Noetic 与 ROS2 Foxy 多版本共存及切换
ubuntu·ros·noetic·foxy