Vue+Koa2 打包后进行线上部署的教程详解
最近使用Vue和Koa2重构了自己的博客,过程中踩了不少坑,查了很多资料,最后总算成功上线。之后我计划围绕这个过程写一系列文章,讲讲如何用Vue+Koa2写一套网站。
而现在,先来讲讲最后一步,在写完Vue和Koa2后,如何将它们部署到线上。
1.将Vue和Koa2结合
很多人在打完包后就不知道怎么做了,毕竟后面都是后端的事情。如果你用的是Vue-cli3.0,那么打包这一步会非常简单,只需要执行一条命令即可,其它的不用关心:
npm run build
之后会生成一个dist的文件夹,将它放到Koa2目录下的public文件里,然后在Koa2的配置文件app.js里将静态资源指向这个文件夹,指向命令在我们创建Koa2框架时就已经自动生成,所以我们要做的也只是改一下文件地址就行了:
app.use(require('koa-static')(__dirname + '/public/dist'))
改好之后打开koa2的主页,看看是否加载成功,第一步就愉快地完成了。
2.Nginx配置
现在登录服务器,安装完Nginx后,在`/etc/nginx/sites-enabled/`下新建一个conf文件,然后写入配置:
//Koa的端口一般默认是3000 upstream koa.server{ server 127.0.0.1:3000; } server { listen 80; server_name .******.com; location / { proxy_pass http://koa.server; proxy_redirect off; } }
写完之后重启Nginx:
sudo /etc/init.d/nginx restart
接着将Koa2文件上传到服务器,启动后在浏览器里输入你的网址或者服务器ip,能访问到就大功告成了。
当然,这套Nginx配置还是非常简陋,如果希望长期稳定运行的话还得加入SSL和Gzip,网上资料很多,如果以后有机会的话我也会讲一下。
3.使用Pm2进行进程管理
能成功访问后接着就是将Koa放到后台运行,这里使用了Pm2进行管理,先来安装:
npm install -g pm2
安装好后在Koa目录下创建一个文件 “pm2.conf.json”,然后输入以下代码:
{ "apps":{ "name":"blog", "script": "bin/www", "watch": true, "ignore_watch":[ "node_modules", "logs" ], "instances":2, "error_file":"logs/err.log", "out_file":"logs/out.log", "log_date_format": "YYYY-MM-DD HH:mm:ss" } }
来重点说下两个参数,watch和instances。
Watch是检测到文件有改动会自动重启加载,ignore_watch则是排除不需要监控的文件。
Instances则是开启实例数,建议根据cpu核数进行配置,有多少核就开启多少条。
最后启动:
pm2 start pm2.conf.json
到这里,网站就部署完成了!
总结