前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >rancher教程(三): rancher 前端项目dashboard架构解析

rancher教程(三): rancher 前端项目dashboard架构解析

作者头像
拿我格子衫来
发布2022-05-07 15:17:43
1.2K0
发布2022-05-07 15:17:43
举报
文章被收录于专栏:TopFE

简介

本篇文章我将给大家讲解一下rancher的dashboard项目的架构。 如果大家想要学习dashboard的前端架构,或者想要移植某个相似的功能到自己公司的容器开发平台,这将是一篇非常不错的入门文章。能够帮助你理清项目的技术栈和目录结构。 此外如果你要给rancher提交pr,也可以先从了解项目开始。 废话不多说让我们先来看看dashboard这个项目结构吧。

主要技术栈

打开dashboard的 package.json文件,项目所有的依赖包都映入眼帘,首先项目使用的是vue.js + nuxt.js。这两个框架是底层的。 用的nuxt是2.14.6版本。该版本对应的vue是2.x

此外样式方面使用的sasssass-loader

格式校验使用的eslint,测试使用的jestcypress(这部分目前用的比较少)

http请求库使用的@nuxtjs/axios

在dashboard的项目中,还存储了一些文档,使用的storybook这个库来进行管理的

操作命令都在package.json中。 package.json中有些命令是直接调用shell脚本,所以对windows开发者很不友好。

如果遇到那个命令无法运行,可能是运行环境不一致。 或许rancher的开发人员人均mac。

在package.json中我看到了"@novnc/novnc": "^1.2.0", 这个包,这个依赖包我直接讲解过,它是用于实现wbe vnc的功能的核心包。web vnc简单来说就是在浏览器里访问某一条主机的桌面,并实质操作。你或许在一些云厂商平台使用过该功能,非常酷炫。其实原理是将桌面服务当做一个对外暴露的web 服务。对外使用socket输出文件流,该文件流可以被渲染成一个canvas画板,画板的内容就是主机的桌面,用户所有的鼠标操作,键盘操作,都会通过socket回传到主机,并进行相应。 可以看看我之前的一篇文章。

dashboard还使用d3做一些图表(竟然没有选择使用echarts),配合jquery完成一些dom操作。终端编辑器使用的"xterm": "^4.9.0",

此外还使用一些常用工具库lodash。解压库jszip,国际化i18n,状态管理vuex

项目目录

page根据nuxt架构的规定,该目录存放的所有文件都是一个单独的页面,这意味着你看到的页面,入口文件都在该目录下,并且你可以根据路径,找到文件。 比如

plugins这里边定义的都是一些插件,比如封装的aixos,VueCodemirror,i18n,

assets 存放的是svg,图片,以及公共样式文件。

chart 存放的是图表相关的组件。日志,监控,备份,istio相关模块用到的图表

components 该目录存放了项目里绝大多数的业务组件以及公共组件。

config 目录里存放的都是定义的静态常量。比如一些下拉框的选项,类型。

edit,detaillist 是抽离出来的编辑页面,详情页,列表页组件。属于基础组件,适用性很强。

store 存放的是vuex中定义的状态。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 简介
  • 主要技术栈
  • 项目目录
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档