我现在的情况是 我单独部署一个未集成数据库的情况下 部署到 vercel 可以正常访问 hello world
但是我集成了数据库以后 我用的 orm 工具无论是 prisma 还是 sequelize 都会没法正常去访问
我的疑惑点在于 vercel 可以去部署 nest+orm 的这种项目吗?
如果可以是我哪里配置的不对呢?
|  |      1husinhu      2024-06-04 22:14:09 +08:00 有没有一种可能是 next ? | 
|  |      3yangg      2024-06-04 22:31:05 +08:00 via iPhone prisma 肯定可以,请上错误信息 | 
|  |      4mmdsun      2024-06-05 08:41:46 +08:00 via iPhone | 
|  |      5liwenka1 OP @yangg  ``` This Serverless Function has crashed. Your connection is working correctly. Vercel is working correctly. 500: INTERNAL_SERVER_ERROR Code: FUNCTION_INVOCATION_FAILED ID: hnd1::npz54-1717550365607-554473530ff7 ``` 这是我的 vercel.json ``` { "builds": [ { "src": "src/main.ts", "use": "@vercel/node" } ], "routes": [ { "src": "/(.*)", "dest": "src/main.ts", "methods": ["GET", "POST", "PUT", "DELETE"] } ] } ``` | 
|  |      6lshbosheth      2024-06-05 09:47:57 +08:00 我连我服务器的 mysql 还是 vercel 的 pq 数据库 都可以,,, | 
|  |      7lshbosheth      2024-06-05 09:49:22 +08:00 @2020583117 我感觉和这个配置没关系把 这个无非也就是类似入口文件的 作用 ? | 
|  |      8liwenka1 OP @lshbosheth 能详细讲解一下吗?我这边的情况是在我不使用 orm + 数据库的时候是正常的,但是使用以后就会出现上面的报错,我不太确定我部署 nest.js 的时候应该做哪些额外的配置或操作 /(ㄒoㄒ)/~~ | 
|  |      9lshbosheth      2024-06-05 10:52:02 +08:00 这是我 ormconfig 配置  import { TypeOrmModuleOptions } from '@nestjs/typeorm'; const VercelConfig: TypeOrmModuleOptions = { type: 'postgres', host: 'ep-aged-waterfall-13013279-pooler.us-east-1.postgres.vercel-storage.com', port: 5432, username: 'xxx', password: 'xxx', database: 'xxx', ssl: { rejectUnauthorized: false }, // For local development, consider removing this in production synchronize: true, // Automatically create database tables based on entities (set to false in production) logging: process.env.NODE_ENV === 'development' ? true : ['error'], entities: [__dirname + '/**/*.entity{.ts,.js}'], }; const MySqlLocalConfig: TypeOrmModuleOptions = { type: 'mysql', host: 'xxx', port: 3306, username: 'root', password: 'xxx', database: 'xxx', synchronize: true, retryDelay: 500, retryAttempts: 10, autoLoadEntities: true, logging: process.env.NODE_ENV === 'development' ? true : ['error'], }; export { VercelConfig, MySqlLocalConfig }; 具体我也不懂 哈哈哈 直接 app.module 就用了 TypeOrmModule.forRoot(MySqlLocalConfig) 然后 再 service 里直接整就完事了 | 
|  |      10liwenka1 OP @lshbosheth 你没有去配置 vercel.json 这些吗? | 
|  |      11HeyCaptainJack      2024-06-05 10:57:45 +08:00 nestjs 可以用 railway 部署,vercel 主要针对 next.js 的 | 
|  |      12liwenka1 OP @HeyCaptainJack railway 现在没有免费额度了吧?我好难受 /(ㄒoㄒ)/~~ | 
|  |      13lshbosheth      2024-06-05 15:27:09 +08:00 @2020583117 { "builds": [ { "src": "src/main.ts", "use": "@vercel/node" } ], "routes": [ { "src": "/(.*)", "dest": "src/main.ts" } ] } 就这一点 我感觉这个就是个纯入口文件的作用把 和数据库没关系 | 
|  |      14AEP203      2024-06-05 16:53:08 +08:00 ```json { "$schema": "https://openapi.vercel.sh/vercel.json", "buildCommand": "pnpm build", "installCommand": "pnpm install", "outputDirectory": "packages/web/dist", "builds": [ { "src": "package.json", "use": "@vercel/static-build", "config": { "zeroConfig": true, "installCommand": "pnpm install", "buildCommand": "pnpm build", "outputDirectory": "packages/web/dist" } }, { "src": "packages/server/src/main.ts", "use": "@vercel/node" } ], "rewrites": [ { "source": "api/(.*)", "destination": "packages/server/src/main.ts" } ] } ``` 这是我之前的配置,可以跑 nestjs ,但是原生的 .node 模块我没搞明白怎么配置,后来还是换阿里云了 | 
|  |      15liwenka1 OP @lshbosheth 兄弟你仓库代码能给我看下不,或者给个联系方式具体请教一下你  我现在三个 orm 工具都用了一遍了 都是报错了 /(ㄒoㄒ)/~~ | 
|  |      16lshbosheth      2024-06-06 09:10:59 +08:00 @2020583117 我也是初学者 按照我之前 angular 经验和 chatgpt 搞得 。。。 | 
|  |      17liwenka1 OP @lshbosheth 可能是我的数据库问题吧,我去排查一下吧,谢谢哥们回复了 | 
|      18boogoogle      2024-06-21 07:17:09 +08:00 对啊,一般服务器到你的数据库不能直连,你得配置什么白名单,如果是 aws 的话,还有安全规则 |