You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
324 lines
14 KiB
JavaScript
324 lines
14 KiB
JavaScript
"use strict";
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
0 && (module.exports = {
|
|
getRequestHandlers: null,
|
|
startServer: null
|
|
});
|
|
function _export(target, all) {
|
|
for(var name in all)Object.defineProperty(target, name, {
|
|
enumerable: true,
|
|
get: all[name]
|
|
});
|
|
}
|
|
_export(exports, {
|
|
getRequestHandlers: function() {
|
|
return getRequestHandlers;
|
|
},
|
|
startServer: function() {
|
|
return startServer;
|
|
}
|
|
});
|
|
require("../next");
|
|
require("../require-hook");
|
|
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
|
|
const _v8 = /*#__PURE__*/ _interop_require_default(require("v8"));
|
|
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
|
|
const _http = /*#__PURE__*/ _interop_require_default(require("http"));
|
|
const _https = /*#__PURE__*/ _interop_require_default(require("https"));
|
|
const _os = /*#__PURE__*/ _interop_require_default(require("os"));
|
|
const _watchpack = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/watchpack"));
|
|
const _log = /*#__PURE__*/ _interop_require_wildcard(require("../../build/output/log"));
|
|
const _debug = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/debug"));
|
|
const _utils = require("./utils");
|
|
const _formathostname = require("./format-hostname");
|
|
const _routerserver = require("./router-server");
|
|
const _constants = require("../../shared/lib/constants");
|
|
const _appinfolog = require("./app-info-log");
|
|
const _turbopackwarning = require("../../lib/turbopack-warning");
|
|
const _trace = require("../../trace");
|
|
const _ispostpone = require("./router-utils/is-postpone");
|
|
function _interop_require_default(obj) {
|
|
return obj && obj.__esModule ? obj : {
|
|
default: obj
|
|
};
|
|
}
|
|
function _getRequireWildcardCache(nodeInterop) {
|
|
if (typeof WeakMap !== "function") return null;
|
|
var cacheBabelInterop = new WeakMap();
|
|
var cacheNodeInterop = new WeakMap();
|
|
return (_getRequireWildcardCache = function(nodeInterop) {
|
|
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
|
|
})(nodeInterop);
|
|
}
|
|
function _interop_require_wildcard(obj, nodeInterop) {
|
|
if (!nodeInterop && obj && obj.__esModule) {
|
|
return obj;
|
|
}
|
|
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
|
|
return {
|
|
default: obj
|
|
};
|
|
}
|
|
var cache = _getRequireWildcardCache(nodeInterop);
|
|
if (cache && cache.has(obj)) {
|
|
return cache.get(obj);
|
|
}
|
|
var newObj = {};
|
|
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
|
|
for(var key in obj){
|
|
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
|
|
if (desc && (desc.get || desc.set)) {
|
|
Object.defineProperty(newObj, key, desc);
|
|
} else {
|
|
newObj[key] = obj[key];
|
|
}
|
|
}
|
|
}
|
|
newObj.default = obj;
|
|
if (cache) {
|
|
cache.set(obj, newObj);
|
|
}
|
|
return newObj;
|
|
}
|
|
if (performance.getEntriesByName("next-start").length === 0) {
|
|
performance.mark("next-start");
|
|
}
|
|
const debug = (0, _debug.default)("next:start-server");
|
|
let startServerSpan;
|
|
async function getRequestHandlers({ dir, port, isDev, server, hostname, minimalMode, isNodeDebugging, keepAliveTimeout, experimentalTestProxy, experimentalHttpsServer }) {
|
|
return (0, _routerserver.initialize)({
|
|
dir,
|
|
port,
|
|
hostname,
|
|
dev: isDev,
|
|
minimalMode,
|
|
server,
|
|
isNodeDebugging: isNodeDebugging || false,
|
|
keepAliveTimeout,
|
|
experimentalTestProxy,
|
|
experimentalHttpsServer,
|
|
startServerSpan
|
|
});
|
|
}
|
|
async function startServer(serverOptions) {
|
|
const { dir, isDev, hostname, minimalMode, allowRetry, keepAliveTimeout, isExperimentalTestProxy, selfSignedCertificate } = serverOptions;
|
|
let { port } = serverOptions;
|
|
process.title = "next-server";
|
|
let handlersReady = ()=>{};
|
|
let handlersError = ()=>{};
|
|
let handlersPromise = new Promise((resolve, reject)=>{
|
|
handlersReady = resolve;
|
|
handlersError = reject;
|
|
});
|
|
let requestHandler = async (req, res)=>{
|
|
if (handlersPromise) {
|
|
await handlersPromise;
|
|
return requestHandler(req, res);
|
|
}
|
|
throw new Error("Invariant request handler was not setup");
|
|
};
|
|
let upgradeHandler = async (req, socket, head)=>{
|
|
if (handlersPromise) {
|
|
await handlersPromise;
|
|
return upgradeHandler(req, socket, head);
|
|
}
|
|
throw new Error("Invariant upgrade handler was not setup");
|
|
};
|
|
// setup server listener as fast as possible
|
|
if (selfSignedCertificate && !isDev) {
|
|
throw new Error("Using a self signed certificate is only supported with `next dev`.");
|
|
}
|
|
async function requestListener(req, res) {
|
|
try {
|
|
if (handlersPromise) {
|
|
await handlersPromise;
|
|
handlersPromise = undefined;
|
|
}
|
|
await requestHandler(req, res);
|
|
} catch (err) {
|
|
res.statusCode = 500;
|
|
res.end("Internal Server Error");
|
|
_log.error(`Failed to handle request for ${req.url}`);
|
|
console.error(err);
|
|
} finally{
|
|
if (isDev) {
|
|
if (_v8.default.getHeapStatistics().used_heap_size > 0.8 * _v8.default.getHeapStatistics().heap_size_limit) {
|
|
_log.warn(`Server is approaching the used memory threshold, restarting...`);
|
|
(0, _trace.trace)("server-restart-close-to-memory-threshold", undefined, {
|
|
"memory.heapSizeLimit": String(_v8.default.getHeapStatistics().heap_size_limit),
|
|
"memory.heapUsed": String(_v8.default.getHeapStatistics().used_heap_size)
|
|
}).stop();
|
|
await (0, _trace.flushAllTraces)();
|
|
process.exit(_utils.RESTART_EXIT_CODE);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
const server = selfSignedCertificate ? _https.default.createServer({
|
|
key: _fs.default.readFileSync(selfSignedCertificate.key),
|
|
cert: _fs.default.readFileSync(selfSignedCertificate.cert)
|
|
}, requestListener) : _http.default.createServer(requestListener);
|
|
if (keepAliveTimeout) {
|
|
server.keepAliveTimeout = keepAliveTimeout;
|
|
}
|
|
server.on("upgrade", async (req, socket, head)=>{
|
|
try {
|
|
await upgradeHandler(req, socket, head);
|
|
} catch (err) {
|
|
socket.destroy();
|
|
_log.error(`Failed to handle request for ${req.url}`);
|
|
console.error(err);
|
|
}
|
|
});
|
|
let portRetryCount = 0;
|
|
server.on("error", (err)=>{
|
|
if (allowRetry && port && isDev && err.code === "EADDRINUSE" && portRetryCount < 10) {
|
|
_log.warn(`Port ${port} is in use, trying ${port + 1} instead.`);
|
|
port += 1;
|
|
portRetryCount += 1;
|
|
server.listen(port, hostname);
|
|
} else {
|
|
_log.error(`Failed to start server`);
|
|
console.error(err);
|
|
process.exit(1);
|
|
}
|
|
});
|
|
const nodeDebugType = (0, _utils.checkNodeDebugType)();
|
|
await new Promise((resolve)=>{
|
|
server.on("listening", async ()=>{
|
|
const addr = server.address();
|
|
const actualHostname = (0, _formathostname.formatHostname)(typeof addr === "object" ? (addr == null ? void 0 : addr.address) || hostname || "localhost" : addr);
|
|
const formattedHostname = !hostname || actualHostname === "0.0.0.0" ? "localhost" : actualHostname === "[::]" ? "[::1]" : (0, _formathostname.formatHostname)(hostname);
|
|
port = typeof addr === "object" ? (addr == null ? void 0 : addr.port) || port : port;
|
|
const networkUrl = hostname ? `http://${actualHostname}:${port}` : null;
|
|
const appUrl = `${selfSignedCertificate ? "https" : "http"}://${formattedHostname}:${port}`;
|
|
if (nodeDebugType) {
|
|
const debugPort = (0, _utils.getDebugPort)();
|
|
_log.info(`the --${nodeDebugType} option was detected, the Next.js router server should be inspected at port ${debugPort}.`);
|
|
}
|
|
// expose the main port to render workers
|
|
process.env.PORT = port + "";
|
|
process.env.__NEXT_PRIVATE_HOST = `${actualHostname}:${port}`;
|
|
// Only load env and config in dev to for logging purposes
|
|
let envInfo;
|
|
let expFeatureInfo;
|
|
if (isDev) {
|
|
const startServerInfo = await (0, _appinfolog.getStartServerInfo)(dir);
|
|
envInfo = startServerInfo.envInfo;
|
|
expFeatureInfo = startServerInfo.expFeatureInfo;
|
|
}
|
|
(0, _appinfolog.logStartInfo)({
|
|
networkUrl,
|
|
appUrl,
|
|
envInfo,
|
|
expFeatureInfo,
|
|
maxExperimentalFeatures: 3
|
|
});
|
|
try {
|
|
const cleanup = ()=>{
|
|
debug("start-server process cleanup");
|
|
server.close(()=>process.exit(0));
|
|
};
|
|
const exception = (err)=>{
|
|
if ((0, _ispostpone.isPostpone)(err)) {
|
|
// React postpones that are unhandled might end up logged here but they're
|
|
// not really errors. They're just part of rendering.
|
|
return;
|
|
}
|
|
// This is the render worker, we keep the process alive
|
|
console.error(err);
|
|
};
|
|
// Make sure commands gracefully respect termination signals (e.g. from Docker)
|
|
// Allow the graceful termination to be manually configurable
|
|
if (!process.env.NEXT_MANUAL_SIG_HANDLE) {
|
|
process.on("SIGINT", cleanup);
|
|
process.on("SIGTERM", cleanup);
|
|
}
|
|
process.on("rejectionHandled", ()=>{
|
|
// It is ok to await a Promise late in Next.js as it allows for better
|
|
// prefetching patterns to avoid waterfalls. We ignore loggining these.
|
|
// We should've already errored in anyway unhandledRejection.
|
|
});
|
|
process.on("uncaughtException", exception);
|
|
process.on("unhandledRejection", exception);
|
|
const initResult = await getRequestHandlers({
|
|
dir,
|
|
port,
|
|
isDev,
|
|
server,
|
|
hostname,
|
|
minimalMode,
|
|
isNodeDebugging: Boolean(nodeDebugType),
|
|
keepAliveTimeout,
|
|
experimentalTestProxy: !!isExperimentalTestProxy,
|
|
experimentalHttpsServer: !!selfSignedCertificate
|
|
});
|
|
requestHandler = initResult[0];
|
|
upgradeHandler = initResult[1];
|
|
const startServerProcessDuration = performance.mark("next-start-end") && performance.measure("next-start-duration", "next-start", "next-start-end").duration;
|
|
handlersReady();
|
|
const formatDurationText = startServerProcessDuration > 2000 ? `${Math.round(startServerProcessDuration / 100) / 10}s` : `${Math.round(startServerProcessDuration)}ms`;
|
|
_log.event(`Ready in ${formatDurationText}`);
|
|
if (process.env.TURBOPACK) {
|
|
await (0, _turbopackwarning.validateTurboNextConfig)({
|
|
...serverOptions,
|
|
isDev: true
|
|
});
|
|
}
|
|
} catch (err) {
|
|
// fatal error if we can't setup
|
|
handlersError();
|
|
console.error(err);
|
|
process.exit(1);
|
|
}
|
|
resolve();
|
|
});
|
|
server.listen(port, hostname);
|
|
});
|
|
if (isDev) {
|
|
function watchConfigFiles(dirToWatch, onChange) {
|
|
const wp = new _watchpack.default();
|
|
wp.watch({
|
|
files: _constants.CONFIG_FILES.map((file)=>_path.default.join(dirToWatch, file))
|
|
});
|
|
wp.on("change", onChange);
|
|
}
|
|
watchConfigFiles(dir, async (filename)=>{
|
|
if (process.env.__NEXT_DISABLE_MEMORY_WATCHER) {
|
|
_log.info(`Detected change, manual restart required due to '__NEXT_DISABLE_MEMORY_WATCHER' usage`);
|
|
return;
|
|
}
|
|
_log.warn(`Found a change in ${_path.default.basename(filename)}. Restarting the server to apply the changes...`);
|
|
process.exit(_utils.RESTART_EXIT_CODE);
|
|
});
|
|
}
|
|
}
|
|
if (process.env.NEXT_PRIVATE_WORKER && process.send) {
|
|
process.addListener("message", async (msg)=>{
|
|
if (msg && typeof msg && msg.nextWorkerOptions && process.send) {
|
|
startServerSpan = (0, _trace.trace)("start-dev-server", undefined, {
|
|
cpus: String(_os.default.cpus().length),
|
|
platform: _os.default.platform(),
|
|
"memory.freeMem": String(_os.default.freemem()),
|
|
"memory.totalMem": String(_os.default.totalmem()),
|
|
"memory.heapSizeLimit": String(_v8.default.getHeapStatistics().heap_size_limit)
|
|
});
|
|
await startServerSpan.traceAsyncFn(()=>startServer(msg.nextWorkerOptions));
|
|
const memoryUsage = process.memoryUsage();
|
|
startServerSpan.setAttribute("memory.rss", String(memoryUsage.rss));
|
|
startServerSpan.setAttribute("memory.heapTotal", String(memoryUsage.heapTotal));
|
|
startServerSpan.setAttribute("memory.heapUsed", String(memoryUsage.heapUsed));
|
|
process.send({
|
|
nextServerReady: true
|
|
});
|
|
}
|
|
});
|
|
process.send({
|
|
nextWorkerReady: true
|
|
});
|
|
}
|
|
|
|
//# sourceMappingURL=start-server.js.map
|