百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

微服务时代,运维必须了解的那些事(服务架构演变)

wptr33 2025-04-05 23:30 18 浏览

现在IT已经进入了微服务时代,作为运维,思想观念也需要跟上,所以,这里跟大家说一下,运维需要知道哪些知识。

服务架构演变史

首先说一下架构的演变史。

应用架构已经从最开始单体架构,SOA架构逐渐演变成了现在最新的微服务架构。每个架构的演变,都是对开发的一次解放,也是对运维的要求进一步的提高。可以这么说,运维在这些年来,逐渐变得越来越专业,越来越重要。

单体架构

首先说一下单体架构吧,就是一个业务就是只有一个Java WAR文件,一般也就一个Redis,所有的功能都在一起,代码也都在一起。单体架构是最早的开发模式,现在还有很多小的项目使用这种方法,因为方式很简单。但是也带来了很多问题,诸如开发麻烦(所有的开发在一个项目改代码,递交代码相互等待,代码冲突不断),维护麻烦(代码功能耦合在一起,新人不知道何从下手),部署麻烦(构建时间长,任何小修改必须重新构建整个项目,这个过程往往很长),稳定性差(一个部分出问题就全挂了)。

然后随着业务的要求逐渐增加,所有就有了面向服务的架构——SOA架构.

SOA架构

SOA可以这样粗暴的理解:把系统按照实际业务,拆分成刚刚好大小的、合适的、独立部署的模块,每个模块之间相互独立。

使用SOA架构,会有多个服务模块,那么这些模块是如何组装在一起的呢?那就是使用了企业服务总线(ESB)

在一个大公司,会有很多的服务,比如说OA,考勤,财务,对外的业务等等,这些服务开发的人员都不一样,开发的语言可能也用的不同,那么怎么样把他们集成在一起,并且可以互相通讯呢?

首先,每个服务都会需要提供一个可以被远程调用的通用接口,并且注册到ESB上,ESB负责服务注册和服务治理。有了ESB我们就能清晰地看到服务被谁谁谁调用,谁谁谁调用了哪些服务,哪些服务是热点服务需要配置服务器集群,而对这个服务集群的负载均衡也是ESB可以完成的重要功能之一。

但是,SOA也只是一个粗粒度的拆分,并且为了兼容各种不同的服务,会有一个很笨重的ESB总线,因此,又诞生了一种新的架构——微服务架构。

微服务架构

微服务架构舍弃了笨重的ESB总线,取而代之的是轻便的apigateway,也就是api网关。

API网关负责服务请求路由、组合及协议转换。客户端的所有请求都首先经过 API网关,然后由它将请求路由到合适的微服务。API网关经常会通过调用多个微服务并合并来处理一个请求。它可以在 WEB协议与内部使用的非WEB协议之间相互转换。

除此之外,微服务还对服务进行了更细粒度的拆分,把服务拆分成了一个一个的组件,每个组件都可以用自己喜欢的方式来实现。这样就好比原来是一个部门去整体开发一个业务,现在是精确到每个人负责其中的一个功能。

微服务的出现,使得开发更加的专注,只需要实现一个功能,并且微服务之间更进一步的解耦合,从而可以频繁发布。

对运维的要求——自动化部署平台

随着服务架构的演变,对运维的要求也越来越高。

首先是发布频率的极大改变,单体架构的发布很少,可能是一个月几次,或者几个月一次,每次发布都会选择在晚上或者用户较少的时间。到了SOA架构,服务之间的解耦合,使得服务发布频率变大,开始变成一周好几次或者一天一两次。现在的微服务时代,发布的频率变成了一天好几十次甚至几百上千次,因此,自动化部署平台(CICD)也就是运维必须要搭建的服务了,不然无法满足频繁发布的要求。

自动化部署平台,现在的主要框架还是Git+Jenkins+harbor+k8s+配置管理这一套架构。

首先,git是代码管理中心,开发在写完代码后会推送到git上,根据实际的需求,可以是推送到指定分支后自动触发webhook调用jenkins,或者是在jenkins上手动进行发布,这个是运维要根据实际需求来实现。提交代码后,就是CI ,持续集成(CI)是构建软件和完成初始测试的过程。通过jenkins来拉取git上的代码,然后进行编译构建成指定的产物(二进制包或者镜像),并且完成初始的测试,并且把产物归档(上传到指定机器或者harbor)。在大多数使用k8s的公司,编译产物都是镜像,并且上传到harbor中,打好对应的tag。

CI完成后,就是CD,持续部署(CD)是将代码与基础设施相结合的过程,确保完成所有测试并遵循策略,然后将代码部署到预期环境中。CD大多数也是使用jenkins来实现,使用jenkins从git上拉取对应的部署文件,可以是helm,也可以是yaml文件,并且将对应的镜像传输至指定环境的harbor,通过执行helm或者yaml文件,来拉取对应的镜像并且部署到k8s平台上。同时,为了统一管理各个微服务的配置文件,也会需要一个统一的配置管理中心,可以使用k8s的configmap,亦可以使用第三方的配置管理中心,比如说nacos或者eureka。

CD很多还会伴随着测试和监控,以及日志的收集.

说完了自动化话部署平台,接下来就是微服务的编排与治理,将会在下一篇文章为大家介绍。

相关推荐

redis的八种使用场景

前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...

基于Redis的3种分布式ID生成策略

在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...

基于OpenWrt系统路由器的模式切换与网页设计

摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...

这篇文章教你看明白 nginx-ingress 控制器

主机nginx一般nginx做主机反向代理(网关)有以下配置...

如何用redis实现注册中心

一句话总结使用Redis实现注册中心:服务注册...

爱可可老师24小时热门分享(2020.5.10)

No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...

Apportable:拯救程序员,IOS一秒变安卓

摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...

JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透

以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...

3月26日更新 快速施法自动施法可独立设置

2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...

Redis 是如何提供服务的

在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...

lua _G、_VERSION使用

到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...

China's top diplomat to chair third China-Pacific Island countries foreign ministers' meeting

BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...

移动工作交流工具Lua推出Insights数据分析产品

Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...

Redis 7新武器:用Redis Stack实现向量搜索的极限压测

当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...

Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求

重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...