袋鼠云前端项目发布工具dtux-kangaroo

简介: 在目前的大趋势下,前端和后端解耦已经是一个业界的趋势。前端和后端一旦解耦之后,前端的项目和后端的项目便可以自己发布,互不影响。这样极大地提高工作效率,免去了很多互相等待的时间。每家公司在前端项目发布体系可能不尽相同,本篇文章仅仅介绍袋鼠云的前端发布体系,希望能对大家能有所启发。

前言

在目前的大趋势下,前端和后端解耦已经是一个业界的趋势。前端和后端一旦解耦之后,前端的项目和后端的项目便可以自己发布,互不影响。这样极大地提高工作效率,免去了很多互相等待的时间。每家公司在前端项目发布体系可能不尽相同,本篇文章仅仅介绍袋鼠云的前端发布体系,希望能对大家能有所启发。

项目地址: github.com/ruichengpin…

实现原理

运行流程

首先说一下整个前端这边的运行流程,一般浏览器请求我们大致分为两条线资源请求接口请求。下面我们以这两个线说一下整个流程:

1. 资源请求: 这边我们Nginx服务器跟我们前端打包出来资源都是放在同一台机器上。Nginx设置一下我们静态资源的目录,浏览器的资源请求都会从这个静态资源目录中获取,我们本地往远程机器推送前端资源也是在这个目录下。

2. 接口请求: 浏览器的所有接口请求都会被我们远程机器上的Nginx拦截,然后路径规则匹配代理相应的接口服务上。

准备工作

安装nginx

这边以Centos为例为例:

yum install nginx

这里有个需要注意的是,我们要尽量保证nginx全局命令是可用,有不少公司nginx命令不是全局的,如何在对应的roo.config.js中做一下设置,后面我们会讲到。

设置好相应的目录

这里我们需要设定一下三个目录:

  • 前端资源存放目录 例如:/root/app
  • 前端项目nginx配置存放目录 例如:/root/nginx
  • 前端资源备份目录 例如:/root/backup

配置nginx文件

设置一下nginx配置文件,一般来说是**/etc/nginx/nginx.conf**。当然根据每个公司不同情况找到对应的配置文件

