nuxt有两种打包方式
nuxt.config.js
文件需要对不同打包方式进行配置
target: 'server', //build打包用server,generate用static 默认 server
这是静态部署,比较简单
npm run generate
生成dist
文件夹,直接放到服务器就可以访问
但是 如果后台修改数据,前端还是显示之前打包的数据
npm run build
.nuxt
static
nuxt.config.js
package.json
把这四个文件放到远程服务器中的文件夹里
在远程服务器中安装node
cmd
这个文件夹,执行
npm install
npm run start
就能生成个本地链接进行访问
修改nginx.conf
配置反向代理
listen
后台去开设的端口为86
,默认为80
,因为被占用了
server_name
放你的代理的域名,不要带http://
proxy_pass
为你node启动的服务器地址,需要保持连接状态
项目nuxt.config.js
配置的server
server: {
port: 3000,
host: '0.0.0.0',
timing: false
},
upstream nodenuxt {
server 0.0.0.0:3000;
keepalive 64;
}
server {
listen 86;
server_name xxx.com;
location / {
proxy_pass http://nodenuxt;
}
}
必须要在nginx.exe
的目录下,打开cmd
,启动nginx
start nginx //启动nginx
nginx
常规命令如下
start nginx //启动nginx
nginx -s stop //停止/关闭nginx
nginx -s reload //重新启动nginx
nginx -t //检验nginx书写问题
taskkill /f /t /im nginx.exe //清除所有nginx进程
就可以IP地址
或域名
携带86
端口号访问了
如果需要域名能够在外网进行访问,需要配置服务器的防火墙
打开控制面板\系统和安全\Windows Defender 防火墙
路径下的允许应用通过Windows Defender 防火墙进行通信
点击允许其他应用
,浏览指定nginx.exe
文件,然后 添加
npm install pm2 -g
pm2
可以关闭了node服务窗口,还可以继续访问链接服务
在服务器项目的根目录新建ecosystem.config.js
文件
module.exports = {
apps: [
{
name: 'NuxtAppName',
exec_mode: 'cluster',
instances: 'max', // Or a number of instances
script: './node_modules/nuxt/bin/nuxt.js',
args: 'start'
}
]
}
项目目录下执行
pm2 start
status为online
就成功了
参考了nuxt官方pm2操作
pm2常规命令
pm2 delete id //删除指定id的pm2进程
pm2 delete all //删除全部进程
pm2 list //查看所有pm2进程