一,前言

到今天正好接触编程或者说接触前端一年,一直想写个自己的网站,无奈一直忙(一直技术很菜),不会后端,仅仅学了node,不会部署,项目一直跑在本地,很难受。正好这几天闲下来,就趁摸鱼时间,整理下之前的内容。主要是打通这么个流程。也给有需要的小伙伴点参考。
本文主要是说部署配置的流程,例子就用了个最简单的前后台项目,前端vue,后台koa2,数据库是mysql。
读完本文可以学会:
1,将node后台项目部署到服务器上
2,云服务器上添加mysql
3,本地开发前后端项目时,可以直接连上使用云服务器上的数据库
4,将本地的前端项目也部署到服务器上

二,koa项目部署到服务器上

1,前后端项目准备

这是我准备的项目,半年前刚接触koa,用它连接mysql时写的,里面有具体的代码和项目地址(mysql的表格名,用户名密码啥的得对应你自己的改改):

2,把node的koa2项目部署到服务器上

这个也是我之前写的,有些地方比较麻烦,可以参考下,不看也行:

上面这篇文章里面有购买云服务器,安装宝塔面板的教程。安装完宝塔面板之后,安装的有这么几个软件:

第一步:购买云服务器和安装宝塔面板

这篇文章的内容网上都可以找到,就是购买云服务器和安装宝塔面板的教程,比较简单。

第二步:安装PM2来监听服务

第一次打开宝塔面板时,推荐安装的是php环境,这些都安装了之后。而我写的是node.js,所以需要安装node。

后续我们把后端代码放到云服务器之后,退出服务器后node进程就自动关了,项目也就自动关闭了所以我们需要 pm2 来守护进程。而pm2安装的时候,会自动帮助我们安装好node环境。

宝塔面板上搜索到,直接安装就行:

宝塔面板能安装python 宝塔面板安装node环境_数据库


(上图中的软件都是第一次打开宝塔面板时推荐安装的,最好都安装下。)

第三步,把本地的koa项目上传到服务器

这里有很多办法,宝塔面板有内置,ftp,xshell等工具也是可以的。
我使用的是finalshell,这个连接服务器真的很好用,强烈推荐。软件的windows版本下载地址:

http://www.hostbuf.com/downloads/finalshell_install.exe 下图的账号密码等信息就是你自己云服务器的信息:

宝塔面板能安装python 宝塔面板安装node环境_云服务_02


连接上云服务器后,先进入自己云服务器的网站空间

cd www/wwwroot

宝塔面板能安装python 宝塔面板安装node环境_服务器_03


新建一个文件夹来存放后端项目的代码,然后直接把后台项目的源代码这部分上传上去(尽量不要传node_modules,它比较大,太耗时间):

宝塔面板能安装python 宝塔面板安装node环境_数据库_04


然后在终端中进入这个文件夹,运行

npm install

刷新下,就会发现有node_modules生成了:

宝塔面板能安装python 宝塔面板安装node环境_云服务_05

第四步,让pm2来管理启动项目

PM2可以查看运行日志,可以停止,可以重启,他的最主要作用还是守护进程。

因为当我们退出服务器后node进程就自动关了,项目也就自动关闭了所以我们需要 pm2 来守护进程。

宝塔面板能安装python 宝塔面板安装node环境_服务器_06


然后启动PM2即可在服务器上运行这个koa项目:

宝塔面板能安装python 宝塔面板安装node环境_宝塔面板能安装python_07

第五步,云服务器安全组设置开放端口

到目前为止,我们已经把koa项目部署到云服务器上了。但是还不能访问,需要做两个事情。

1,去腾讯云服务器上,在安全组那边 把5000端口(就是这个服务器端口)设置入站规则,意思就是其他人可以访问这个端口:

宝塔面板能安装python 宝塔面板安装node环境_云服务_08


2,Linux防火墙开启5000端口

需要运行这个命令(暂时不要运行):

firewall-cmd --add-port=5000/tcp

这个是因为我们的云服务器安装了宝塔面板之后,它默认给我们开启了云服务器的防火墙,所以多了这一步,后续我们连接数据库,这里还会有坑,所以我的处理是直接把服务器的防火墙关闭掉:
先查看防火墙的状态,
Centos7,配置防火墙

1.查看已开放的端口(默认不开放任何端口)
    firewall-cmd --list-ports
 2.停止防火墙
    systemctl stop firewalld

我关闭掉之后是这样的:

宝塔面板能安装python 宝塔面板安装node环境_云服务_09


这里需要注意的是,以后维护系统时,重启服务器,使用宝塔面板,他会自动开启防火墙,所以还是要手动关闭一下。

第六步,测试是否部署成功

访问koa项目中的测试接口,如下图则说明部署koa项目到服务器上成功。

宝塔面板能安装python 宝塔面板安装node环境_宝塔面板能安装python_10

三,新建服务器上的数据库

第一步,新建数据库

以上的配置,仅仅是把node项目运行在服务器上,当运行有查询数据库的接口时,就会报500,这是因为连接不上服务器。

在宝塔面板中新建数据库,

宝塔面板能安装python 宝塔面板安装node环境_数据库_11


然后修改上传上去的后台代码:

宝塔面板能安装python 宝塔面板安装node环境_云服务_12


主要修改这个数据库的参数:

