Deployed a Next.js application to App Engine Standard [Nodejs] and got a 500 error

前端 未结 3 2040
被撕碎了的回忆
被撕碎了的回忆 2021-02-04 18:45

I deployed to app engine with nodejs8 runtime and got a 500. Im deploying a next.js application, and upon reviewing StackDriver I get. It appears .next might be getting ignored.

3条回答
  •  情深已故
    2021-02-04 19:00

    When your application is returning 500 errors, make sure to look at the stdout and stderr logs of your application in Stackdriver Logging at https://console.cloud.google.com/logs/viewer. Double check that you are looking at "GAE Application" resource picker.

    Looking at the error message, it seems that the .next folder does not exist in your app. This .next folder is a folder that is usually generated via a "build step", and I see indeed that you have "build": "next build" as a script in your package.json.

    You should not be using prestart to perform this build step, first because App Engine does not run prestart on instance startup, but also because in general this would be bad for performances.

    You have two ways to create this folder:

    1. Generate .next on your machine before deploying, to do so, you can change your deploy script to be: "deploy": "npm run build && gcloud app deploy". (And also make sure that the .gcloudignore file does not contain .next or does not include the content of the .gitignore file)

    2. Run this build step on Google Cloud's servers after deploying: The Node.js App Engine runtime will execute any gcp-build script if present. This means that you can add this script: "gcp-build": "npm run build" to your package.json. When doing so, I recommend you to add .next to the .gcloudignore file so that the .next folder does not get uploaded at deployment time.

    In addition, note that you can simplify your app.yaml to just runtime: nodejs8:

    • NODE_ENV is automatically set to production, you can remove it
    • Your handlers section is equivalent to the default one.

提交回复
热议问题