01.微服务系列介绍

微服务系列实践 .NET CORE

在开始之前呢,还是得废话一下,毕竟还是需要介绍一下这个系列我们要实现什么样的一套服务架构,也让大家能初步的有一个了解,后续实践起来也有一个完整的概念,相对也会容易的多。

互联网架构演变

随着市场的快速发展,业务的不断扩大,单块架构应用面临着越来越多的挑战,其改造与重构势在必行。而微服务架构的诞生,是互联网高速发展,虚拟化技术应用以及持续交付、DevOps深入人心的综合产物。随着用户需求个性化、产品生命周期变短,微服务架构是未来软件软件架构朝着灵活性、扩展性、伸缩性以及高可用性发展的必然方向。同时,以Docker为代表的容器虚拟化技术的盛行,将大大降低微服务实施的成本,为微服务落地以及大规模使用提供了坚实的基础和保障。

640?wx_fmt=png

单体架构

记得刚毕业12年左右那会这种单体应用都是常规的一种软件开发设计模式,它足够简单,在当时能很好切较快的满足各种小心公司的各个业务模块。

优点

  • 请求延时低

  • 部署运维成本低

  • 开发简单直接,集中式管理

  • 单应用内基本不会重复开发

缺点

  • 耦合严重,可拓展性差

  • 技术选型单一

  • 架构力度较粗,不能很好适应需求的迭代

  • 提供服务困难,调用困难

  • 配置越来越多管理也变得更加苦难

  • 加载、编译缓慢

RPC架构

随着应用的迭代、系统访问量提高、业务复杂度提高、代码也越来越复杂,这个时候单体应用架构逐渐转变为面向服务的架构转变。RPC(Remote Promote Call) 一种进程间通信方式,允许像调用本地服务一样调用远程服务,在 .NET 语言,接触的比较少,在java当中如:spring cloud、dubbo。

优点

  • RPC框架一般使用长链接,不必每次通信都要3次握手,减少网络开销

  • RPC框架一般都有注册中心,有丰富的监控管理

  • 发布、下线接口、动态扩展等,对调用方来说是无感知、统一化的操作

  • 协议私密,安全性较高

  • rpc 协议更简单内容更小,效率更高

  • 服务化架构、服务化治理,RPC框架是一个强力的支撑

缺点

  • 配置复杂

  • 仅适用内部服务调用

  • 多了一层间接性,出现网络问题时,debug比较困难

  • 交互方式单一,不能进行复杂的多模块之间的协议交互

  • 异常处理困难

改善了单体应用在系统间交互的不足,适用于内部服务交互。

微服务架构 与 SOA架构

这两个我就放一起说了,因为本质上SOA与微服务是一脉相承的,微服务相当于把SOA的理念继续升华,精进。

其核心思想是在应用开发领域,使用一系列微小服务来实现单个应用的方式途径,或者说微服务的目的是有效的拆分应用,实现敏捷开发和部署 ,可以是使用不同的编程语言编写。而SOA可能包含的意义更泛一些,更不准确一些。

随着业务发展,服务数量越来越多,服务生命周期管控和运行态的治理成为瓶颈,单体架构按照业务功能在垂直方向进行拆分,就变成了SOA架构,用于提升服务质量、服务治理。

微服务是一种架构风格,也是一种服务,通过服务的原子化拆分,以及微服务的独立打包、部署和升级,小团队的交付周期将缩短,运维成本也将大幅度下降。

优点

  • 按业务边界拆分服务

  • 服务可独立部署

  • 服务复用率高

  • 服务之间通讯也变得更加容易

  • 从架构划分应用划分更加清晰

  • 核心模块稳定,独立升级带来的影响较小

  • 服务可根据分类到团队进行管理(维护、工作分明,职责清晰)

  • 业务模块复用率相对较高

  • 按照业务边界划分后的服务拓展也更加容易

  • 可不同语言,引入新技术较为方便

微服务系列的实践方式

虽然微服务有着很大的优势,但同时我们面临的挑战也将更多:

  • 服务多,配置管理复杂

  • 服务间依赖关系复杂

  • 服务需要通过负载集群实现高可用

  • 服务调用关系及性能监控面临挑战

  • 服务文档的规范

  • 服务降级、熔断

  • 服务的拓展性

我们的实现方式:

  • 负载集群及高可用:keepalived + nginx

  • 服务注册、发现、健康检查通知:consul

  • 服务治理、性能监控、跟踪:skywalking

  • 统一配置中心:apollo

  • 集中的日志:elasticSearch + logstash + kibana

  • API网关(熔断、降级):Ocelot

