当前位置:首页>编程日记>正文

微服务实战分享

本站寻求有缘人接手,详细了解请联系站长QQ1493399855

导语
喜欢踢球的同学一般知道这样的一个段子,当年有好事的记者问风头正盛的球王马拉多纳,在他进球中,哪个踢得最精彩?马拉多纳想了想就说:“一个吧”所以,努力追求“下一个”是一个普通球员到天才球员的必备品质,那么在快速互联网行业中同样如此,每一次的技术更新变革也意味着无数个追求“下一个”的互联网从事着的日日夜夜的辛勤劳动。

第一章 软件架构演进
按照不同阶段使用的软件架构来排序:单体架构,垂直架构,服务化架构,微服务架构以及未来可能出现的无服务架构(ServiceLess)以及服务网格(Service Mesh)。
1.单体架构
单体架构在初创的小微企业比较常见,典型代表就是一个应用、一个数据库、一个Web容器就可以跑起来,但现在实际的。
特点:
所有功能集中在一个项目工程中,所有的功能在一个war包中,然后部署到服务上,并且可以通过集群来提高系统的性能瓶颈。
优点:
①部署实施简单,可以保证项目快速上线。
②项目架构简单,前期开发成本低,周期短。
缺点:
①全部功能集成在一个工程中,对于大型项目不易开发、扩展及维护。
②系统性能扩展只能通过扩展集群结点,成本高。
微服务实战分享 配图01

2.垂直架构
每一个垂直模块属于一个单一团队,通过垂直拆分,原来的单体项目不至于无限扩大。在模块之间共享代码是严令禁止的。出现了影响力最大设计典范MVC模式,模型(model)-视图(view)-控制器(controller),SSH框架是典型的MVC设计思想的应用框架。
特点:
垂直架构思想在于分层。
优点:
①隐藏下层的实现。下层为上层提供其所需的服务,但实现的过程,上层是无法知晓的。
②不同的项目可采用不同的技术。
③代码的复用性得到极大提高。
缺点:
①上下层级相互依赖,牵一发而动全身。
②全部功能集成在一个工程中,对于大型项目不易开发、扩展及维护。
微服务实战分享 配图02

3.服务化架构
SOA代表面向服务的架构,将应用程序根据不同的职责划分为不同的模块,不同的模块直接通过特定的协议和接口进行交互。这样使整个系统切分成很多单个组件服务来完成请求,当流量过大时通过水平扩展相应的组件来支撑,所有的组件通过交互来满足整体的业务需求。
特点:
在系统的角度,解决两个核心的问题,程序的通讯问题以及服务化的构成。由于服务化架构使用的RPC通讯的方式,所以也被很多人称为RPC框架,RPC是远程调用,RPC是服务化架构的核心,在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC,WebService等通讯方式使得服务化的分布式基础。
优点:
①将重复的功能抽取为服务,提高开发效率,提高系统的可重用性、可维护性。②采用ESB减少系统中的接口耦合。
缺点:
①抽取的服务的粒度过大,系统与服务之间耦合性高。
②系统与服务的界限模糊,不利于开发及维护。
微服务实战分享 配图03

软件架构演进总结:单体架构是最早最行之有效的软件架构,也是对以后的架构发展的基础;在单体架构发展一段时间后,公司的业务量和业务层级开始需要更高的要求, 在这一阶段单体架构的增加机器带来提高瓶颈的功能越来越小,最后只能将系统分为不同的层级,每个层级有对应的职责,以提升效率;如果公司进一步的做大,垂直子系统会变的越来越多,系统和系统之间的调用就不能避免了,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,以便应用更快速度的响应多变的市场需求。

第二章 微服务架构
其实服务化架构已经可以解决大部分企业的需求了,程序之间可以通讯了,逻辑上服务也分离出来了,那么我们为什么要研究微服务呢?微服务架构是SOA架构思想的一种扩展,更加强调服务个体的独立性、拆分粒度更小。

微服务的定义
将大型的复杂应用分解为多个小的微服务,每个微服务都围绕着具体业务进行构建,各微服务可分布式独立部署,且服务之间互相协调、互相配合,实现应用的快速迭代。

微服务的优点和缺点
优点:能够独立完成相应的服务,不再相互牵制。
缺点:微粒度越高,维护的成本越高。

微服务的价值
微服务的价值按照职位不同的角度来阐述的话,对于运维,开发人员,测试人员来说,是能提高工作效率的系统或者是工具;而对于CTO,技术管理者来说,微服务架构能够解决部分管理问题,合理的微服务抽象和拆分对应合理的组织结构划分,每个服务就变成一个独立的小产品,运营这个产品就是组织主要目标,产品的价值决定部门的价值,产品用户的多少决定组织价值的高低,这种类似市场化的管理方法是最能提供明确的指导性,战略性。

