美文网首页
记一次前端node服务器部署

记一次前端node服务器部署

作者: overflow_hidden | 来源:发表于2019-01-08 16:36 被阅读24次

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 //密码

这样数据就备份进去了。

总结:本人第一次尝试部署,很多方法可能不是最简单的。

相关文章

网友评论

      本文标题:记一次前端node服务器部署

      本文链接:https://www.haomeiwen.com/subject/vknvrqtx.html