如何打包vue项目加node.js后端到云服务器

JavaScript027

如何打包vue项目加node.js后端到云服务器,第1张

在命令行输入npm run build:prod,等待打包完成

项目目录下就会多出一个dist文件夹,里面有index.html文件和static文件夹,

直接上传到服务器上就行了

先确认下系统环境合不合要求

Python -V(确认python版本大于2.6)

访问http://nodejs.org/download/下载需要的Node.js版本(wget

http://nodejs.org/dist/v0.10.26/node-v0.10.29.tar.gz )

解压 tar zxvf node-v0.10.26-linux-x64.tar.gz

进入目录 cd node-v0.10.26-linux-x64

./configure --prefix=/home/work/setups/node-v0.10.26

make

sudo make install

添加到系统环境 echo "export PATH=$PATH:/home/work/setups/node-v0.10.26/bin">>

~/.bash_profile

. ~/.bash_profile执行该文件更新$PATH变量

###安装Express

sudo npm install express

-gd g参数:把express安装到NodeJS的lib目录d参数:同时安装依赖模块包

sudo npm install forever -gd

(异常情况:

如果遇到npm 找不到的情况 确认sudo node -v是否找不到 找不到的话:需要added /usr/local/bin to secure_path in /etc/sudoers :

sudo visudo

把 Defaultssecure_path =

/sbin:/bin:/usr/sbin:/usr/bin 这行 改为 Defaultssecure_path = /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin然后:x保存退出

如果遇到

npm ERR! Error: Hostname/IP doesn't match certificate's altnames

执行 npm config set strict-ssl false

如果遇到 npm ERR! registry error parsing json

npm cache clean

执行npm config set registry http://registry.npmjs.eu/

)

###部署forever

$ npm install -g forever

启动

NODE_ENV=pro LANG='zh' /usr/local/bin/foreverstart-o

/home/work/log/node_out.log-e /home/work/log/node_err.log /home/work/webroot/index.js

NODE_ENV=pro环境变量 pro为生产环境(程序中可以指定)

LANG环境变量 指定默认语言

node_out.log输出日志 注意路径别抄成我的了

node_err.log错误日志

index.js 启动文件

不知不觉间,2019已经接近尾声,在这一年里,我们看到了很多技术的长足发展,其中就包括NodeJS,它已经变得越来越流行,NPM上的各种功能模块(Package)的发布总数,也呈井喷之势,早早的就跨越了100万大关,成为了这个星球上最大的开源库集合。不

更令人惊喜的是,作为一种Web服务器端的技术,在2019年度,我们看到了业界,在基于NodeJS,构建健壮的**内容管理系统(CMS)**这一应用领域上的持续发力,一批充满现代意味、方便、实用的CMS产品被纷纷推出,下面所列的,则是在2019年度,被广泛使用的一些CMS产品,正在希望使用NodeJS,开发相关以内容管理为核心的网站的朋友,不妨可以关注下。

至于能不能像WordPress一样,成为一款现象级的CMS产品,就一切都要靠时间去检验了,拭目以待吧。

1. KeystoneJs

KeystoneJs是一款功能强大的NodeJs CMS框架。除了其本身提供了丰富而强壮的CMS基础功能外,KeystoneJs还可以用于开发RESTful API的应用、各种非CMS的应用程序,如电子商务平台或者在线论坛等。

特别的,KeystoneJs提供了简化的Admin UI,可帮助开发人员快速的创建美观但功能复杂的CMS后台管理功能。

KeystoneJs的其他一些主要特性如下:

KeystoneJS使用MongoDB数据库进行数据存储,并借助于Mongoose实现了有效的对象文档映射(ODM)。

通过KeystoneJS MVC架构,并使用KeystoneJS的内置模板,可以快速的构建基于数据的相关页面呈现功能。

只需要少量的一些工作,开发人员就能在KeystoneJS的基础上,实现自定义的路由,并实现各种定制功能的开发。

KeystoneJS非常轻量级,同时为数据库管理提供了丰富的API,这对于构建面向内容的网站来说,是非常重要的。

2. Ghost CMS

如果在几年前,以Ghost为代表的Headless(无头类)类的CMS系统,还只是CMS中的一个不特别被人关注的分支的话,那么,2019年度,在CMS领域,最应该引起人关注的,就是Headless(无头类)类的CMS系统,已经蔚为壮观,渐成主流。

这一现象,反映了一个不争的现实,即:一个后台,多种前端,已经越来越成为了业界基本的形态。

Ghost总体来说,更加适合于构建功能复杂的博客类平台,这也是为什么,一众公司,如苹果(Apple)、天空新闻(SkyNews)等都使用Ghost CMS的原因所在。

首先,Ghost的整体设计是非常干净,简单,舒适的,几乎零配置就能拥有非常友好的内容编辑接口。

其次,Ghost内置了强大的SEO功能。您可以在Ghost里,就准备好所有的站点地图、元数据、AMPs、规范标记等等等等和SEO相关的内容。

3. Strapi CMS

了解了Ghost的优雅,不妨来认识下另一个,在2019年度发展堪称迅猛的框架:Strapi CMS!

和Ghost一样,这也是一个Headless的CMS框架,它为开发人员提供了一个强大的、自托管的、高度可定制的内容API系统。

因此,Strapi非常适用于开发系统级别的、具有良好配置、易于管理的Web和移动端应用程序。