赛罗终极形态_终极战斗仪

赛罗终极形态_终极战斗仪实践是推广一个产品或技术的最好的方式,特别在IT行业让产品管理产品本事,就是一种很好的推广方式,例如DockerinDocker、k8sink8s,这些已经被大家普遍接受。所以我觉得spinnaker要想很好的推广开来,也需要类似的应用方案,我把它称为SpinnakerOnSpinnaker。架构图如下:最上面部分是主spinnaker,或者叫masterspinn…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

实践是推广一个产品或技术的最好的方式,特别在IT行业让产品管理产品本事,就是一种很好的推广方式,例如Docker in Docker、k8s in k8s,这些已经被大家普遍接受。所以我觉得spinnaker要想很好的推广开来,也需要类似的应用方案,我把它称为Spinnaker On Spinnaker。

 

架构图如下:

赛罗终极形态_终极战斗仪

最上面部分是主spinnaker,或者叫master spinnaker,这个spinnaker用来管理每条业务线真正使用的spinnaker。Master spinnaker中只对接一个容器云,利用spinnaker管理k8s的方式来为业务线发布和更新子spinnaker系统。

 

中间部分就是部署子spinnaker的那套容器云,我们采用代码配置分离的方式来管理它们,这样管理的优点会在下文中做解释。这套容器云要做的事情就很简单了,根据预先准备的每个spinnaker微服务镜像,挂载业务线自己的配置,然后启动对应服务。我这里举例场景中有3条业务线在用spinnaker,Odin、Tinker和Loki。

 

最下面部分就是业务线中真正操作使用spinnaker的团队了,每个子spinnaker需要一个项目管理员负责自己spinnaker的权限管理、pipeline配置等,但是他不可更改云平台认证相关的信息,剩下的团队成员就是一线的研发、测试和运维同学了,他们享受着spinnaker自动化带来的福利。

 

Spinnaker On Spinnaker设计的优点:

1 职责分担

  设想如果没有这种内嵌设计,Spinnaker的管理员除开维护Spinnaker本身的应用的配置,还需要维护到所有产品线的所有资源和所有pipeline,这对于管理员来说是灾难性的,因为他不具备一线人员对产品和运维上的理解能力,他不可能搞得清负载均衡的名称、实例上要打哪些tag这些细如牛毛的琐事。

  现在引入Spinnaker On Spinnaker的设计,Spinnaker的master管理员只需要配置每个子spinnaker的账号信息,偶尔更新一下spinnaker版本、接入新子项目即可;而每个子项目的spinnaker具有自己产品线除云账号以外的所有配置权力,他们是跟着业务线走的,所以他们具备spinnaker master不具备的业务知识。

 

2 账户隔离

  2.1 资源隔离

  每条产品线使用自己的云资源账号,在master spinnaker中给这个子spinnaker配置好账号后,子spinnaker的admin就可以看到自己账号云平台下的所有资源。假如没有内嵌设计,很难做到账号级别的资源隔离,一旦有维护不到的application就会导致所有spinnaker用户都可以访问和修改这些资源,作为生产级别的产品这是不能容忍的。

  2.2 服务隔离

  每个子spinnaker需要扩容或者重启服务,master spinnaker直接就对他们做操作,因为他们的服务是隔离的。假如没有内嵌设计,spinnaker的使用者被绑定在一套服务中,其中一个要求重启,所有人都将受到影响。

 

3 高可用性

我们来直接模拟故障吧。

子spinnaker本身就是由容器云,理论上容器云中的资源可以通过重启容器等方式快速恢复的,所以我们先不考虑子spinnaker出现故障的场景,而且spinnaker除开云平台鉴权信息存在本地,pipeline和配置信息存在S3等云存储上,剩下的都是直接在云平台中采集的资源,所以不存在数据丢失的场景。

那么最大的单点故障就是在master spinnaker上了,假如没有内嵌设计,spinnaker挂了后所有产品线都将瘫痪,云资源虽然不受影响,但不能进行自动化的软件本发布了。有了内嵌设计,master spinnaker就算挂了,也是失去了对承载子spinnaker的容器云的控制,不能添加和修改子spinnaker的而已,不会影响现有子spinnaker的正常使用。

 

以上设计只是一个雏形,理论上是不存在问题的,同时也欢迎大家指出其中的不足。当然,所有的理论能否落地是需要一批志同道合的同事们一起努力才能实现的,目前在spinnaker推广和使用中略显孤独。

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/213469.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JAVA 日期格式化

    最近项目中需要用到SimpleDateFormat格式化日期,但是因为对日期格式的不熟练多花了十分钟左右的时间在日期格式化上面,所以趁着周末外面下着大雨闲着无聊整理一下日期格式问题。日期格式化学习预定义格式日期格式化样式自定义日期格式化预定义格式java提供了预定义的日期格式,预定义的日期格式可以满足绝大多数的场景需要。格式化日期需要两步:1、通过DateFormat.getDate…

    2022年4月6日
    49
  • 用python 打印九九乘法表的7种方式 (python经典编程案例)[通俗易懂]

    用python 打印九九乘法表的7种方式 (python经典编程案例)[通俗易懂]用python打印九九乘法表,代码如下:#九九乘法表foriinrange(1,10):forjinrange(1,i+1):print(‘{}x{}={}\t’.format(j,i,i*j),end=”)print()执行结果如下图:…

    2022年6月29日
    43
  • Data Mining资源大全

    Data Mining资源大全

    2021年5月3日
    163
  • java中applet是什么意思_Java Applet与Java Application的区别

    java中applet是什么意思_Java Applet与Java Application的区别在Java语言中,能够独立运行的程序称为Java应用程序(Application)。Java语言还有另外一种程序–Applet程序。Applet程序(也称Java小程序)是运行于各种网页文件中,用于增强网页的人机交互、动画显示、声音播放等功能的程序。JavaApplet和JavaApplication在结构方面的主要区别表现在:(1)运行方式不同。JavaApplet程序不能单独运行,它必…

    2022年7月8日
    21
  • 人工智能:智能优化算法

    人工智能:智能优化算法**人工智能:智能优化算法优化问题是指在满足一定条件下,在众多方案或参数值中寻找最优方案或参数值,以使得某个或多个功能指标达到最优,或使系统的某些性能指标达到最大值或最小值。优化问题广泛地存在于信号处理、图像处理、生产调度、任务分配、模式识别、自动控制和机械设计等众多领域。优化方法是一种以数学为基础,用于求解各种优化问题的应用技术。各种优化方法在上述领域得到了广泛应用,并且已经产生了巨大的经济效益和社会效益。实践证明,通过优化方法,能够提高系统效率,降低能耗,合理地利用资源,并且随着处理对象规模的增加

    2022年5月22日
    61
  • Web端即时聊天项目实现(基于WebSocket)

    Web端即时聊天项目实现(基于WebSocket)Web端即时聊天项目实现项目背景 其实这个项目算是我做过的花时间最长也投入心血最多的一个项目了,当时决定开始做这个的时候我几乎什么都不会,那时我个人的情况是:-JavaEE方面:会jsp+servlet,也简单使用过Struts,Spring仅仅只是听说过。-前端方面:html,css有一些基础,会使用Bootstrap前端工具开发集,js基本不了解。-数据库…

    2022年5月14日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号