640?wx_fmt=png

总结

总之呢,微服务的核心思想是有多个独立的微小的服务组成,每个服务的开发和发布都没有绝对的依赖关系。服务可独立拓展伸缩,每个服务应有自己明确的边界,也可以采用不同的编程语言来实现,我们主要做的就是给用户一个友好的体验,让用户能感受到它的方便简单和快捷,服务内部也应该有良好的日志和监控体系,提高服务的高可用、易拓展的能力。

原文地址: https://github.com/zengqinglei/microservice-deploy/wiki/01.%E5%BE%AE%E6%9C%8D%E5%8A%A1%E7%B3%BB%E5%88%97%E4%BB%8B%E7%BB%8D


640?wx_fmt=jpeg


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

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

相关文章

Walker

Walker 题意: 一个区间[0,n],区间上有两个点,坐标分别是pos1,pos2,速度分别是v1,v2,这两个点是在移动,可以随时改变移动方向,问当区间的每一块均被一个点或两个点移动覆…

【网络流】最大流问题(EK算法带模板,Dinic算法带模板及弧优化,ISAP算法带模板及弧优化)上下界网络流

本blog重点是代码网络流的相关概念流网络(flow network)流(flow)网络的流残留网络(residual network)增广路径(augmenting path)Edmonds-Karp算法思想bfs模板调用EK&更新残留网络流模板luogu的AC代码(EK版)Dinic算法思路时间复杂度证明bfs模板模板1模板2dfs模板不带弧优化模…

Rainbond 5.0正式发布, 支持对接管理已有Kubernetes集群

今天很高兴的向大家宣布Rainbond v5.0正式发布,Rainbond是开源的企业应用云操作系统,支撑企业应用的开发、架构、交付和运维的全流程,通过无侵入架构,无缝衔接各类企业应用,底层资源可以对接和管理IaaS、虚拟机和物理服…

Fibonacci

Fibonacci 题意: f[i]表示第i位的斐波那契数列 给定n,求 题解: 这种题一开始没什么思路,那么枚举就行 g(x,y) 1 是当x * y为偶数时 x * y为偶数说明: x是偶数,y也是偶数 x是奇数,y是偶数 而…

基于.NET Standard的分布式自增ID算法--美团点评LeafSegment

概述前一篇文章讲述了最流行的分布式ID生成算法snowflake,本篇文章根据美团点评分布式ID生成系统文章,介绍另一种相对更容易理解和编写的分布式ID生成方式。实现原理Leaf这个名字是来自德国哲学家、数学家莱布尼茨的一句话:There are no two …

[费用流专题]Going Home,Minimum Cost,工作安排

文章目录T1:Going Home题目题解CODET2:Minimum Cost题目题解CODET3:工作安排题解CODET1:Going Home 题目 On a grid map there are n little men and n houses. In each unit time, every little man can move one unit step, e…

Sky Garden

Sky Garden 题意: 画n个圆和m条直线,圆的中心点为(0,0),圆的半径分别从1到n,而直线都必经过(0,0)点,并且所有直线会把每个圆平均分成2m个面积相等的区域,直线会和圆形成交点,求所有交点两两经…

IdentityServer4-前后端分离的授权验证(六)

上两节介绍完Hybrid模式在MVC下的使用,包括验证从数据获取的User和Claim对MVC的身份授权。本节将介绍Implicit模式在JavaScript应用程序中的使用,使用Node.jsExpress构建JavaScript客户端,实现前后端分离。本节授权服务和资源服务器基于第四和…

人类智慧贪心

题意看起来很清新&#xff0c;代码实现也基本在入门难度&#xff0c;但是为什么我不会&#xff01; 另&#xff1a;反悔贪心 <details><summary>$\texttt{solution}$</summary></details> P2672 [NOIP2015 普及组] 推销员 $\texttt{solution}$ 发现答案…

周末狂欢赛3(跳格子,英雄联盟,排序问题)

文章目录T1&#xff1a;跳格子题目题解CODET2&#xff1a;英雄联盟题目题解CODET3&#xff1a;排序问题题目题解CODET1&#xff1a;跳格子 题目 n 个格子排成一列&#xff0c;一开始&#xff0c;你在第一个格子&#xff0c;目标为跳到第 n 个格子。在每个格子 i 里面你可以做…

