nuxt3: trpc-nuxt和sqlite导致的503错误

原文链接:

https://www.xxdl.xyz/archives/nuxt-trpc-503-error-sqlite

项目介绍

相关版本

nuxt: 3.17+/4.0.2

node: 18.18.2/20.19.4都试过

trpc-nuxt: 1.2.0

nuxt全栈项目, 使用了nuxt ui pro作为组件库, 前后端通信用的是trpc-nuxt. 数据库用的是sqlite.

为什么不用mysql?

项目写好后是准备独立使用的, 把数据放在使用者本地, 保证数据安全.

问题描述

项目能正常启动, trpc接口和参数也能正常的提示和返回. 这是前提.

但当我修改server/trpc/routers/ 下的文件时, 就会出现Dev server is unavailable. 错误

有时也会出现 **  ELIFECYCLE  Command failed with exit code 3221225477. **

这些错误出现的时机是完全随机的, 有时加个log打印就报错, 有时新增个方法就报错, 完全没办法复现.

比如trpc/routers下面有10个文件, 有时候我修改到3个的时候报错, 重启后, 修改第2个文件就又报错, 完全随机.

问题复现

首先是搜github, 找到有个类似的问题: Nuxt restarts when data in sqlite .db file is updated in directory root, 按照他的说明, 不让.db在根目录. 当天测试是可以, 但第二天不知道为啥就失效了, 问题依旧存在.

接着我想做个demo复现问题, 相关的仓库在这里. 但这个项目出问题的概率, 是我原项目的1/10, 有时候甚至能一直正常使用.

后面我想着从我的原项目一点点删除东西. 我分别测试了下面的几种情况:

  • 把路由目录下的内容简写, 取消多余的引用 -> 报错
  • trpc/routers/index.ts文件中删除一些引用 -> 依旧报错
  • 不打开web页面的时候修改 -> 报错
  • 一次性修改多个文件, 统一保存 -> 报错
  • 把.db文件放到其他目录, 使用绝对路径使用 -> 还是报错
  • 我甚至复制了两份代码, 一个跑前端, 一个跑后端, trpc通过绝对路径引用对方的...reuters/index.ts文件 -> 还是报错

再后面我开始排查trpc client的问题, 但不知道从哪开始, 放弃了.

解决问题

接着我重新查看项目: 既然不管我怎么动trpc/routers里面的文件, 他都报错, 哪可能trpc是没问题的.

nuxt是自己用过的, 正常在server目录里写路由没出现过这种问题, drizzle orm也不是第一次用. 剩下的可能就是sqlite的问题了.

所以重新将sqlite换成mysql, 没想到居然可以了. 不过当我修改后的第一个请求,时间明显的长于普通请求.

猜测是修改是需要重新建立数据库链接, 网络链接可以重试, 本地文件重建链接时可能导致nuxt内部出错, 所以一直503

相关推荐
像风一样!15 小时前
MySQL Galera Cluster部署如何实现负载均衡和高可用
数据库·mysql
飞鸟真人16 小时前
VUE+Electron从0开始搭建开发环境
electron·vue
last_zhiyin16 小时前
Oracle sql tuning guide 翻译 Part 6-4 --- Hint使用准则和Hint使用报告
数据库·sql·oracle·sql tunning
chenchihwen17 小时前
AI代码开发宝库系列:FAISS向量数据库
数据库·人工智能·python·faiss·1024程序员节
小光学长17 小时前
基于Vue的课程达成度分析系统t84pzgwk(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
摇滚侠17 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节
周杰伦fans18 小时前
Navicat - 连接 mysql 、 sqlserver 数据库 步骤与问题解决
数据库·mysql·sqlserver
码以致用19 小时前
StarRocks笔记
数据库·starrocks·olap·1024程序员节
auspicious航19 小时前
PostgreSQL数据库关于pg_rewind的认识
数据库·postgresql·oracle
武子康20 小时前
Java-159 MongoDB 副本集容器化 10 分钟速查卡|keyfile + –auth + 幂等 init 附 docker-compose
java·数据库·mongodb·docker·性能优化·nosql·1024程序员节