Как развернуть Next.js с бэкэндом GraphQL на Zeit Now?
У меня есть приложение Next.js/Express/Apollo GraphQL, работающее на локальном хосте.
Я пытаюсь развернуть его на Zeit Now, и часть Next.js работает нормально, но серверная часть GraphQL терпит неудачу, потому что /graphql
маршрут возвращается:
502: An error occurred with your deployment
Code: NO_STATUS_CODE_FROM_LAMBDA
мой now.json
похоже:
{
"version": 2,
"builds": [
{ "src": "next.config.js", "use": "@now/next" },
{ "src": "server/server.js", "use": "@now/node" }
],
"routes": [
{ "src": "/api/(.*)", "dest": "server/server.js" },
{ "src": "/graphql", "dest": "server/server.js" }
]
}
Предложения?
1 ответ
Вот полный пример Next.js/Apollo GraphQL, работающего как на Zeit Now (как бессерверная функция / лямбда), так и на Heroku (с сервером Express):
https://github.com/tomsoderlund/nextjs-pwa-graphql-sql-boilerplate
Я получал эту ошибку, пока не нашел решение на слабом канале Уэса Боса.
Следующее сработало для меня, но, возможно, вы могли получить эту ошибку по другой причине.
Я не уверен, почему это работает.
Вы можете увидеть это работает здесь
cd backend
- Бежать
npm install graphql-import
- Обновление скриптов в
package.json
:
"deploy": "prisma deploy --env-file variables.env&& npm run writeSchema",
"writeSchema": "node src/writeSchema.js"
Примечание: для пользователей не Windows, убедитесь, что место перед
&&
- Создайте
src/writeSchema.js
:
const fs = require('fs');
const { importSchema } = require('graphql-import');
const text = importSchema("src/generated/prisma.graphql");
fs.writeFileSync("src/schema_prep.graphql", text)
- Обновить
src/db.js
:
const db = new Prisma({
typeDefs: __dirname + "/schema_prep.graphql",
...
});
- Обновить
src/createServer.js
:
return new GraphQLServer({
typeDefs: __dirname + '/schema.graphql',
...
});
- Обновить
src/schema.graphql
:
# import * from './schema_prep.graphql'
- Создайте
now.json
{
"version": 2,
"name": "Project Name",
"builds": [
{ "src": "src/index.js", "use": "@now/node-server" }
],
"routes": [
{ "src": "/.*", "dest": "src/index.js" }
],
"env": {
"SOME_VARIABLE": "xxx",
...
}
}
- Бежать
npm run deploy
изначально создатьschema_prep.graphql
, - Бежать
now
Другой ответ сказал это:
Вы не должны смешивать импорт graphql и импорт js/ts. Синтаксис в файле graphql будет интерпретироваться graphql-import и будет игнорироваться ncc (компилятором, который читает содержимое __dirname и перемещает файл в правильный каталог и т. Д.). В моем примере schema_prep.graphql уже предварительно обработан с помощью импорт из сгенерированного файла graphql.
Надеюсь, это поможет.