想让AI在企业落地?微软最新Azure AI不容错过!

Microsoft Connect(); 2018 如期举行&#xff0c;大会上发布的众多顶尖技术&#xff0c;瞬间引爆了全球&#xff01;AI的高速发展&#xff0c;正在掀起新一波的创新浪潮。对于很多企业来说&#xff0c;AI创造的巨大价值&#xff0c;是不容错过的风口&#xff0c;大会上&#xf…

[费用流]数字配对,新生舞会

文章目录T1&#xff1a;数字配对题目题解CODET2&#xff1a;新生舞会题目题解CODE&#xff08;最大费用最大流版&#xff09;CODE&#xff08;最小费用最大流版&#xff09;T1&#xff1a;数字配对 题目 有 n 种数字&#xff0c;第 i 种数字是 ai、有 bi 个&#xff0c;权值是…

.NET Core实战项目之CMS 第十三章 开发篇-在MVC项目结构介绍及应用第三方UI

作为后端开发的我来说&#xff0c;前端表示真心玩不转&#xff0c;你如果让我微调一个位置的样式的话还行&#xff0c;但是让我写一个很漂亮的后台的话&#xff0c;真心做不到&#xff0c;所以我一般会选择套用一些开源UI模板来进行系统UI的设计。那如何套用呢&#xff1f;今天…

[FFT/IFFT]快速傅里叶(逆)变化 + 递归和递推模板

现在时间是2021-2-2&#xff0c;重新回来看2019学习的一知半解的FFTFFTFFT&#xff0c;又有了新的理解 所以修改了以往写过的文章&#xff0c;并增添些许内容 因为过去一年多&#xff0c;上了高中&#xff0c;学的知识多了些&#xff0c;以前不懂的有些东西现在看来挺简单的&am…

软件开发模式:瀑布与敏捷

瀑布和敏捷不是什么新概念&#xff0c;这里只是个人在团队合作中不得不去思考而做的归纳和总结&#xff0c;同时记录自己曾经踩过的坑&#xff0c;新瓶装旧酒&#xff0c;希望对你有所启发。瀑布模式瀑布模型是比较传统一种开发模式&#xff0c;特别是在2B的传统企业&#xff0…

.net core+Spring Cloud学习之路 一

文章开头唠叨两句。2019年了&#xff0c;而自己参加工作也两年有余了&#xff0c;用一个词来概括这两年多的生活&#xff0c;就是&#xff1a;“碌碌无为”。也不能说一点收获都没有&#xff0c;但是很少。2019来了&#xff0c;我立志要打破现状&#xff0c;改变自己&#xff0…

P3128 [USACO15DEC]Max Flow P

P3128 [USACO15DEC]Max Flow P 树上差分之点差分模板题 题目描述&#xff1a; FJ给他的牛棚的N(2≤N≤50,000)个隔间之间安装了N-1根管道&#xff0c;隔间编号从1到N。所有隔间都被管道连通了。 FJ有K(1≤K≤100,000)条运输牛奶的路线&#xff0c;第i条路线从隔间si运输到隔…

周末狂欢赛4(1-02E. JM的西伯利亚特快专递,寿司晚宴,荷马史诗)

文章目录T1&#xff1a;1-02E. JM的西伯利亚特快专递题目题解codeT2&#xff1a;寿司晚宴题目题解codeT3&#xff1a;荷马史诗题目题解codeT1&#xff1a;1-02E. JM的西伯利亚特快专递 题目 今天JM收到了一份来自西伯利亚的特快专递&#xff0c;里面装了一个字符串 s &#x…

.NET Core容器化开发系列(一)——Docker里面跑个.NET Core

前言博客园中已经有很多如何在Docker里面运行ASP.NET Core的介绍了。本篇主要介绍一些细节&#xff0c;帮助初学的朋友更加深入地理解如何在Docker中运行ASP.NET Core。安装DockerDocker现支持在主流Linux、Windows和macOS上安装&#xff0c;官方的安装文档请参考docker docs。…

中小研发团队架构实践之生产环境诊断工具WinDbg

生产环境偶尔会出现一些异常问题&#xff0c;WinDbg或GDB是解决此类问题的利器。调试工具WinDbg如同医生的听诊器&#xff0c;是系统生病时做问题诊断的逆向分析工具&#xff0c;Dump文件类似于飞机的黑匣子&#xff0c;记录着生产环境程序运行的状态。本文主要介绍了调试工具W…