宝塔面板能安装python 宝塔面板安装node环境_云服务_13

var mysql = require('mysql');

//封装的query方法
let query = function(sql,values){
	var connection = mysql.createConnection({
	  host: 'localhost',   //主机地址,默认localhost
	  user: 'roota',      //数据库账号名
	  password: 'password',   //数据库密码
	  database: 'testdata'     //连接的数据库名
	});
    return new Promise((resolve,reject) => {
		//先连接
        connection.connect(function(err){
            if(err){
                reject(err);
				console.log("数据库连接失败")
            }else{
				//连接成功才查询
				console.log("数据库连接成功")
                connection.query(sql,values,(err,rows) => {
                    if(err){
                        reject(err);
                    }else{
                        resolve(rows);
                    }
					//关闭connection
					connection.end(function(err){
					    if(err){ 
					        return;
					    }
					    console.log('关闭数据库连接');
					});
                })
				
            }
        })
    })
}
module.exports = query;

第二步,本地连接服务器上的数据库

需要先在云服务器的安全组添加入站规则:数据库端口3036:

宝塔面板能安装python 宝塔面板安装node环境_数据库_14


另外,需要在宝塔面板上设置防火墙的数据库连接端口3036,但是上文中,我已经把防火墙直接关闭了,所以这里就可以不设置:

宝塔面板能安装python 宝塔面板安装node环境_数据库_15


并且创建的数据库访问权限也要修改下:

1,本地数据库:仅仅本云服务器上后台代码可以访问,为了安全,不连接本地时可以切换成这个。
2,所有人:任何人都可以修改,只要你知道我这个服务器的ip,数据库的名称,用户名,密码。都可以连接上,并修改我的这个数据库。
3,指定ip:只有限定的白名单内的才可以。

宝塔面板能安装python 宝塔面板安装node环境_云服务_16


然后连接数据库:

宝塔面板能安装python 宝塔面板安装node环境_数据库_17


连接好之后,创建项目需要的list:

宝塔面板能安装python 宝塔面板安装node环境_服务器_18


于是在宝塔面板的数据库中,就会对应生成数据库:

宝塔面板能安装python 宝塔面板安装node环境_云服务_19


也就是说,到目前为止,这时候服务器上已经有了koa的后台代码,并且有了mysql数据库,且对于这个后台代码而言,数据库的连接信息是:

var connection = mysql.createConnection({
	  host: 'localhost',   //主机地址,默认localhost,部署到自己的云服务器上也是localhost,因为相对于服务器上的koa代码,数据库也在同一个服务器上
	  port:'3306',
	  user: 'roota',      //数据库账号名
	  password: 'password',   //数据库密码
	  database: 'testdata'     //连接的数据库名
	});

于是这时候,浏览器调用需要访问数据库的接口:

宝塔面板能安装python 宝塔面板安装node环境_宝塔面板能安装python_20


可以看到,返回了数据库的信息,所以说,到目前为止,koa后台项目,连同mysql数据库已经完全部署到了云服务器上面了。

四,本地开发时,使用云服务器上的数据库

到这一步,我要是想在本地开发完善koa后台项目,和前端代码,那我也是要使用数据库的,我希望我本地修改的koa,使用的和云服务器上的是同一个数据库(保证数据统一,免得还需要手动同步数据)。
直接修改连接数据库的参数:

let query = function(sql,values){
	var connection = mysql.createConnection({
	  host: '118.25.12.244',   //主机地址,默认localhost,部署到自己的云服务器上也是localhost
	  port:'3306',
	  user: 'roota',      //数据库账号名
	  password: 'password',   //数据库密码
	  database: 'testdata'     //连接的数据库名
	});

就是把那个host直接修改成自己服务器的ip地址。这样访问的数据库就是云服务器上创建的数据库了。

测试一下,同时启动本地的前端和后台项目:

宝塔面板能安装python 宝塔面板安装node环境_数据库_21


可以看到,返回渲染出来的,就是云服务器数据库中的信息。

这样一来,就可以保证本地开发时的数据库和云服务器上的数据库保持一致(实际工作中是有生产环境,测试环境的。我是因为折腾的是自己的后台,数据库保证一致更适合我,所以才这么搞哈!切勿把这个用在工作中~~)

五,开发完毕后,将本地的vue项目部署到云服务器上面

上文已经完成了后台项目的服务器部署,接下来则是在本地的前端开发完毕之后,部署到服务器上面。

第一步:宝塔面板上创建站点

宝塔面板能安装python 宝塔面板安装node环境_服务器_22

第二步:在自己本地vue项目,npm run build

这一步,咱们做前端的超级熟,不多说哈。打包得到的dist文件夹:

宝塔面板能安装python 宝塔面板安装node环境_服务器_23

第三步:把dist文件夹中打包的文件通过finalshell部署到服务器上

实际上就是把编译后的前端代码放到服务器上:

宝塔面板能安装python 宝塔面板安装node环境_服务器_24

第四步:打开浏览器检验下

宝塔面板能安装python 宝塔面板安装node环境_数据库_25


非常完美,嘿嘿。

(备注:因为一直在本地和服务器间切换,所以,你clone下来的我的这个前后端项目的配置,对应的访问接口路径,访问数据库信息得对应微调下,这个只要区分好本地和服务器就很好处理。)