发布Angular应用至生产环境的方法


Posted in Javascript onDecember 10, 2018

两年前, 写过一篇使用rollup 来 为生产环境编译 Angular 2 应用 的文章, 因为当时还没有 angular-cli 项目。 而如今 Angular 已经到了 7.x 版本, 对应的工具也是非常的完善, 也就不在使用 rollup 来处理 angular 项目。

angular-cli 用起来虽然方便, 但是针对生产环境编译的话, 还是有一些地方要注意的, 接下来就介绍我在项目部署时的一些做法。

合理拆分功能模块, 按需加载

一个系统往往功能非常多, 因此就要根据项目的实际情况划分功能模块,一个功能模块对应一个 NgModule , 编译成一个独立的 js 文件, 再结合 angular 的路由技术进行按需加载,就这一功能点来说, angular 的支持已经非常的完善了。

const routes: Routes = [
  { path: '', redirectTo: '/home', pathMatch: 'full' },
  { path: 'home', loadChildren: './home/home.module#HomeModule' },
  { path: 'about', loadChildren: './about/about.module#AboutModule' },
  {
    path: 'arcgis',
    loadChildren: './arcgis/arcgis.module#ArcgisModule',
    canLoad: [EsriLoaderGuard]
  }
];

这一点经常容易被忽视, 曾经就出现过犹豫没有合理划分模块, 导致编译出来的 js 文件高达 5 兆, 造成的客户体验非常差。 (甚至还出现开发机内存不足,无法成功编译的情况)

预先压缩 js 文件

当然, 仅仅考合理划分 js 模块的话, 还往往不太够, 因为单个模块也可能会比较大, 可能会超过 1 兆, 特别是使用了一些第三方控件(ng-bootstrap, ng-zorro 等)的情况下。

针对这种情况, 通常还需要对编译生成的 js 文件进行 gzip 压缩, 因此在执行 ng build --prod 编译之后, 再继续执行下面的 shell 命令:

find dist -name "*.js" -print0 | xargs -0 gzip -k

当然, 如果发现编译生成 css 文件比较大的话, 也可以通过下面的命令进行压缩:

find dist -name "*.css" -print0 | xargs -0 gzip -k

以一个仅仅使用了 ng-bootstrap 的模板项目为例, 生成的 js 文件如下所示:

1.8K dist/ng-seed/4.1495aba38157395f4a2d.js
 1.7K dist/ng-seed/5.ec7eb27ea7c8eee53bcc.js
 482K dist/ng-seed/main.6ee651175769ea64ed5f.js
 37K dist/ng-seed/polyfills.5d61d41949cb87471fa8.js
 2.2K dist/ng-seed/runtime.c66e13242c809a55bd2f.js

其中的 main.6ee651175769ea64ed5f.js 就有 482KB , 而经过 gzip 压缩之后, 文件大小显著减小:

1.8K dist/ng-seed/4.1495aba38157395f4a2d.js
1.0K dist/ng-seed/4.1495aba38157395f4a2d.js.gz
1.7K dist/ng-seed/5.ec7eb27ea7c8eee53bcc.js
888B dist/ng-seed/5.ec7eb27ea7c8eee53bcc.js.gz
482K dist/ng-seed/main.6ee651175769ea64ed5f.js
124K dist/ng-seed/main.6ee651175769ea64ed5f.js.gz
 37K dist/ng-seed/polyfills.5d61d41949cb87471fa8.js
 12K dist/ng-seed/polyfills.5d61d41949cb87471fa8.js.gz
2.2K dist/ng-seed/runtime.c66e13242c809a55bd2f.js
1.2K dist/ng-seed/runtime.c66e13242c809a55bd2f.js.gz

main.6ee651175769ea64ed5f.js.gz 有 124KB , 只有原来的 1/4 。

一般来说, 对于 angular 项目编译出的 js 文件, gzip 压缩能减少 3/4 甚至 4/5 的体积, 这样将会显著减轻网络传输的压力。

使用 nginx 作为服务器

为什么使用 nginx 作为前端服务器呢? 原因如下:

支持传输预先压缩的 js 文件

将预先压缩好的 .js.gz 和原来的 .js 文件一起上传到服务器, 只要在 nginx 服务器的配置文件上加一句 gzip_static on; 即可启用,这样在客户端请求 .js 文件时, nginx 会先检查一下是否存在对应的 .js.gz 文件, 如果存在的话, 就直接返回 .js.gz 文件的内容, 从而省去了在服务端进行压缩的过程, 节省服务器的资源。

location /ng-app {
  root  /usr/share/nginx/html;
  index index.html index.htm;
  gzip_static on;
  try_files $uri /ng-app/index.html;
}

作为后台接口的网关

