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

2023-11-02 10:41

本文主要是介绍袋鼠云前端项目发布工具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里面的locationlocations:[{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里面的locationlocations:[{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
本文来源:掘金  如需转载请联系原作者

这篇关于袋鼠云前端项目发布工具dtux-kangaroo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/330053

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

sqlite3 命令行工具使用指南

《sqlite3命令行工具使用指南》本文系统介绍sqlite3CLI的启动、数据库操作、元数据查询、数据导入导出及输出格式化命令,涵盖文件管理、备份恢复、性能统计等实用功能,并说明命令分类、SQL语... 目录一、启动与退出二、数据库与文件操作三、元数据查询四、数据操作与导入导出五、查询输出格式化六、实用功

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框