本地项目部署至服务器-下

背景

  • 已部署好node环境和mongodb的阿里云轻量级服务器,域名。
  • vue-tool :node.js搭建的后台 vue-tool
  • vue-first:使用vue框架的简单应用 vue-first

准备工作

连接阿里云

  • 启动防火墙
    systemctl start firewalld
    
  • 开启外部网络访问5000端口(这个端口注意是我的node项目启动的端口哦)
    firewall-cmd --permanent --add-port=5000/tcp
    
  • 刷新防火墙
    firewall-cmd --reload
    
  • 重启防火墙
    systemctl restart firewalld
    
  • 注意要在阿里云添加安全组
    本地项目部署至服务器-下_第1张图片

vue-tool的部署

  1. 在/home目录创建新的文件夹vue-tool
  2. 利用WinSCP将本地的vue-tool项目除了node_moudel文件夹复制到阿里云服务器/home/vue-tool中
  3. 进入到/home/vue-tool npm install初始化项目
  4. 配置项目为长久运行状态
    1. 安装forever
      npm install forever -g
    2. 运行项目:forever start app.js
      如果此时报错,无法识别forever命令就用软连接(下面有讲)

vue-first的部署

1.初始化项目

  1. 在/home目录创建新的文件夹vue-firstl
  2. 利用WinSCP将本地的vue-first项目除了node_moudel文件夹复制到阿里云服务器/home/vue-first中
  3. 进入到/home/vue-tool npm install初始化项目

这时候遇到问题发现:

{ Error: EACCES: permission denied, mkdir ‘/developer/git-repo/shop-backend/node_modules/node-sass/vendor’

查资料发现 问题原因:权限不足;
解决办法sudo npm install

继续尝试发现问题

sudo npm command not found

解决方法:
输入which npm可以得到/usr/local/bin/npm,这个是普通用户的bin目录 而sudo执行的是/usr/bin目录,这是root用户的目录 。通过软连接解决:

sudo ln -s /usr/local/bin/npm /usr/bin/npm

如果遇到相似的问题,只要将xxx替换成可执行程序就可以了

sudo ln -s /usr/local/bin/xxx /usr/bin/xxx

2.运行项目

  1. 初始化项目成功以后:npm run dev
    出现错误/usr/bin/env: node: No such file or directory

推测因为npm执行的时候默认是使用/usr/bin/node去执行的,但本地是没有/usr/bin/node的,所以需要创建一个软连接将自己的node的执行文件指到/usr/bin/node上,于是修改如下:

ln -s /home/node/node_v12.14.0/bin/node /usr/bin/node

再次执行npm run dev成功,但出现问题"g++: Command not found"
解决方法:

  • 检查版本:*yum search "gcc-c++*"
  • 按版本安装:yum install "gcc-c++.x86_64" -y
  1. 项目运行成功:但是发现外部无法访问
    **解决办法:**进入项目文件/home/vue-first vi package.json修改package.json 文件本地项目部署至服务器-下_第2张图片

3.配置项目为长久运行状态

  • 命令输入which nohup 返回的地址一般是 /usr/bin

  • 编辑用户环境变量:
    命令行输入: vi ~/.bash_profile

    在它的最后一行,即 PATH=$PATH:$HOME/bin 的后面添加刚才查询的地址本地项目部署至服务器-下_第3张图片

  • 加载环境变量: source ~/.bash_profile

  • 在项目目录中执行启动命令: nohup npm run dev &

  • 然后exit

此时关掉终端,还能访问就是成功了。

最后附上参考的文章:
sudo npm command not found 问题解决
解决Linux "g++: Command not found"报错问题
让 vue项目在Linux后台持久运行 npm run dev

你可能感兴趣的:(本地项目部署至服务器-下)