Я делаю это в одном из моих производственных приложений.
Мы готовим следующий объект приложения и запускаем экспресс-сервер.Это делается в файле server.js .Вы можете прочитать больше об этом в документах о пользовательском сервере .
. Next.js также имеет пример в своем github в папке примеров о пользовательском экспресс-сервере.Это здесь .
const express = require('express');
const next = require('next');
const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();
app
.prepare()
.then(() => {
const server = express();
server.use((req, res, next) => {
const hostname = req.hostname === 'www.app.domain.com' ? 'app.domain.com' : req.hostname;
if (req.headers['x-forwarded-proto'] === 'http' || req.hostname === 'www.app.domain.com') {
res.redirect(301, `https://${hostname}${req.url}`);
return;
}
res.setHeader('strict-transport-security', 'max-age=31536000; includeSubDomains; preload');
next();
});
server.get('*', (req, res) => handle(req, res));
server.listen(
4242,
error => {
if (error) throw error;
console.error('Listening on port 4242');
}
);
})
.catch(error => {
console.error(error);
process.exit(1);
});
Что касается развертывания в Heroku, вы можете просто настроить скрипт npm start , чтобы запускать следующие файлы следующим образом:
"scripts": {
"dev": "next",
"build": "next build",
"start": "next start"
}
Heroku также автоматически запускает npm run build , поэтому приложение должно быть создано для вас.