istio springcloud_手牵手一起学Springcloud(1)微服务这么流行,你理解了嘛?

在前一段时间,我们实验室的项目开始变得越来越麻烦,代码也越来越臃肿,一个人兼顾前后端的全栈开发,实在是力不从心,没有一点点幸福感,于是迫切的想要解放生产力,放飞自我,因此开始决定重构项目,改用之前学习过但是一直没用过的微服务架构。这篇文章将从以下几个角度来学习Springcloud入门的一些相关知识。

1、微服务是什么?

2、微服务和微服务架构的区别是什么?

3、微服务技术有什么?

4、微服务的优缺点是什么?

5、为什么选择Springcloud作为微服务架构?

在写本系列文章之前,我也看了很多网上的大佬那些微服务系列的文章,他们写的都非常好,别人问我关于一些微服务的技术文章时,我也都会把那些我认为写的好的文章推送给他们,但是存在一个问题,那就是刚刚接触微服务的同学,一开始觉得写的通俗易懂而且确实很简单,但是越往后看越看不懂。因此才萌生出自己写一套循序渐进的文章。

一、从单体结构说起

本来想以自己的项目为例,但是由于涉及一些学校不能外传的信息,所以换一个常见的例子。我们以餐厅卖饭为例

77a3963cdbc146040ec47d43305c4b1d.png

从上图我们会发现,收银、做饭、洗碗等操作都由小张一个人完成。随着服务项目的不断复杂,顾客人数的不断增多,这会带来大量的问题。

1、技术太复杂,有时候往往会牵一发而动全身,代码耦合性太大,修改起来很麻烦。

2、拓展能力弱,功能模块代码紧耦合,无人进行有效拓展

3、维护成本太高,一旦出一个问题,修改很难受。

当然还有很多很多的缺点,为此继续一种技术去改善这个问题。什么技术呢?就是我们今天所说的微服务架构。

二、什么是微服务

由于业界还没有对微服务的概念有一个统一的解释,但是你可以这样去理解,微服务其实就是一种思想,这个思想是:考虑如何把一个复杂的项目拆分成一个个独立的小项目。就好比是电脑中的进程,拆分成一个个小的线程一样。

再举个

8ee29803cf615ceaa055e84e26ab92a6.png

现在,小张每一个服务业务都让不同的人来负责,这就大大简化了人的劳动程度。

三、微服务和微服务架构的区别是什么

他们俩的区别你可以这样去理解,微服务就好比是指导思想,微服务架构就是根据这个指导思想实施的方案。就好比是古代的时候,皇帝说要减轻赋税,然后下面的大臣根据这个指导思想去实施具体的方案。

当然这里还有更加标准化的回答:

微服务架构是⼀种架构模式,它提倡将单⼀应⽤程序划分成⼀组⼩的服务,服务之间互相协调、互相配合,为⽤户提供最终价值。每个服务运⾏在其独⽴的进程中,采⽤轻量级的通信机制互相协作

如果你能理解刚刚皇帝的那个例子,应该就能理解微服务架构的含义了。

四、微服务技术有什么?

微服务的技术还是很多的,python、c++等等都有,不过因为是专注于java,所以还是主要聊聊java中的微服务技术。

Dubbo被重启之后又焕发出了新的光彩,但是跨语言支持不足是它的一个弱项,另外功能比较少,之后服务治理相关的技术,完全用好这个框架的门槛比较高。这对于初学者来说开发难度还是比较大的。目前dubbo已经被阿里捐献给Apache了,Apache也正在致力打造属于dubbo的微服务体系,但是从这两年多的发展情况来看,并不乐观。

Netflix微服务架构经过多年生产验证,最终形成一整套开源的微服务基础组件,统称 NetflixOSS,Netflix 的成功经验开始被业界认可并推崇,于是Pivotal 将 NetflixOSS 开源微服务组件集成到其 Spring 体系,推出 Spring Cloud 微服务开发技术栈。随着时间的推移目前基本上也占据了半壁江山。本系列教程也会围绕着Springcloud来展开。

其他的微服务技术比如springcloud Alibaba、istio等等在这里就不对比了,没有大规模使用的还有待观察。一旦流行了再学习也不迟。

五、微服务的优缺点是什么?

既然要使用微服务,微服务有什么优点呢?他的优缺点你可以对比着单体结构的缺点来记忆。

1、维护起来比较简单,毕竟每一个服务只关注于项目中的一个小模块

2、拓展性好,有新功能需要添加的时候,那就再建立一个微服务,和之前的互不干扰。

