通过 HTTP 提供静态文件
PM2 可以使用 pm2 serve
功能非常轻松地提供静态文件。它支持从指定文件夹提供原始文件,或者您可以使用它提供 SPA(单页应用程序)。
CLI
使用简单的命令通过 HTTP 提供静态文件(例如前端应用程序)
pm2 serve <path> <port>
如果您没有指定 <path>
,则将使用当前文件夹,默认端口为 8080
。您可以使用与普通应用程序相同的选项,例如 --name
或 --watch
。
进程文件
您可以在进程文件中声明要提供服务的特殊目录,方法如下
module.exports = {
script: "serve",
env: {
PM2_SERVE_PATH: '.',
PM2_SERVE_PORT: 8080
}
}
您只需要将 PM2_SERVE_PATH
和 PM2_SERVE_PORT
添加到环境变量中以指定路径和端口,默认值与 CLI 相同。
提供 SPA:将所有请求重定向到 index.html
要自动将所有查询重定向到 index.html,请使用 --spa
选项
pm2 serve --spa
通过进程文件
module.exports = {
script: "serve",
env: {
PM2_SERVE_PATH: '.',
PM2_SERVE_PORT: 8080,
PM2_SERVE_SPA: 'true',
PM2_SERVE_HOMEPAGE: './index.html'
}
}
使用密码保护访问
要对公开文件的访问进行基本保护,您可以使用 --basic-auth-username
和 --basic-auth-password
pm2 serve --basic-auth-username <username> --basic-auth-password <password>
通过进程文件
module.exports = {
script: "serve",
env: {
PM2_SERVE_PATH: '.',
PM2_SERVE_PORT: 8080,
PM2_SERVE_BASIC_AUTH: 'true',
PM2_SERVE_BASIC_AUTH_USERNAME: 'example-login',
PM2_SERVE_BASIC_AUTH_PASSWORD: 'example-password'
}
}