服务化架构与微服务化架构对比
1.通讯方式对比
服务化架构采用的RPC通讯方式,而微服务架构采用的是REST的通讯方式。RPC通讯是基于TCP传输层协议的产物(7层协议中的第三层),但像很多对DUBBO二次开发的的框架同样也支持HTTP,例如当当网的DUBBOX。RESTFUL通讯方式是基于HTTP应用层协议的产物。RPC是以动词为中心的, REST是以名词为中心的, 此处的动词指的是一些方法, 名词是指资。以动词为中心,意味着,当你要需要加入新功能时,你必须要添加更多的动词, 这时候服务器端需要实现相应的动词(方法), 客户端需要知道这个新的动词并进行调用。而以名词为中心, 假使我请求的是 hostname/friends/, 无论这个URI对应的服务怎么变化,客户端是无需关注和更新的,而这种变化对客户端也是透明的。

2.典型框架对比
DUBBO是SOA架构时代的产物,但国内技术人喜欢拿DUBBO和微服务架构SPRING CLOUD进行对比,是因为两者都是服务治理非常优秀的开源框架。DUBBO系出名门,是2008年底在阿里内部开始规划调用,2011开源的服务化治理的核心框架,2013年中途停止过,2017年9月份又重启维护并发布了新版本并被广泛应用于阿里巴巴集团的各成员站点。同时阿里云也推出了企业级分布式应用服务EDAS,为DUBBO提供应用托管。SPRING CLOUD,从命名我们就可以知道,它是SPRING SOURCE的产物,SPRING社区的强大背书可以说是JAVA企业界最有影响力的组织了,而为其提供技术后盾是Netflix公司(https://netflix.github.io/),在中国也叫网飞。Netflix也是非常有传奇色彩的公司,最开始是在线影片租赁,后来开始自制剧,著名的纸牌屋就是出自网飞,去年还买下了白夜追凶的播放版权。就目前请看看来说,阿里的DUBBO知名度更高一些,一个可能这也与早年阿里就开源了DUBBO框架之外,另一个原因是不少科技公司的架构师或者是主程均出自阿里系习惯了阿里的内部框架。随着技术的发展,大家可以关注两个框架的发展情况。

3.框架选型
可以打个比方。SPRING CLOUD品牌机,DUBBO是组装机;品牌机的兼容性有保证,开机即用。组装的机子更自由,选购自己心仪的CPU,内存条,硬盘等资源,但是需要一定技术能力去规划组装。但总的来说,微服务是未来发展的大趋势,有意更换架构的企业可以尽早做好打算。

第三章 Spring Cloud与DevOps实战
Spring Cloud
Spring Cloud是一系列框架的有序集合,它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。Spring 并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装、屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。Spring Cloud是微服务最典型也是目前应用最广泛的架构。
微服务实战分享 配图04

所有请求都统一通过 API 网关(Zuul)来访问内部服务;网关接收到请求后,从注册中心(Eureka)获取可用服务;由Ribbon进行均衡负载后,分发到后端的具体实例;微服务之间通过Feign进行通信处理业务;Hystrix负责处理服务超时熔断;Turbine监控服务间的调用和熔断相关指标。

CI/CD
CI持续集成,CD持续交付,通常会采用一些软件如Jenkins、TeamCity等来辅助项目流程。CI/CD能够与Git SVN等代码管理仓库集成,帮助使用者实现自动化任务。CI/CD是DevOps中最重要也是最典型的实际应用。
微服务实战分享 配图05
微服务实战分享 配图06

Spring cloud与DevOps结合
Spring cloud与DevOps不是先有鸡还是先有蛋的问题,而是相互利好的关系。DevOps就是直击Spring cloud的痛点,把最复杂的分布式的服务,进行高效持续的生产。使用Spring cloud,第一步是要构建一个一体化的DevOps平台,试想如果不使用DevOps做微服务的话,整个环境会变得非常的乱、非常的糟糕,Spring cloud会给你的整个开发、测试和运维增加很多成本,反而是得不偿失了。所以第一步我们是提高DevOps的能力,能够把它的开发、部署和维护进行很完美的结合,才可以说我们真正能够享受到Spring cloud框架的福利。
微服务实战分享 配图07

技术流程(手动打包)
1.Jenkins从仓库中手动拉取最新代码。
2.通过Jenkins的自带插件打包编译代码。
3.进行单元测试。
4.build构建最新的容器镜像。
5.push镜像到镜像仓库中去。
6.使用K8S或者docker-compose等容器编排工具进行项目的启动。

第四章 思考
中小企业新技术的选择思考
1.永远不要优先考虑性能问题,等到有性能问题,使用负载均衡。等到负载均衡搞不定时,公司也大了,就说融资上市的事情了,那就有新的技术架构技术方案代替原来的。
2.优先考虑的是文档/社区/可维护性。
3.优先选择硬通货,一旦有问题不仅仅是你一个人有问题,可以去Stack Overflow找答案;可以参考swarm和K8S的情况。

微服务的可实施性思考
我的总结观点是:不要为了追求技术而追求技术。稳定而有效的结果才是我们的最求,例如我维护过做游戏的日本客户,到现在都还在使用Windows Server 2013系统。
1.团队的技术人员是否已经具备相关技术基础。包含了对微服务的理解,DevOps的掌握等等都需要过硬的技术实力。
2.公司业务是否适合进行微服务化改造,并不是所有的平台都适合进行微服务化改造,比如:传统行业有很多复杂垂直的业务系统。而且要涉及到整个业务的数据库的分表分库,重新统一服务接口,最后还要规划具体的容器实施部署。
3.Spring Cloud 生态的技术有很多,并不是每一种技术方案都需要用上,适合自己的才是最好的。

运维行业的思考
新的技术发展到现在,给我最深的感触就是基础性的技术支持越来越被隐藏,更多的是强调自身业务快速实现和拓展。国外像Netflix和亚马逊是压根就没有运维这样的角色,运维的事情都是由开发工程师来完成,他们的职位名称是SDE(Software Develop Engineer),所以他们也被戏称为Someone Do Everything。所以,运维转型不是一句吓唬人的话,真的已经在我们身边发生了。

总结
技术变革的根本原因是业务发展的瓶颈与突破,技术能力决定业务能力的宽度,业务能力决定公司的长度;当技术能力达到一定高度的时候,可以试着调整自己的思考角度,从产品,从业务发展来考虑,又可以看到不一样的风景。


http://www.coolblog.cn/news/87548bfed57766f8.html

相关文章:

  • asp多表查询并显示_SpringBoot系列(五):SpringBoot整合Mybatis实现多表关联查询
  • s7day2学习记录
  • 【求锤得锤的故事】Redis锁从面试连环炮聊到神仙打架。
  • 矿Spring入门Demo
  • 拼音怎么写_老师:不会写的字用圈代替,看到孩子试卷,网友:人才
  • Linux 实时流量监测(iptraf中文图解)
  • Win10 + Python + GPU版MXNet + VS2015 + RTools + R配置
  • 美颜
  • shell访问php文件夹,Shell获取某目录下所有文件夹的名称
  • 如何优雅的实现 Spring Boot 接口参数加密解密?
  • LeCun亲授的深度学习入门课:从飞行器的发明到卷积神经网络
  • 法拉利虚拟学院2010 服务器,法拉利虚拟学院2010
  • Mac原生Terminal快速登录ssh
  • 支撑微博千亿调用的轻量级RPC框架:Motan
  • mysql commit 机制_1024MySQL事物提交机制
  • java受保护的数据与_Javascript类定义语法,私有成员、受保护成员、静态成员等介绍...
  • 2019-9
  • jquery 使用小技巧
  • vscode pylint 错误_将实际未错误的py库添加到pylint白名单
  • 科学计算工具NumPy(3):ndarray的元素处理
  • 工程师在工作电脑存 64G 不雅文件,被公司开除后索赔 41 万,结果…
  • linux批量创建用户和密码
  • js常用阻止冒泡事件
  • 气泡图在开源监控工具中的应用效果
  • newinsets用法java_Java XYPlot.setInsets方法代碼示例
  • 各类型土地利用图例_划重点!国土空间总体规划——土地利用
  • php 启动服务器监听
  • dubbo简单示例
  • Ubuntu13.10:[3]如何开启SSH SERVER服务
  • [iptables]Redhat 7.2下使用iptables实现NAT
  • Django View(视图系统)
  • 【设计模式】 模式PK:策略模式VS状态模式
  • JS实现-页面数据无限加载
  • CSS小技巧——CSS滚动条美化
  • 最新DOS大全
  • 阿里巴巴分布式服务框架 Dubbo
  • 阿里大鱼.net core 发送短信
  • Sorenson Capital:值得投资的 5 种 AI 技术
  • 程序员入错行怎么办?
  • Arm芯片的新革命在缓缓上演
  • 两张超级大表join优化
  • 第九天函数
  • Linux软件安装-----apache安装
  • 通过Spark进行ALS离线和Stream实时推荐
  • HDU 5988 最小费用流
  • 《看透springmvc源码分析与实践》读书笔记一
  • nagios自写插件—check_file
  • python3 错误 Max retries exceeded with url 解决方法
  • 正式开课!如何学习相机模型与标定?(单目+双目+鱼眼+深度相机)
  • 行为模式之Template Method模式