Как видно из названия, я не могу запустить свой саперный проект в производственном режиме. Когда я запускаю npm run start
, я получаю вывод на консоль:
niklas@Niklass-iMac project-name % npm run start
> apple-on-svelte@0.0.1 start /Users/niklas/path/to/project
> node __sapper__/build
Starting server on port 3000
niklas@Niklass-iMac project-name %
, как вы видите, команда немедленно прервана и сервер не запущен. В чем может быть причина?
мой package.json
выглядит так
{
"name": "project name",
"description": "description",
"version": "0.0.1",
"scripts": {
"build": "sapper build --legacy",
"deploy": "firebase deploy --only functions",
"dev": "sapper dev",
"export": "sapper export --legacy",
"fb_start": "npm run shell",
"logs": "firebase functions:log",
"serve": "firebase emulators:start --only functions",
"shell": "firebase functions:shell",
"start": "node __sapper__/build"
},
"browserslist": [
"last 3 version"
],
"engines": {
"node": "10"
},
"dependencies": {
"compression": "^1.7.4",
"express": "^4.17.1",
"firebase-admin": "^8.10.0",
"firebase-functions": "^3.6.0",
"sirv": "^0.4.2"
},
"devDependencies": {
"@babel/core": "^7.9.0",
"@babel/plugin-syntax-dynamic-import": "^7.8.3",
"@babel/plugin-transform-runtime": "^7.9.0",
"@babel/preset-env": "^7.9.5",
"@babel/runtime": "^7.9.2",
"@fullhuman/postcss-purgecss": "^2.1.2",
"@rollup/plugin-commonjs": "11.0.2",
"@rollup/plugin-node-resolve": "^7.1.3",
"@rollup/plugin-replace": "^2.3.1",
"autoprefixer": "^9.7.6",
"cssnano": "^4.1.10",
"firebase-functions-test": "^0.2.0",
"npm-run-all": "^4.1.5",
"postcss": "^7.0.27",
"postcss-import": "^12.0.1",
"postcss-nested": "^4.2.1",
"postcss-url": "^8.0.0",
"rollup": "^2.6.1",
"rollup-plugin-babel": "^4.4.0",
"rollup-plugin-postcss": "^2.6.1",
"rollup-plugin-svelte": "^5.2.1",
"rollup-plugin-terser": "^5.3.0",
"sapper": "^0.27.12",
"svelte": "^3.20.1",
"svelte-preprocess": "^3.7.1",
"svelte-preprocess-postcss": "^1.1.1",
"tailwindcss": "^1.2.0"
}
}
, а мой src/server.js
выглядит так:
import sirv from "sirv";
import express from "express";
import compression from "compression";
import * as sapper from "@sapper/server";
import "./assets/global.css";
const { PORT, NODE_ENV } = process.env;
const dev = NODE_ENV === "development";
const expressServer = express().use(
compression({ threshold: 0 }),
sirv("static", { dev }),
sapper.middleware()
);
if (dev) {
expressServer.listen(PORT, (err) => {
if (err) console.log("error", err);
});
}
export { expressServer };
и мой index.js
выглядит так:
const functions = require("firebase-functions");
const { expressServer } = require("./__sapper__/build/server/server");
exports.ssr = functions.https.onRequest(expressServer);
Я использую накопительный пакет и последнюю версию узла lts на macOS 10.15.5 Без проблем я могу запустить npm run dev
или npm run build
, но не npm run start
Как я могу решить это? Есть идеи?