Axum+Vue3前后端分离生产环境部署

1.准备条件

  1. 前端已开发完成并可成功构建
  2. 后端已开发完成并可成功构建
  3. 已安装Nginx服务器

2.前端

前端使用Nginx托管静态文件

1.在项目根目录执行命令npm run build生成dist目录

2.将生成的dist目录复制到/var/www目录下面,例如/var/www/vue-project/dist

3.在目录/etc/nginx/sites-available下面创建服务配置文件vue-project.conf,内容如下:

bash 复制代码
server {
    listen 80;   # 监听端口号
    server_name yourdomain.com;    # IP或者域名
    
    location / {
        root /var/www/vue-project/dist;    # 静态文件根目录
        index index.html;    # 默认索引文件
        try_files $uri $uri/ /index.html;    # 处理所有路径请求
    }
    
    # 代理API请求到后端
    location /api/ {    # 将以/api开头的请求代理到后端服务
        proxy_pass http://localhost:8000/;     # 后端服务器地址
        proxy_set_header Host $host;    # HTTP请求头
        proxy_set_header X-Real-IP $remote_addr;    # 将客户端真实IP传递给后端
    }
}

4.使配置文件生效

ln -s /etc/nginx/sites-avaiable/vue-porject.conf /etc/nginx/sites-enabled/vue-project.conf

5.重新加载nginx服务

systemctl restart nginx

3.后端

后端使用systemd管理服务

1.在项目根目录先使用命令cargo build --release构建出二进制文件,产物路径为target/release/your_project_name

2.在目录/etc/systemd/system下创建配置文件,例如project_name.service,内容如下:

ini 复制代码
[Unit]
Description=SoulStranded Web Server   # 服务描述信息

[Service]
ExecStart=/root/workspace/project_name/target/release/project_name   # 构建产物二进制路径
WorkingDirectory=/root/workspace/soulstranded/backend    # 项目根目录
Restart=always    # 服务退出时自动重启

[Install]
WantedBy=multi-user.target    # 服务的启动级别依赖关系

3.启用并启动服务

bash 复制代码
sudo systemctl enable project_name
sudo systemctl start project_name
相关推荐
Mintopia9 小时前
🧠 Next.js 还是 Nuxt.js?——当 JavaScript 碰上命运的分叉路
前端·后端·全栈
Mintopia1 天前
🇨🇳 Next.js 在国内场景下的使用分析与实践指南
前端·后端·全栈
王六岁4 天前
🐍 前端开发 0 基础学 Python 入门指南:数字与字符串篇
前端·python·全栈
Mintopia4 天前
📚 Next.js 分页 & 模糊搜索:在无限数据海里优雅地翻页
前端·javascript·全栈
Mintopia5 天前
⚙️ Next.js 事务与批量操作:让异步的世界井然有序
前端·javascript·全栈
Amos_Web6 天前
Rust实战教程--文件管理命令行工具
前端·rust·全栈
用户5277137976196 天前
银河麒麟部署自托管Sentry流程及问题记录(暂未成功)
全栈
Mintopia6 天前
🧭 Next.js 架构与运维:当现代前端拥有了“分布式的灵魂”
前端·javascript·全栈
孙笑川_7 天前
从 React 前端到 Golang 全栈开发者的转型之旅
全栈
Mintopia7 天前
⚙️ Next.js 缓存与队列:当数据与请求跳起“低延迟之舞”
前端·全栈·next.js