自訂伺服器
Next.js 預設包含自己的伺服器,可使用 next start
啟動。如果您已擁有後端,仍然可以將其與 Next.js 搭配使用(這不是自訂伺服器)。自訂 Next.js 伺服器允許您以程式化方式啟動伺服器以實現自訂模式。大多數情況下,您不需要這種方法。但是,如果您需要退出預設設定,可以使用它。
注意事項 (Good to know):
參考以下範例,了解如何建立自訂伺服器
server.ts
import { createServer } from 'http'
import { parse } from 'url'
import next from 'next'
const port = parseInt(process.env.PORT || '3000', 10)
const dev = process.env.NODE_ENV !== 'production'
const app = next({ dev })
const handle = app.getRequestHandler()
app.prepare().then(() => {
createServer((req, res) => {
const parsedUrl = parse(req.url!, true)
handle(req, res, parsedUrl)
}).listen(port)
console.log(
`> Server listening at https://127.0.0.1:${port} as ${
dev ? 'development' : process.env.NODE_ENV
}`
)
})
server.js
並不會經過 Next.js 編譯器或打包程序。請確保此檔案所需的語法和原始碼與您目前使用的 Node.js 版本相容。參考一個範例。
要執行自訂伺服器,您需要像這樣更新 package.json
中的 scripts
package.json
{
"scripts": {
"dev": "node server.js",
"build": "next build",
"start": "NODE_ENV=production node server.js"
}
}
或者,您可以設定 nodemon
(範例)。自訂伺服器使用以下導入方式來將伺服器與 Next.js 應用程式連接
import next from 'next'
const app = next({})
上述的 next
導入是一個函式,它接收一個具有以下選項的物件
選項 | 類型 | 說明 |
---|---|---|
conf | 物件 | 與您在 next.config.js 中使用的物件相同。預設為 {} |
customServer | 布林值 | (*選用*)當伺服器由 Next.js 建立時,設為 false |
dev | 布林值 | 布林值 |
(*選用*)是否以開發模式啟動 Next.js。預設為 | dir | 字串 |
(*選用*)Next.js 專案的位置。預設為 | 布林值 | quiet |
布林值 | dir | (*選用*)隱藏包含伺服器資訊的錯誤訊息。預設為 false |
hostname | 字串 | (*選用*)伺服器執行的背後主機名稱 |
port | 數字 | (*選用*)伺服器執行的背後埠號 |
Turbo | 布林值 | httpServer |
node:http#Server
這個對您有幫助嗎?