宝塔面板项目部署踩坑日记

1. 服务器地址

  1. mysql地址与密码(密码或地址错误会连接不上数据库,直接导致项目启动不了,也关闭不了)
  2. 前端访问的地址记得改为上线地址
  3. 如果涉及到操作文件(比如上传文件到服务器),文件的目录也要改为服务器上的目录(比如/www/wwwroot)

2. 请求404的问题

  1. nginx跨域解决

挂载到服务器的前端项目会默认有一个api前缀

参考文章:blog.csdn.net/weixin_4320...

打开前端站点,点击设置,到配置文件加一个这个,proxy_pass:是你搭建好的后端地址

javascript 复制代码
 
    location  ^~/api/
    {
    add_header 'Access-Control-Allow-Origin' '*';
    proxy_pass http://42.194.242.69:3000/;
    }
    
    location  ^~/image/ 
    {
		root /www/wwwroot/soulmate/soulmateImage/;     #指定图片存放路径    
	  }

3. 图片上传服务器失败

  1. 修改文件权限 用这个命令也不是所有情况都能解决,可以看看《鸟哥的 Linux 私房菜》 关于权限的那块内容
bash 复制代码
chmod -R 777

4. 图片访问失败

我后端使用的是资源映射。

访问失败,一般为你的站点没有配置可访问路径

bash 复制代码
  location  ^~/image/ 
    {
		root /www/wwwroot/soulmate/soulmateImage/;     #指定图片存放路径    
	  }

参考文章: blog.csdn.net/qq_48922459...

5. 刷新页面找不到

使用的是history模式 由于我们的应用是一个单页的客户端应用

参考文章: cloud.tencent.com/developer/a...

6. 面试题

hash模式

hash模式 它在内部传递的实际 URL 之前使用了一个哈希字符(#)。由于这部分 URL 从未被发送到服务器,所以它不需要在服务器层面上进行任何特殊处理。不过,它在 SEO 中确实有不好的影响。如果你担心这个问题,可以使用 HTML5 模式。

history模式

当使用这种历史模式时,URL 会看起来很 "正常",例如 example.com/user/id。漂亮!

不过,问题来了。由于我们的应用是一个单页的客户端应用,如果没有适当的服务器配置,用户在浏览器中直接访问 example.com/user/id,就会得... 404 错误。这就尴尬了。

不用担心:要解决这个问题,你需要做的就是在你的服务器上添加一个简单的回退路由。如果 URL 不匹配任何静态资源,它应提供与你的应用程序中的 index.html 相同的页面。漂亮依旧!

解决方案:

  1. 改为hash模式
  2. nginx
bash 复制代码
 location / 
    {
    index /www/wwwroot/dist/index.html;
    try_files $uri $uri/ /index.html;
    }

参考

cloud.tencent.com/developer/a...

一定要配置日志!!!

相关推荐
程途知微22 分钟前
AQS 同步器——Java 并发框架的核心底座全解析
java·后端
iPadiPhone1 小时前
分布式架构的“润滑剂”:RabbitMQ 核心原理与大厂面试避坑指南
分布式·后端·面试·架构·rabbitmq
武子康1 小时前
大数据-255 离线数仓 - Apache Atlas 数据血缘与元数据管理实战指南
大数据·后端·apache hive
javaTodo1 小时前
IntelliJ IDEA 2026.1 上强度了:Spring 运行时 Debug + AI 全面接入,太香了
后端
晴栀ay2 小时前
Generator + RxJS 重构 LLM 流式输出的“丝滑”架构
javascript·后端·llm
下次一定x2 小时前
深度解析 Kratos 客户端服务发现与负载均衡:从 Dial 入口到 gRPC 全链路落地(下篇)
后端·go
彭于晏Yan3 小时前
SpringBoot整合ECC实现文件签名与验签
java·spring boot·后端
pupudawang3 小时前
Spring EL 表达式的简单介绍和使用
java·后端·spring
xianjian09123 小时前
springboot与springcloud以及springcloudalibaba版本对照
spring boot·后端·spring cloud
羊小猪~~4 小时前
【QT】-- QMainWindow简介
开发语言·数据库·c++·后端·qt·前端框架·求职招聘