作者 | 步尔斯特

来源 | 步尔斯特

刚刚看到一个话题:==Java大军,真的开始把目光从Spring Cloud转向云原生系的k8s + Istio了么?==

乍一看,有一丝不解,Java大军?Spring Cloud?Kubernetes?Service Mesh?这四个技术栈放在一起,真的能擦出火花?

此时,一束余辉射在旁边老奶奶那粉嘟嘟的小脸上,我顿悟了,也许提出这个问题的人,本意并不是这样。

他或许是在问“微服务的最佳落地方案?”,亦或是“以Kubernetes为核心的云原生发展趋势?”...

这篇文章就像高考一样,它并不会直接带给你具体的技术知识,但是可能会改变你,成为你的灯塔。

也许你看完没有一丝收获,会骂骂咧咧的走开,但是你不得不承认,当你看到这里的时候,你会有一种想要读完这篇文章的冲动,所以,我尽可能写的简短,不必浪费你太多时间。

不论是云原生还是上述的话题,不得不说到微服务。什么是微服务?把大服务拆成小服务,不就是微服务喽!

微服务肯定是大趋所向了,小而专一,松耦合,语言无关。可问题随之而来,服务治理是个难点:系统复杂性增加、分布式一致性问题、数据一致性问题、服务通信成本增加、服务依赖、性能监控...

本手

所谓本手,便是掌握了事物的发展规律,要顺势而为,要懂规则,且大可不必明理。

以Spring Cloud系列为代表的侵入式微服务解决方案,应该是Java开发者广为熟知的。

从上图就可以看出Spring Cloud项目是完全可以部署在Kubernetes上的。

侵入式框架是从开发者的角度来衡量的,所以同时会增加开发者的学习成本。

Java web开发从Servlet、SSM、SpringBoot,再到Spring Cloud Netflix和现在的Spring Cloud Alibaba,还有后续的Spring Cloud Kubernetes等,这种变化是与时俱进的。

Spring Cloud 系列和Kubernetes虽然在各自的领域处理的问题不一样,但是他们无疑都是伟大的技术。

云原生时代的这个风口,他们完全可以手牵手乘浪而行。

妙手

何为妙手?妙手便是在正确掌握了规律的基础上充分发挥自己的主观能动性,一鼓作气,再而衰,三而竭,彼竭我盈,故克之。

Service Mesh作为微服务的另一种架构哲学,以Istio作为代表的非侵入式微服务解决方案,目前为止用的企业还蛮多的。

这一类的框架都是基于边车的设计思想(Sidecar),完全松耦合。

Spring Cloud系列提供了一整套微服务的解决方案,但是Kubernetes都有相对应的替代者,而且是从更高的维度来解决问题,可以说是降维打击。

  • 服务注册与发现

    • Spring Cloud系列主流的解决方案是Nacos + Spring Cloud Loadbalancer

    • Kubernetes提供了Service

  • API网关

    • Spring Cloud系列主流的解决方案是Spring Cloud Gateway

    • Kubernetes提供了Ingress

  • 配置中心

    • Spring Cloud系列主流的解决方案是Nacos

    • Kubernetes提供了ConfigMaps

  • 熔断限流

    • Spring Cloud系列主流的解决方案是Sentinel

    • Kubernetes可以结合ServiceMesh来做

再来看看Istio的亮眼之处

  1. 便于流量控制和监测及安全机制

  2. 与 K8s 完美兼容

  3. 使用高性能的 Go 语言开发

  4. 支持多种高级快速的网络协议

  5. Sidecar 默认 Envoy 并自动注入

  6. 容错机制完善

  7. 集成了用于监测的可视化界面

  8. Jaeger 作为跟踪机制集成

  9. 具备权限认证功能

  10. Sidecar 代理具有缓存功能

  11. 完全免费

由此看来,在云原生的体系中,相对于Kubernetes + Spring Cloud,Kubernetes + Istio的微服务解决方案代表着未来。

俗手

说完了本手和妙手,让我们来说说俗手,俗手乃是忽视了规律,胡乱地发挥主观能动性。

一个月前,我的好朋友狗蛋和我诉苦,说他的领导执意要将微服务架构从Spring Cloud转为Istio,连一个过渡期都没有。

真是绝绝子啊,盲目跟风,难道不考虑一下成本问题?

上述提到的SideCar容器,随着业务越来越复杂,所消耗的资源也越来越大,甚至会超过业务容器。

看过一份数据,对比Spring Cloud,基本每个Pod增加3GB内存,每秒RT增加0.8,CPU增加50%到80%。姑且不说Service Mesh带来的技术复杂度,这数据如果被中小企业的技术总监看了,不得虎躯一震?

非侵入式框架所带来的最大问题就是性能问题,内存、CPU的损耗都是值得深入思考的,盲目的跟随主流,最终只会让自己受苦。

我们需要倾听到你专业的声音!