3、每一个微服务都有着自己的数据库

优点真的是太多了,能想到的就这些吧。

当然还有很多缺点,咳咳,缺点不说太多,要不然你觉得微服务不好了,缺点那就是一个个微服务构成了分布式系统,出现了分布式系统的各种问题。

六、为什么选择Springcloud?

说实话,一开始我在认识微服务的时候,完全不理解他的特点是什么含义,只有当学习了一遍之后,重新回过头来看,才发现,原来是这样呀。不过在这里你最好先记住。否则以后你连回头的想法都没:

1、约定大于配置。

2、适用于各种环境

3、整合了Springboot的优点

4、轻量级组件

5、功能齐全

6、灵活

优点太多,数不过来,所以你先记住这几条,看了几本书发现基本上也是这样介绍的。

这篇文章是我的微服务系列的第一篇文章,下一篇文章将主要开始介绍Springcloud的每一个组件的功能,以及为什么要有这样一个组件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/527067.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2021年计算机应用基础统考题库,2021年计算机应用基础统考题库试卷全-20210515145621.doc-原创力文档...

一、单选题1、第三代计算机运算速度_____。A:高于第二代但低于第四代B:高于第一代但低于第二代C:低于第一代D:高于第四代答案: A2、将计算机分为通用计算机、专用计算机两类分类原则是______。A:计算机解决…

力改变物体形状举例_人教版八年级物理下册第七章《力》知识点大全

力是物体对物体的作用,比如推土机推动了土。知识点1:力1.概念:是物体对物体的作用叫做力。2.特点:物体间力的作用是相互的。3.力的单位和表示符号:(1)力的单位:牛顿,简称牛(N)。托起一个鸡蛋大约…

计算机29首流行音乐叫什么,流行歌曲有哪些 流行歌曲500首

流行歌曲有哪些 流行歌曲500首作者: 锦瑟更新日期: 2020-10-15 21:43:12音乐是一种能治愈人心的存在,它还可以炒热气氛和渲染气氛,总之歌曲的共情能力是很强的,相信没几个人会不喜欢音乐的吧。小编也喜欢在无聊的时候听一下音乐呢&#xff0c…

bool类型数组转换成一个整数_Go 学习笔记 02 | 基本数据类型以及 byte 和 rune 类型...

一、基本数据类型unsafe.Sizeof() 查看不同长度的整型在内存中的存储空间。 类型转换,高位向低位转换要注意溢出。数字字面量语法。64 位系统中 Go 语言中浮点数默认是 float64。二、Golang 中 float 精度丢失问题利用第三方包:http://github.com/shopsp…

计算机应用基础(高起专)答案,东北师范大学14秋《计算机应用基础(高起专)》14秋在线作业1答案...

计算机应用基础(高起专)《计算机应用基础(高起专)》14秋在线作业1 一,单选题1. 局域网组网完成后,决定网络使用性能的关键是A. 网络的拓扑结构B. 网络的通信协议C. 网络的传输介质D. 网络的操作系统?正确答案:D2. 加工处理汉字信息时,使用汉…

ldap基本dn_LDAP 中 DN CN DC OU

