本文档适合的场景是:解决因分布、带宽、服务器性能带来的访问延迟问题,将运行于 Rainbond 的 Nodejs 前端项目进行动静分离,经过 阿里云CDN 加速 对象存储OSS 中的静态资源,提高用户访问速度。css
实现原理:Rainbond 支持 Nodejs 前端项目的源码构建,在项目CI 结束后经过自定义脚本自动将静态文件(css,js,img等)推送至 对象存储OSS ,使用阿里云 CDN 对 对象存储OSS 中的静态资源进行加速,实现动静分离,有效提高内容加载速度。前端
操做步骤
Demo:好雨科技 Rainbond 前端开源项目 Rainbond-uigit
推送静态文件
npm 是 Nodejs 的包管理器,提供了 pre 和 post 两种钩子,对于任何在 package.json 的 scripts 字段中定义的命令,能够经过 pre 以及 post 名称前缀,额外定义该任务在执行前、后的额外执行的钩子命令。例如:docker
"postbuild" 中定义了在编译后须要执行的脚本 cdn_release.sh
npm
项目package.json文件json
{ "name": "rainbond-ui", "version": "5.3.0", "description": "rainbond front-end project.", "private": true, "scripts": { "start": "umi dev", "start:no-mock": "cross-env MOCK=none umi dev", "build": "umi build", "postbuild": "./cdn_release.sh", #在执行npm install以后,自动执行脚本cdn_release.sh "image": "umi build && docker build -t registry.cn-hangzhou.aliyuncs.com/goodrain/rainbond-ui:V5.2.1-pre-release .", "site": "roadhog-api-doc static && gh-pages -d dist", "analyze": "cross-env ANALYZE=true roadhog build" },
该脚本作了两件事: 1.安装 OSS 命令行工具 ossutil,若是对接其余CDN服务,安装不一样的文件上传工具。 2.将源码编译后的静态文件以日期分割推送至OSS,若是其余即推送到对应的CDN服务。api
通常同一个代码在开发测试阶段不须要发布到CDN,可使用环境变量ENABLE_CDN
控制是否开启CDN加速,在生产环境中设置该变量。缓存
环境变量CDN_ACCESS_KEY_ID``CDN_ACCESS_KEY_SECRET
定义阿里云OSS帐户信息,其余CDN服务以相似方式进行定义。bash
cdn_release.sh脚本服务器
#!/bin/bash osstool="./ossutil64" os=$(uname -s) osstool_install() { if [ ! -f ${osstool} ]; then echo "installing ossutil binary" if [ "$os" == "Darwin" ]; then wget http://gosspublic.alicdn.com/ossutil/1.6.14/ossutilmac64 -O ${osstool} else wget http://gosspublic.alicdn.com/ossutil/1.6.3/ossutil64 -O ${osstool} fi chmod +x ${osstool} cat >~/.ossutilconfig <<EOF [Credentials] language=CH endpoint=http://oss-cn-shanghai.aliyuncs.com accessKeyID=${CDN_ACCESS_KEY_ID} accessKeySecret=${CDN_ACCESS_KEY_SECRET} EOF fi } if [ "${ENABLE_CDN}" == 'true' ]; then echo "Upload static file to oss" osstool_install now_day=$(date '+%Y-%m-%d') ${osstool} mkdir "oss://grstatic/cdn-demo/publish/${now_day}/" ${osstool} cp -u -r dist/ "oss://grstatic/cdn-demo/publish/${now_day}/" fi
定义访问路径
静态资源推送至OSS之后,须要修改项目 css,js,img 资源访问路径,不然后续客户端的请求依然会发送至源站。
依然采用环境变量ENABLE_CDN
的方式进行控制,若是在编译过程当中检测到该环境变量值为true,则访问路径为OSS中的静态资源文件。
项目config.js文件
import defaultSettings from '../src/defaultSettings'; import routerConfig from './router.config'; import moment from 'moment'; const dayFormat = moment(new Date()) .locale('zh-cn') .format('YYYY-MM-DD'); let publcPath = '/static/dists/'; if (process.env.SEPARATION === 'true') { publcPath = `/`; } if (process.env.ENABLE_CDN === 'true') { //若是ENABLE_CDN环境变量的值为true,则路径以下 publcPath = `https://static.goodrain.com/cdn-demo/publish/${dayFormat}/`; }
使用该项目在平台中进行编译,编译过程当中添加如下环境变量
环境变量 | 值 | 简介 |
---|---|---|
BUILD_ENABLE_CDN | true | 是否开启CDN |
BUILD_CDN_ACCESS_KEY_ID | 阿里云OSS Access key | |
BUILD_CDN_ACCESS_KEY_SECRET | 阿里云OSS Access secret |
请注意,使用 BUILD_ 为前缀的变量在Rainbond中寓意是在构建阶段生效,生效时会移除 BUILD_ 前缀。
阿里云CDN加速OSS资源
参考 经过CDN加速OSS资源 进行阿里云CDN的配置,对静态资源进行缓存,配置完成后客户端访问 css,js,img 资源时将会优先从CDN获取。