...
http{
    include /root/nginx/*.conf;  
}
...

include /root/nginx/*.conf;

这句话表示**/root/nginx下所有以.conf结尾的文件都会被加载进来,而/root/nginx**是我们所设定的nginx配置文件存放目录。

启动Nginx

nginx -c /etc/nginx/nginx.conf  //启动nginx,并确定前面配置是否正确

上面命令仅作参考,具体根据情况来定。

我们访问资源的时候有些人会遇到nginx抛出403 Forbidden的情况,这是是因为我们nginx配置文件最上面的user设置的用户权限不够,可以改成user root来解决。

支持功能

以下四个功能均支持**-c或者--config指定配置文件.如果未指定配置文件,则默认在项目根目录下去roo.config.js**作为配置文件。

roo backup

该命令用于备份我们的前端资源包,这样有利于我们做版本的管理。当线上出现重大问题的时候,可以及时拿过来做版本回滚。

执行roo backup命令,如果设置了NODE_ENV=production则会在远程机器上的backupDirectory里生成一个“production_YYYYMMDD”的前端资源包,若未设置则生成一个 “test_YYYYMMDD”的前端资源包,其中YYYYMMDD为当天的年月日,当天上传多次也只会生成一个包,后续上传的将会覆盖之前上传的前端资源。

以下为必须配置项:

roo.config.js

module.exports={
  local:{
    resourceDirectory:'<本地前端资源所在目录,该目录下的内容将会全部上传>'
  },
  origin:{
    host:'<远程机器IP>',
    username: '<远程机器用户名>',
    password: '<远程机器密码>',
    backupDirectory:'<远程机器备份前端资源的目录>'
  }
}

roo nginx

该命令用于生成项目对应的nginx配置文件,并更新线上的nginx配置文件。执行roo nginx文件之后,会在roo.config.js中指定的local.nginxConfigFilePath生成对应的nginx配置文件,并更新远程机器上的roo.config.js中指定的origin.nginxConfigFilePath的nginx配置文件,然后执行nginx的reload操作。

以下为必须配置项:

roo.config.js

module.exports={
  local:{
     nginxConfigTemplate:'<roo nginx nginx配置文件生成所用模板>'
     nginxConfigFilePath:'<roo nginx nginx配置文件生成路径>'
  },
  origin:{
    host:'<远程机器IP>',
    username: '<远程机器用户名>',
    password: '<远程机器密码>',
    nginxConfigFilePath:'<远程机器上该项目的nginx配置文件的路径,此文件将会被nginx主文件include>'    
  },
//nginxConfig里的参数将用于生成本项目的nginx配置文件
  nginxConfig:{
    port:'<开放端口>',
    serverName:'<服务名称>',
    publicPath:'<静态资源目录>',
    //locations将对于nginx里面的location
    locations:[
        {
            path:'<匹配路径>',
            //对应location中的配置项
            configs:[
                {
                    key:'proxy_redirect',
                    value:'off'
                },
                {
                    key:'proxy_set_header',
                    value:'Host $host'
                },
                {
                    key:'proxy_pass',
                    value:'代理路径'
                },
            ]
        }
    ]
  }
}

默认nginx配置文件模板

server {
  listen       {{port}};
  server_name  {{serverName}};
  location / {
    root        {{publicPath}};
    try_files $uri /index.html;
    location ~ .*\.(ico|js|css|gif|jpg|jpeg|png|bmp|swf)$ {}
  }
  {{#each locations}}
  location {{this.path}} {
    {{#each this.configs}}
    {{this.key}} {{this.value}};
    {{/each}}
  }
  {{/each}}
}

roo port

该命令用于检查远程机器的端口占用情况。

  • -p 或者 --port | 会检测该端口是否占用,若占用会显示相关使用情况
roo port  // 会拉取远程机器上所有已占用的端口情况

roo port -p 8000  //检测8000端口是否占用,若占用显示被使用情况

以下为必须配置项:

roo.config.js

module.exports={
    origin:{
        host:'<远程机器IP>',
        username: '<远程机器用户名>',
        password: '<远程机器密码>'
    }
}

roo publish

该命令将roo.config.js文件中local.resourceDirectory指定的前端资源目录内的资源上传到origin.resourceDirectory目录下。origin.resourceDirectory指定的目录也会跟nginxConfig.publicPath指定的目录相对应。

以下为必须配置项:

roo.config.js

module.exports={
    local:{
        resourceDirectory:'<本地前端资源所在目录,该目录下的内容将会全部上传>'
    }    
    origin:{
        host:'<远程机器IP>',
        username: '<远程机器用户名>',
        password: '<远程机器密码>',
        resourceDirectory:'<远程机器存在前端资源的目录,上传的前端资源将会存在这里>',
        nginxConfigFilePath:'<远程机器上该项目的nginx配置文件的路径,此文件将会被nginx主文件include>'  
    }
}

roo.config.js配置参数说明

module.exports={
  local:{
    resourceDirectory:'<本地前端资源所在目录,该目录下的内容将会全部上传>',
    nginxConfigFilePath:'<roo nginx nginx配置文件生成路径>'
  },
  origin:{
    host:'<远程机器IP>',
    username: '<远程机器用户名>',
    password: '<远程机器密码>',
    resourceDirectory:'<远程机器存在前端资源的目录,上传的前端资源将会存在这里>',
    backupDirectory:'<远程机器备份前端资源的目录>'
    nginxConfigFilePath:'<远程机器上该项目的nginx配置文件的路径,此文件将会被nginx主文件include>'    
  },
 //nginxConfig里的参数将用于生成本项目的nginx配置文件
  nginxConfig:{
    port:'<开放端口>',
    serverName:'<服务名称>',
    publicPath:'<静态资源目录>',
    //locations将对于nginx里面的location
    locations:[
        {
            path:'<匹配路径>',
            //对应location中的配置项
            configs:[
                {
                    key:'proxy_redirect',
                    value:'off'
                },
                {
                    key:'proxy_set_header',
                    value:'Host $host'
                },
                {
                    key:'proxy_pass',
                    value:'代理路径'
                },
            ]
        }
    ]
  }
}

展望

roo create

目前袋鼠云这边的项目构建工具采用的是Yeoman的构建体系,可以满足袋鼠云这边对项目构建的需求。但是有点小小不足的地方,就是每次项目模板更新之后都要重新发布Yeoman的脚手架,灵活性相对较差。后面打算把项目的生成的工作交给dtux-kangaroo,并且所有项目模板均放在github上,每次生成项目都会从github重新拉,模板贡献者只需要关注自己的github仓库即可,只要将更新合并到master分支上,后续项目生成均会提到更新。当然在现有的Yeoman的脚手架改造也可以实现同样的功能,但是本着工具精简的原则,会将现有的Yeoman的脚手架迁到dtux-kangaroo并进行改造。

roo mock

目前袋鼠云采用的是前后端分离的方式,但是开发中还是比较依赖后端的,接口数据mock还不是很完善。后面计划加入roo mock来解决数据mock问题,初步想法是借助后端的swagger来实现接口数据mock。

在dtux-kangaroo上基础做一个前端资源发布平台

dtux-kangaroo已经验证了这套发布体系的可行性,也解决了如何与远程机器的交互的问题。为前端资源发布平台的搭建打下很好的基础。后面计划搭建这个前端资源发布平台,提高前端资源发布的效率,减少对运维的依赖。


原文发布时间为:2018年06月07日
本文作者: ruichengping
本文来源:掘金  如需转载请联系原作者
相关文章
|
2月前
|
缓存 移动开发 Rust
前端构建工具 Mako 开源了
Hi,我是 sorrycc,Mako 的主要负责人之一,也是 Umi、Dva、Father 等库的作者。 很开心,Mako 终于开源了! Github 地址:https://github.com/umijs/mako/ 今天和大家正式介绍下他。
118 3
|
1月前
|
前端开发 JavaScript API
探索React Hooks:前端开发的革命性工具
【10月更文挑战第5天】探索React Hooks:前端开发的革命性工具
|
6天前
|
监控 前端开发 JavaScript
前端稳定性工具-Sentry
【11月更文挑战第9天】Sentry 是一个开源的错误和性能监控平台,支持多种编程语言和框架。它能够捕获前端应用中的各种错误和性能问题,提供详细的错误信息和用户行为关联,帮助开发团队快速定位和解决问题,优化应用性能。但需注意隐私保护、数据准确性和成本控制。
|
13天前
|
前端开发 JavaScript API
前端开发的秘密武器:这些工具让你轻松应对各种复杂动画效果!
【10月更文挑战第30天】前端开发中,动画效果为页面增添了无限生机。CSS3的@keyframes规则和JavaScript动画库如GSAP、Anime.js等,使开发者能轻松实现从简单到复杂的动画效果。掌握动画原理和设计原则,结合工具和库,可以创造出既美观又实用的动画,提升用户体验。
35 4
|
11天前
|
Web App开发 前端开发 JavaScript
前端开发的秘密武器:这些工具让你轻松应对各种复杂布局!
【10月更文挑战第31天】前端开发充满挑战,尤其是在处理复杂布局时。本文介绍了几种关键工具和技术,如HTML和CSS基础、Firefox开发者工具、Visual Studio Code以及Vue、React和Angular等前端框架,帮助开发者高效应对复杂布局,提升代码质量和用户体验。
24 2
|
29天前
|
自然语言处理 前端开发 JavaScript
推荐 10 个前端开发会用到的工具网站
本文介绍了多个前端开发工具,包括 Web Design Museum、Landing Page、Google Fonts、Lorem Ipsum、Animista、Blobmaker、Spline、CodeToGo、UnusedCSS 和 Responsively,帮助开发者提高效率和项目质量。这些工具涵盖了设计、动画、代码片段管理、响应式测试等多个方面。
66 0
推荐 10 个前端开发会用到的工具网站
|
1月前
|
Web App开发 前端开发 开发工具
2024前端开发工具推荐
本文推荐了2024年最受前端开发者欢迎的十款工具,包括Visual Studio Code、Dreamweaver、Sublime Text、WebStorm、Atom、HBuilder、Chrome Developer Tools、Figma、Postman和Git。这些工具覆盖了代码编辑、调试、版本控制及API开发等多个方面,旨在帮助开发者提高效率和代码质量,让开发工作更高效、更愉快。
|
29天前
|
存储 前端开发 JavaScript
前端模块化打包工具的深度解析
【10月更文挑战第13天】前端模块化打包工具的深度解析
|
1月前
|
存储 前端开发 JavaScript
前端开发中的状态管理概述与工具选择
【10月更文挑战第7天】前端开发中的状态管理概述与工具选择
18 0
|
2月前
|
前端开发 开发者
在前端开发中,webpack 作为一个强大的模块打包工具,为我们提供了丰富的功能和扩展性
【9月更文挑战第1天】在前端开发中,Webpack 作为强大的模块打包工具,提供了丰富的功能和扩展性。本文重点介绍 DefinePlugin 插件,详细探讨其原理、功能及实际应用。DefinePlugin 可在编译过程中动态定义全局变量,适用于环境变量配置、动态加载资源、接口地址配置等场景,有助于提升代码质量和开发效率。通过具体配置示例和注意事项,帮助开发者更好地利用此插件优化项目。
81 13