DN 的英文名称是(distinguished name),直接翻译过来就是专有名称。简单的就可以理解为一个路径就对了。这个路径可以指向 OU ,也可以指到 CN。其中 DN 有三个属性,分别是CN,OU,DC。DC (Domain C…

学校计算机 电教材料账册,电教室管理制度

电教室管理制度(一)电教室必须有专人管理。未经许可,外人不得擅 自动用仪器、设备。(二)按配备标准和教学要求,及时申购仪器、设备及材料,保证教学正常进行。(三)仪器、设备、材料入库,要凭单据及时记账、编号后分类存放&#xff…

滴答定时器的计数模式_【高手私藏】STM32学习笔记:SysTick滴答时钟

今天我们来说说SysTick定时器。SysTick定时器在从参考手册中根本没有介绍。我费了九牛二虎之力才在一个犄角格拉里找到SysTick定时器的英文版的说明。在Cotex-M3有介绍,为什么要找STM32的介绍,是因为功能设置上还有点区别。首先看一下SysTick定时器的作用…

2008wsus创建和管理计算机组,Windows Server 2012 R2 WSUS-6:配置计算机组和客户端目标...

转载:https://blog.51cto.com/543925535/1406660对于WSUS来说,配置计算机的方式有两个出发点,一个是使用update services控制台来配置计算机组,计算机分组的管理都需要手动维护,第二种是使用计算机上的组策略和注册表设…

多选框实现全选_Angular1.x-checkbox-全选amp;单选amp;多选

ng-checked&#xff1a;Angular里ng-checked属性影响复选框的状态&#xff0c;值>true则复选框选中&#xff0c;值>false则取消选中。HTML:<div class"col-lg-4"><fieldset><legend>选题列表</legend><div class"table-respon…

复旦计算机考研复试要口试吗,2017复旦大学考研复试:英语口语面试常见问题汇总...

2017复旦大学考研复试&#xff1a;英语口语面试常见问题汇总本站小编 辅仁网/2017-12-29A magazine publisher is trying to decide how many magazines she should deliver to each individual distribution out let in order to maximize profits. She has extensive histori…

2020笔记本性价比之王_什么笔记本性价比高?2020性价比最高的笔记本电脑

阅读本文前&#xff0c;请您先点击上面的蓝色字体&#xff0c;再点击“关注”&#xff0c;这样您就可以继续免费收到最新文章了。每天都有分享。完全是免费订阅&#xff0c;请放心关注。注&#xff1a;本文转载自网络&#xff0c;不代表本平台立场&#xff0c;仅供读者参考&…

专利计算机存储介质是智力活动,涉及计算机程序的发明专利申请的相关问题PPT课件.pptx...

文档介绍&#xff1a;1提纲涉及计算机程序的专利申请涉及算法的专利申请“方法与产品相对应”的情形2涉及计算机程序的专利申请涉及程序本身的权利要求主题名称为程序限定内容涉及程序本身限定内容仅涉及程序本身限定内容一部分涉及程序本身3涉及计算机程序的专利申请主题名称为…

前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录

为什么UI自动化维护成本更高&#xff1f;因为前端页面变化太快&#xff0c;而且UI自动化比较耗时(比如等待页面元素的加载、添加等待时间、定位元素、操作元素、模拟页面动作这些都需要时间)为什么接口自动化维护成本较低&#xff1f;因为接口较稳定&#xff0c;接口的响应时间…

input css年月日,input标签的type为date,显示的日期格式样式更改

这个///是改不了---的&#xff0c;这是谷哥自带的功能样式&#xff0c;只能改颜色背景色等&#xff0c;如果要那种效果可以用日历插件有个取巧的方法&#xff0c;一个不能改的input覆盖在input type"date"上面*{margin: 0;padding: 0;}#div{width: 500px;height: 300…

docker 容器安装conposer_docker和php:将依赖项(composer)放入容器中

目前我正致力于以下解决方案&#xff1a;开发环境&#xff1a;将整个src添加为volume&#xff1a;volumes:- .:/appinitial composer install commanddocker-compose exec app composer installinstall new composer package:docker-compose exec app composer require some/pa…

Windows虚拟服务器vm,史上最详细的虚拟机VMware12安装Windows7教程 | 心塞塞

首先你电脑必须安装了 VMware &#xff0c;推荐版本 VMware12 或者 VMware 11 版本&#xff0c;然后你还需要一个系统镜像&#xff0c;可以通过下面链接下载 Win7 的镜像&#xff0c;复制链接&#xff0c;打开迅雷新建任务即可下载&#xff1a;Windows7 64位1ed2k://|file|cn_w…

shader 获取法线_Unity Shader 入门到改行5——法线贴图

the best of blur1. 法线贴图理论1.1 什么是法线贴图一般的贴图中存储的是表面颜色值(RGBA)&#xff0c;而法线贴图存放的则是法线信息(xyzw)&#xff0c;假设某顶点处的 uv 坐标为 (u,v), 那么在法线贴图 (u,v)处纹素的值表示该顶点的“法线”方向。通常法线贴图中存储的并不是…

主站系统服务器选择,配电网自动化主站系统的结构_功能及操作系统的选择.doc...

业界建设行业专版水电暖通配电网自动化主站系统的结构&#xff0c;功能及操作系统的选择"徐德勇摘 要&#xff1a;本文主要从系统结构"子系统划分"设计实施"操作系统的选择"及其功能等方面介绍了配电自动化主站系统%关键词&#xff1a;配电自动化*系统…

python切面异常处理_Spring项目中优雅的异常处理

Spring项目中优雅的异常处理前言如今的Java Web项目多是以 MVC 模式构建的&#xff0c;通常我们都是将 Service 层的异常统一的抛出&#xff0c;包括自定义异常和一些意外出现的异常&#xff0c;以便进行事务回滚&#xff0c;而 Service 的调用者 Controller 则承担着异常处理的…