1. 登录服务器
ssh root@111.11.111.1
输入密码
2. 配置node环境
我是先安装nvm ,node版本管理工具
curl -L -o- [http://build.sankuai.com/nvm/install](http://build.sankuai.com/nvm/install) | bash
安装成功之后
nvm install 8.9.3 //node 版本 会安装指定的node,以及对应的npm
3. 将前端页面发布到服务器
/usr/local/nginx/guide//发布目录
接口地址连接的就是服务端启动的端口加上后端服务器ip地址啦
就是按照正常的发布流程发布一下就可以了。
4. 将后端项目发布到服务器
/usr/local/nginx/guide //发布目录
因为后端项目我们没有打包依赖,所以需要在项目目录下面根据package.json包 install一下(因为发布项目的时候我们不仅把dist发布上去了 package.json文件也附带发布上去了
rsync -rtv dist/ 空格 package.json)
npm install //我们还需要把mongodb配置好才能启动服务
5. 安装mongodb
这里不重复介绍安装启动的相关知识了,在这篇总结中,我已经详细说过了(mongodb 安装使用总结)[https://www.jianshu.com/p/3fa9a42e369c]
运维给了一个admin数据库的账号,admin一般有很多内置角色。
[root@iZ23utc5vnhZ ~]# mongo
MongoDB shell version: 2.6.12
connecting to: test
> use admin
switched to db admin
> db.auth("user","password")
1
> show users
{
"_id" : "admin.10bei",
"user" : "10bei",
"db" : "admin",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}
6. 创建自己需要的数据库
use mydb //没有就会自动创建
我们接下来需要创建一个mydb的用户
db.createUser({
user: "root",
pwd: "123456",
roles: [
{ role: "dbAdmin", db: "ideacome-substation" } ,
{ role: "dbOwner", db: "ideacome-substation" } ,
{ role: "userAdmin", db: "ideacome-substation" }
]});//此处我把mydb数据库下面的大部分内建角色给了用户root。
之后我们操作mydb数据库都可以使用这个账号了。
7. 后端项目里面链接数据库
mongoose.connect('mongodb://127.0.0.1:27017/mydb'); //没有权限验证的情况连接
mongoose.connect('mongodb://root:123456@127.0.0.1:27017/mydb');//有验证情况下需要本数据库的账号密码
8. 启动服务
我们正确链接数据库之后,更新一下服务端代码,重新发布。然后启动项目node server.js。 不过为了保证退出之后项目处于启动状态。我们在服务器后端代码根目录下面写了一个脚本。
//run.sh
#!/bin/bash
stop() {
ps -ef|grep node|grep server.js|grep -v grep|awk '{print $2}'|xargs kill -9
}
start() {
cd /usr/local/nginx/substation
nohup node server.js > /usr/local/nginx/substation/nohup.out 2>&1 &
}
case $1 in
start)
start ;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo "只接受 start|stop|restart"
;;
esac
bash run.sh start //启动
bash run.sh stop //停止
bash run.sh restart //重启
9. 将本地数据库数据复制到服务器
走到这里 已经接近尾声了。因为第一次部署,有些本地数据库已经初始化的数据需要复制到服务器对应的数据库。
我们首先备份一下被动数据库数据。
mongodump -h 127.0.0.1:27017 -d ideacome-substation -o /Users/zhanglinyu/work/mongodb/mongodump
我们在服务器/usr/local/nginx/substation下面建一个文件夹
mkdir mongodump //存储备份的数据
我们将本地/Users/zhanglinyu/work/mongodb/mongodump下的数据发布到/usr/local/nginx/substation/mongodump目录下面
然后在服务端端执行
mongorestore
-h 127.0.0.1:27017
-d ideacome-substation
--dir /usr/local/nginx/substation/mongodump
-u root //用户
-p 123456 //密码
这样数据就备份进去了。
总结:本人第一次尝试部署,很多方法可能不是最简单的。
网友评论