• nuxt项目打包上线之二


    之前写过一篇nuxt打包上线的文章,请看这里:https://www.cnblogs.com/daisygogogo/p/11218809.html

    上一篇文章的部署流程有点不好的地方,就是它适用于只有唯一一个后台接口路径的部署,不适合需要根据多个环境切换后台接口的情况。

    为了解决需要根据不同环境(本地,测试,线上)切换请求的baseURL,我们需要引入cross-env , 来实现环境变量的设置,根据环境变量来切换baseURL。

    为了设置环境变量,我们需要把打包的环节放到服务器,在服务器端进行打包。

    首先我们需要保证项目中已经安装了cross-env,并且在nuxt.config.js中设置了env变量

     env: { //环境变量
        __ENV: process.env.__ENV
      }

    package.json中也做了命令配置

      "scripts": {
        "test": "jest",
        "dev": "cross-env process.env.__ENV=dev nuxt",
        "build": "nuxt build",
        "build-testing": "cross-env process.env.__ENV=testing nuxt build",
        "rc": "cross-env process.env.__ENV=rc pm2 start npm --watch --name 'web-pc' -- run start",
        "serve": "cross-env process.env.__ENV=serve pm2 start npm --watch --name 'web-pc' -- run start",
        "start": "nuxt start",
        "generate": "nuxt generate"
      }

    在需要使用的地方就可以这么使用了,比如axios.js

      let baseURL = "";
      if(process.env.__ENV == 'rc'){
        baseURL = 'http://rc.xxx:8011'
      }else if(process.env.__ENV == 'production'){
        baseURL = 'https://www.xxx:4011'
      }else{
        baseURL = 'http://test.xxx:8011'
      }

    接下来就说说我的部署步骤,由于直接在服务器打包,我们需要安装所有项目的依赖,为了安装依赖速度能快一点,我使用了淘宝镜像源。

    第一:首次部署项目
    (1)服务器安装node 和pm2依赖
    服务器:切换到希望安装这两个依赖的目录下,依赖可以用于多个node项目,这里我新建了node_project文件夹
    --安装 node:
    第二步解压:xz -d node-v10.16.0-linux-x64.tar.xz tar -xvf node-v10.16.0-linux-x64.tar
    第三步重命名:mv node-v10.16.0-linux-x64 node
    第四步修改环境变量:vi ~/.bash_profile
    PATH=$PATH:$HOME/bin   // 修改前 PATH=$PATH:$HOME/bin:/usr/local/src/node/bin   // 修改后
    改好之后保存退出
    第五步编译刚刚修改的文件:source ~/.bash_profile
     
    --安装pm2
    npm i -g pm2
     
    --安装 cnpm
    cnpm -v
    查看是否安装了淘宝镜像源,有东西打印出来则已安装,没有则安装,安装完成之后
    npm install -g cnpm --registry=https://registry.npm.taobao.org
     
    安装完成后建立软链接: (如果不知道cnpm的位置,可以查找cnpm所在位置: find / -name cnpm)
    ln -s /usr/local/node_project/node/lib/node_modules/cnpm/bin/cnpm /usr/local/bin/cnpm
     
    再执行一下查看 cnpm-v 看是否安装成功
     
     
    --安装 unsafe-perm,避免个别依赖由于权限问题无法安装
    cnpm install --unsafe-perm
     
    (2) 从svn拉取项目代码到本地(全量拉取即可,前端忽略提交node_modules,.nuxt,.history文件夹),安装依赖 cnpm install
    (3) 根据不同环境打包项目
    测试环境:npm run build-test
    rc环境: npm run build-rc
    线上环境: npm run build-production
    (4)启动项目:pm2 start npm --name "official-website" -- run start
     
    第二:后续更新项目
    (1):从svn拉取最新代码
    (2):切换到项目目录下执行 cnpm install
    (3):根据环境打包项目:
    npm run build-test
    npm run build-rc
    npm run build-production
    (4)pm2重启项目 pm2 restart official-website, official-website为上面启动pm2的时候的项目名
     
  • 相关阅读:
    OpenStack云桌面系列【2】—OpenStack和Spice
    Java中的读写锁 ReentrantReadWriteLock
    Spring Boot Actuator 监控实践
    java子线程中获取父线程的threadLocal中的值
    String源码解析
    Java基础一
    Java 8 Lambda表达式实现原理解析
    Rabbit MQ总结
    AtomicInteger及CAS源码解析
    Queue(队列)接口和其实现类PriorityQueue(优先级队列)源码解析
  • 原文地址:https://www.cnblogs.com/daisygogogo/p/11304421.html
Copyright © 2020-2023  润新知