nginx 支持反向代理, 可以作为后台接口的网关, 这样可以省去一些跨域调用 (cors) 的问题, 一般的反向代理配置如下:

location /api {
  proxy_pass http://api-server:8080/api;
  proxy_read_timeout 600s;
  proxy_redirect off;
  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header X-Forwarded-Proto $scheme;
}

官方的 docker 镜像

nginx 有 docker 的官方镜像, 部署、升级都是非常的方便。 不得不说docker 确实是好东西, 用了就停不下来了。

这几点都是在项目中积累的一些小技巧, 如果想要了解细节, 请查看这个ng-seed 项目。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
html页面显示年月日时分秒和星期几的两种方式
Aug 20 Javascript
jquery自动切换tabs选项卡的具体实现
Dec 24 Javascript
js实现简单的购物车有图有代码
May 26 Javascript
Node.js实现在目录中查找某个字符串及所在文件
Sep 03 Javascript
jQuery中offset()方法用法实例
Jan 16 Javascript
js实现鼠标移到链接文字弹出一个提示层的方法
May 11 Javascript
jQuery mobile 移动web(4)
Dec 20 Javascript
JS中的多态实例详解
Oct 15 Javascript
VueJs 搭建Axios接口请求工具
Nov 20 Javascript
Vue.js 十五分钟入门图文教程
Sep 12 Javascript
详解基于 Node.js 的轻量级云函数功能实现
Jul 08 Javascript
javaScript代码飘红报错看不懂?读完这篇文章再试试
Aug 19 Javascript
webpack优化的深入理解
Dec 10 #Javascript
BootStrap模态框闪退问题实例代码详解
Dec 10 #Javascript
详解为生产环境编译Angular2应用的方法
Dec 10 #Javascript
深入理解Vue.js轻量高效的前端组件化方案
Dec 10 #Javascript
es6基础学习之解构赋值
Dec 10 #Javascript
vue中将html字符串转换成html后遇到的问题小结
Dec 10 #Javascript
vue的.vue文件是怎么run起来的(vue-loader)
Dec 10 #Javascript
You might like
yii去掉必填项中星号的方法
2015/12/28 PHP
Laravel中七个非常有用但很少人知道的Carbon方法
2017/09/21 PHP
Smarty缓存机制实例详解【三种缓存方式】
2019/07/20 PHP
学习js所必须要知道的一些
2007/03/07 Javascript
JS 用6N±1法求素数 实例教程
2009/10/20 Javascript
浅谈Javascript嵌套函数及闭包
2010/11/09 Javascript
js获取url中的参数且参数为中文时通过js解码
2014/03/19 Javascript
javascript给span标签赋值的方法
2015/11/26 Javascript
jQuery Validate表单验证插件的基本使用方法及功能拓展
2017/01/04 Javascript
vue2+el-menu实现路由跳转及当前项的设置方法实例
2017/11/07 Javascript
微信小程序实现打开内置地图功能【附源码下载】
2017/12/07 Javascript
基于vue展开收起动画的示例代码
2018/07/05 Javascript
vue-cli项目修改文件热重载失效的解决方法
2018/09/19 Javascript
npm 常用命令详解(小结)
2019/01/17 Javascript
PostgreSQL Node.js实现函数计算方法示例
2019/02/12 Javascript
Vee-validate 父组件获取子组件表单校验结果的实例代码
2019/05/20 Javascript
详解JavaScript作用域 闭包
2020/07/29 Javascript
Python学习笔记之解析json的方法分析
2017/04/21 Python
Python制作词云的方法
2018/01/03 Python
使用Python的Django和layim实现即时通讯的方法
2018/05/25 Python
在Python中实现shuffle给列表洗牌
2018/11/08 Python
pandas求两个表格不相交的集合方法
2018/12/08 Python
对python中大文件的导入与导出方法详解
2018/12/28 Python
解决pycharm同一目录下无法import其他文件
2020/02/12 Python
印度最大的酒店品牌网络:OYO Rooms
2016/07/24 全球购物
美国知名玩具品牌:Melissa & Doug
2016/08/16 全球购物
预订从美国飞往印度的机票:MyTicketsToIndia
2017/05/19 全球购物
比利时买床:Beter Bed
2017/12/06 全球购物
优秀班主任经验交流材料
2014/06/02 职场文书
药店促销活动总结
2014/07/10 职场文书
2014年重阳节敬老活动方案
2014/09/16 职场文书
2014年社区宣传工作总结
2014/12/02 职场文书
学校食品安全责任书
2015/01/29 职场文书
2015年六一儿童节活动方案
2015/05/05 职场文书
消防宣传语大全
2015/07/13 职场文书
ORM模型框架操作mysql数据库的方法
2021/07/25 MySQL