当前位置:网站首页>《云原生的本手、妙手和俗手》——2022全国新高考I卷作文
《云原生的本手、妙手和俗手》——2022全国新高考I卷作文
2022-07-31 10:32:00 【免费的东西】
2022全国新高考I卷高考作文
题目:
《云原生的本手、妙手和俗手》
作者
:
今天的公交格外拥堵,也许是因为高考吧。
每天回家的路上,总会看一些技术圈的天下大事,刚刚看到一个话题:
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的亮眼之处
- 便于流量控制和监测及安全机制
- 与 K8s 完美兼容
- 使用高性能的 Go 语言开发
- 支持多种高级快速的网络协议
- Sidecar 默认 Envoy 并自动注入
- 容错机制完善
- 集成了用于监测的可视化界面
- Jaeger 作为跟踪机制集成
- 具备权限认证功能
- Sidecar 代理具有缓存功能
- 完全免费
由此看来,在云原生的体系中,相对于Kubernetes + Spring Cloud,Kubernetes + Istio的微服务解决方案代表着未来。
俗手
说完了本手和妙手,让我们来说说俗手,俗手乃是忽视了规律,胡乱地发挥主观能动性。
一个月前,我的好朋友狗蛋和我诉苦,说他的领导执意要将微服务架构从Spring Cloud转为Istio,连一个过渡期都没有。
真是绝绝子啊,盲目跟风,难道不考虑一下成本问题?
上述提到的SideCar容器,随着业务越来越复杂,所消耗的资源也越来越大,甚至会超过业务容器。
看过一份数据,对比Spring Cloud,基本每个Pod增加3GB内存,每秒RT增加0.8,CPU增加50%到80%。姑且不说Service Mesh带来的技术复杂度,这数据如果被中小企业的技术总监看了,不得虎躯一震?
非侵入式框架所带来的最大问题就是性能问题,内存、CPU的损耗都是值得深入思考的,盲目的跟随主流,最终只会让自己受苦。
找年轻漂亮的有用么?找到适合自己的才是幸福的真谛。
??《核心技术系列专栏汇总》??
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- Inversion problem - key point
- Burndown chart of project management tools: Dynamic assessment of team work ability
- 【LeetCode】73.矩阵置零
- Single sign-on principle and implementation
- cocoaPods管理之后工程结构变化
- Redis缓存面临的缓存雪崩问题
- Add a shuffling effect to every pie
- (C language) program environment and preprocessing
- 如何判断自己是否适合IT行业?方法很简单
- Hospital management system database, course design, SQLserver, pure code design
猜你喜欢
Insertion and deletion of doubly linked list
Module eight
AtCoder—E - Σ[k=0..10^100]floor(X/10^k
unity-shader-2
Android安全专题(三)JNI混淆
Hospital management system database, course design, SQLserver, pure code design
NowCoderTOP28-34二叉树——持续更新ing
乐观锁和悲观锁
Come n times - 07. Rebuild the binary tree
Sql optimization summary!detailed!(Required for the latest interview in 2021)
随机推荐
恋爱期间的赠与能否撤销
Chapter VII
Sql optimization summary!detailed!(Required for the latest interview in 2021)
1161. 最大层内元素和 (二叉树的层序遍历)
双链表的创建
掌握SSR
Redis缓存面临的缓存击穿问题
出色的移动端用户验证
Dart Log工具类
一种用于保证多方子系统数据一致性的方法
Qt 编译错误:C2228: “.key”的左边必须有类/结构/联合
SQL去重的三种方法汇总
《JUC并发编程 - 高级篇》06 - 共享模型之不可变(不可变类的设计 | 不可变类的使用 | 享元模式)
GVINS论文阅读笔记
FCN中制作自己的数据集并进行训练
Add a shuffling effect to every pie
[ 动词词组 ] 合集
Burndown chart of project management tools: Dynamic assessment of team work ability
[ verb phrase ] collection
【LeetCode】1161.最大层内元素和