CSDN音视频技术开发者在线调研来啦!

作为一名开发者,如何看待音视频技术的职业发展前景?

你熟悉哪些音视频技术产品和平台呢?

欢迎大家扫码参与调研呦~

云原生的本手、妙手和俗手相关推荐

  1. 云原生的 CICD 框架:Tekton

    作者 | AddoZhang 来源 | 云原生指北 Tekton 是 Google 开源的 Kubernetes 原生CI/CD 系统,功能强大扩展性强.前身是 Knavite 里的 build-pi ...

  2. 软件工程师的本手、妙手和俗手

    "无意中发现了一个巨牛的人工智能教程,忍不住分享一下给大家.教程不仅是零基础,通俗易懂,而且非常风趣幽默,像看小说一样!觉得太牛了,所以分享给大家.点这里可以跳转到教程." 每年高 ...

  3. 《跨境电商的本手、妙手和俗手》——2022高考作文

    前两天,高考作文如期在朋友圈刷屏 只是这次出现了围棋术语和红楼梦 作为一个跨境搬砖人 我在想,本手.妙手.俗手 和"跨境电商"能擦出什么火花? 从脑海中搜刮各种韭菜培训课程后 我忽 ...

  4. 运维工作的“本手、妙手、俗手”

    "本手.妙手.俗手"是围棋的三个术语.本手是指合乎棋理的正规下法:妙手是指出人意料的精妙下法:俗手是指貌似合理,而从全局看通常会受损的下法.对于初学者而言,应该从本手开始,本手的功 ...

  5. 本手妙手俗手为主题写一篇不少于800字的作文

    我们生活在一个技术发达的时代,科技的发展给我们带来了许多便利.但是,本手妙手俗手的精髓依然不可缺少.本手妙手俗手,字面上的意思就是以本领和技能来解决问题,而不是依赖外部技术和机械.这种方式的优势在于可 ...

  6. 力扣1089 的本手妙手俗手

    力扣1089 的本手妙手俗手 题目 给你一个长度固定的整数数组 arr,请你将该数组中出现的每个零都复写一遍,并将其余的元素向右平移.注意:请不要在超过该数组长度的位置写入元素.要求:请对输入的数组 ...

  7. 新一代云原生数据库的设计与实践

    数据库与操作系统.中间件组成了基础软件的三驾马车,也是企业 IT 系统必不可少的核心技术.从上世纪 60 年代诞生至今,不论是互联网行业还是银行.电信.制造等传统行业,都依赖着数据库技术的演进. 在步 ...

  8. 硬核科普:到底啥是云原生?

    本文主要根据课程 什么是云原生?_哔哩哔哩_bilibili 总结而来,其他参考文章如下: <云原生人才计划之Kubernetes 技术图谱>发布! - 知乎 (zhihu.com) ku ...

  9. 容器云原生DevOps学习笔记——第三期:从零搭建CI/CD系统标准化交付流程

    暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...

最新文章

  1. wdpc V3 phpmyadmin打不开的一种解决方式(实测有效)
  2. 关于Python异常处理,你需要了解的知识点
  3. iOS 利用webView加载html代码,在代理中获取html页面的链接时出现的问题
  4. JAVA 通过 Socket 实现 TCP 编程
  5. ZOJ-2587 Unique Attack 最小割的唯一性判定
  6. 华为云摘得信息检索领域国际权威比赛金牌,实力全解析
  7. linux监听apache代码,linux系统使用python监控apache服务器进程脚本分享
  8. Python + Appium 环境搭建
  9. python计数器Count
  10. rsyslog mysql ip_使用rsyslog+loganalzey收集日志显示客户端ip
  11. 基于排队论模型的收银台服务系统的分析及可视化设计
  12. 二极管整流电路工作原理图
  13. Microsoft Office 2016 VOL版下载
  14. 阿里品牌数据品牌银行分析师认证真题资料库整理答案
  15. 关键字搜索aliexpress商品API接口(速卖通关键词搜索商品接口)
  16. CHIL-SQL-NULL 值
  17. 跳槽离职的那些事儿?(转)
  18. 为Visual SVN Server添加认证用户IP功能
  19. 原生js操作input文本框注册获取焦点、失去焦点事件,设置文本框默认值
  20. UE4C++独立游戏开发-守护神石

热门文章

  1. clickhouse on cluster设置
  2. [CVPR2020] StarGAN v2
  3. 如何给MP3文件添加封面
  4. 枪毙病狗问题(看帽子问题类型)
  5. 用PyPy加速Python程序
  6. 生产线平衡如何改善?详解:生产线平衡优化改善方法与措施!
  7. 初中化学二氧化碳的性质与制取合作学习探究
  8. 【PaddleNLP-kie】关键信息抽取2:UIE模型做图片信息提取全流程
  9. 李居明风水人人都懂版之十一~结婚照片与风水
  10. 农村生活污水处理发展的建议和对策