微服务实践00--微服务方法论00

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 微服务实践00--微服务方法论00

微服务实践目录,可以参见连接。

思想

在接收到一个新的新项目时,架构师的职责是建立项目的业务与技术实现之间的桥梁。在翻译业务到技术实现的过程中需要进行业务建模、技术设计等方面的工作。业务建模和技术设计过程中都有各自领域的知识体系。基本上每个知识体系都是由上层的理论、概念和方法论的提供方向上的支撑,由下层的实施方法、实施工具进行具体工作的实施。

微服务实践系列文章中主要介绍在微服务实践过程中可能会考虑到的方向、以及这些方向可供选择的技术工具、并会涉及少量的架构设计理论知识。而在架构设计系列文章中会介绍架构理论、架构设计实践、以及架构设计中的分析与评估方法。

因为本系列文章主要介绍的是技术工具的内容,就会根据技术工具的特性进行介绍。不过本系列文章中不会像网络上其他的技术文章一样以某项技术为维度进行文章编写。而更像书本以技术的维度进行整理。以这种方式一方面是符合了我们的【实践】题目,便于在实践过程中使用技术工具组织整体架构。另一方面以技术方向而不是某一个技术实现,也是以一种自顶向下的思维方式进行说明(软件研发人员一般会使用自底向上的视为方式)。

技术方向

对于微服务中技术的全局中可能会有很多门技术需要学习与掌握。这里以一张图的方式为大家展示可能在微服务中遇到的技术与实现方向:

技术全景

作者把微服务实践中的技术方向有分了四部分:微服务管理,存储技术,业务支持,DevOps。微服务管理是介绍分布式系统的技术实现部分。存储技术独立出来的意义在于存储和大数据,人工智能等大型的独立系统有关系。业务支持是阐述在业务实现过程中可能会用到的技术,但是不和通用的微服务技术相关的技术。DevOps是在微服务设计和敏捷的提倡下需要接受一切自动化的方式。

技术工具

上图中的浅绿色部分,是说明所有的技术方向。之后所有的文章都会按照这个规范进行编写。右侧每一列都是一项技术实现,这些技术实现可能会涵盖不同的技术方向。所以,这里也会在下面的文章中在不同的技术方向上推荐不同的实现技术。例如:做数据库与缓存同步的工具可选范围不多的情况,我就只能推荐Gearman。

从图中可以看到微服务技术关注的大概方向,基本上整理出来五个大方向。并在五个大方向上有相关的具体技术方向进行补充。现在基本上就缺具体的实现技术选型:

- 微服务管理

  • 内容发布

CDN,分布式存储等

  • 远程过程调用

RPC,RMI,JMS,AMQP,

  • 服务发现

DNS,zookeeper,spring eureka,spring consul,ETCD,REDIS

  • 服务注册

DDNS,zookeeper,spring eureka,spring consul

  • 网关

Zuul,Kong,Nginx Plus,OpenResty,Spring Cloud Gateway

  • 负载均衡

LVS,Nginx,F5

  • 高可用

Haproxy,keepalive

  • 服务编排

Netflix Conductor,uber/cadence,zeebe-io/zeebe,ing-bank/baker,Spring Cloud Zuul, Node-RED,ApiConfig

  • 统一配置

Spring Config,ctripcorp/apollo: Apollo,git,nginx,Consul,Netflix Archaius

  • 分布式任务管理

xxl-job,Elastic-Job,

  • 异步任务

AMQP,Spring Cloud,Dubbo

  • 高速缓存

Redis,Memcache,Mysql Memory DB,H2

  • 前后端分离

Swagger,API Gateway

  • 服务降级

Dubbo,Spring Cloud Hystrix

  • 服务限流

Dubbo,Spring Cloud Hystrix

  • 服务熔断

Dubbo,Spring Cloud Hystrix

  • 故障恢复

Docker,Swarm,K8s

  • 事务管理

sage,fescar,gts,Narayana

  • 动态选举

zookeeper

  • 用户
    用户认证,权限管理,用户计费,会话管理
  • OpenAPI

Kong,APIgee

  • 对象存储

minio,riakcs(亚马逊S3技术),ceph

  • 事件驱动

EventBus, spring event

  • 并发处理

akka,Actor

  • 全局唯一性编码

UUID,SetNX,雪花算法,

  • 规则引擎

Drools

- 存储技术

  • 结构化数据存储

Postgresql,(不推荐Mysql)

  • 半结构化数据存储

redis,MongoDB

  • 无结构数据存储

hdfs,mfs,fastdfs

- 业务支持

  • LBS

木有开源滴。

  • AI
  • BigData
  • 全文检索

Lucene

  • 静态化

freemark

  • 智能推荐

mahout

  • 用户跟踪

木有开源滴。

  • IDaaS(身份认证及服务)

暂未找到

  • SEO/SEM

暂未找到

  • 网络爬虫

Python

  • 特性开关

Flagr,Togglz,FF4J,Fitchy,Flip

  • 租户管理

mybaits-plus,Citus,mycat

  • 第三方支付

需要聚合支付。

  • 可视化

Hue,impala,DataDeck,Tableau,Redash,Metabase,Superset

1. 数据可视化

jtablesaw / tablesaw
Processing

  1. 可视化编程

CoatiSoftware / Sourcetrail

3. 可视化控件

Echarts,D3.js,Tableua

4. 前端低代码

20+个可视化搭建工具,一次玩个够

  • 信息推送

木有开源滴。

- 质量

  • 代码扫描
  • 自动测试

    • 混沌实验

ChaosBlade,Chaos Monkey

- DevOps

  • 运行环境

基础环境都在这里。
Terraform(基础设施即代码)

  • 升级

flagr

  • 部署

Puppet、Chef、Ansible和SaltStack

  • 版本管理

scm

  • 日志管理

elk,flume

  • 监控

Zabbix、Nagios、Open-Falcon

  • 可视化

全局可视化系统

Telegraf InfluxDB Grafana

  • 应用性能

lb的使用情况

  • 调用链

zipkin,pinpiont,skywalking

  • 接口管理

swagger,yapi,rap2

总结

这里提供了完善的分布式系统,微服务,SOA的技术方向体系。之后可以方便的从本系列中选择最优工具加入到业务系统中。

参考:

Spring Cloud 体系
Netflix OSS
BAT 程序员们常用的开发工具
数据可视化的开源方案: Superset vs Redash vs Metabase (一)

运维福音——Terraform 自动化管理京东云

目录
相关文章
|
4天前
|
设计模式 API 开发者
深入浅出微服务架构:从理论到实践
在软件开发领域,微服务架构已经成为一种流行的设计模式。它承诺能够带来更好的模块化、可扩展性和敏捷性。然而,将一个传统的单体应用拆分成多个微服务并非易事。本文旨在通过实际案例分析,帮助读者理解微服务的核心概念,以及如何在实际项目中实施微服务架构。我们将一起探讨微服务的设计原则、技术选型和面临的挑战,并分享一些成功实施的策略。
|
7天前
|
Kubernetes Cloud Native 持续交付
云原生技术浪潮下的微服务架构实践
在数字化转型的今天,云原生技术成为推动企业IT革新的关键力量。本文将通过浅显易懂的语言和实际案例,带领读者了解云原生的核心概念、微服务架构的设计原则以及如何在云平台上高效部署和管理微服务。我们将从基础概念出发,逐步深入到微服务的生命周期管理,探讨如何在云原生生态中实现快速迭代和持续交付。无论你是云原生技术的初学者,还是希望深化理解的开发者,这篇文章都将为你提供有价值的指导和思考。
|
1天前
|
消息中间件 运维 监控
探索微服务架构:从理论到实践
【8月更文挑战第19天】 在数字化时代,微服务架构已成为软件开发的新常态。本文通过深入浅出的方式,介绍了微服务的基本概念、设计原则和实践案例,旨在帮助读者从宏观上理解微服务的设计理念,并掌握将其应用于实际项目中的方法。我们将一起走进微服务的世界,解锁其在现代软件工程中的奥秘。
|
6天前
|
消息中间件 运维 监控
深入浅出微服务架构:从理论到实践
微服务架构,一种将复杂应用拆分成小型、独立服务的设计理念,近年来在软件开发领域大放异彩。它以灵活性、可维护性和可扩展性著称,但同时也带来了一系列挑战,如服务间通信、数据一致性和运维复杂性等。本文旨在通过浅显易懂的语言和实际案例,带领读者深入理解微服务架构的核心概念,掌握其设计原则,并了解如何在实际项目中有效运用。我们将从基础讲起,逐步深入,让初学者能够快速上手,同时为有经验的开发者提供一些高级技巧和最佳实践。
16 4
|
8天前
|
运维 监控 Devops
深入浅出:微服务架构的设计与实践
在软件开发的海洋中,微服务架构如同一艘灵活的快艇,它以小而精的服务单元、松耦合的设计哲学和独立部署的能力,为复杂系统的开发和维护提供了新的解决方案。本文将带你领略微服务的风帆,从理论的灯塔到实践的海岸,共同探索微服务架构的设计原则、技术选型、团队协作模式以及应对常见问题的策略,让你的系统设计之旅充满智慧与乐趣。
22 5
|
6天前
|
监控 API 数据库
深入浅出:微服务架构的设计与实践
微服务架构,作为现代软件工程的一颗璀璨明星,它以小而美、独立部署和易于扩展的特点,正逐步改变着后端开发的面貌。本文将通过浅显易懂的语言,带领读者走进微服务的世界,从概念理解到设计原则,再到实战案例,一步步揭示微服务架构的魅力所在。无论你是初学者还是资深开发者,这篇文章都将为你提供新的视角和思考。
17 2
|
10天前
|
运维 监控 持续交付
探索微服务架构的演变与实践
在数字化浪潮推动下,微服务架构如同细胞分裂般不断演化,孕育出更灵活、高效的系统设计哲学。本文将带你穿梭于微服务的发展历程,解锁其背后的技术密码,并分享构建和部署微服务的实践智慧。从理论到实战,我们将一同见证微服务如何重塑现代应用开发的面貌。
19 2
|
10天前
|
Kubernetes 监控 Docker
深入浅出:微服务架构的设计与实践
在数字化转型的浪潮中,微服务架构以其灵活性和可维护性成为众多企业的首选。本文将通过浅显易懂的语言,带领读者一探微服务的世界,从基础概念到实战部署,解锁微服务架构的设计与实践之门。
23 1
|
11天前
|
Kubernetes Java API
深入浅出微服务架构:从理论到实践
在软件开发领域,微服务架构以其灵活性和可扩展性成为现代应用设计的热门选择。本文将通过浅显易懂的语言解释微服务的核心概念,并结合案例探讨如何在实际项目中实施微服务架构。我们将从微服务的定义出发,逐步深入到设计原则、关键技术和实战应用,为读者提供一条清晰的学习路径。无论你是初学者还是有一定经验的开发者,都能从中获益。
|
12天前
|
Kubernetes 监控 Cloud Native
云原生时代的微服务架构实践
在数字化转型的浪潮中,企业级应用正经历着从传统架构到云原生微服务架构的转变。本文将深入探讨云原生技术如何赋能微服务架构,实现服务的快速迭代与弹性扩展,并分析微服务拆分的最佳实践和面临的挑战,以及如何利用云原生工具集来构建和管理微服务。我们将通过具体案例,展示如何在云平台上部署和管理微服务,确保系统的高可用性和可维护性,同时提供一套应对常见微服务问题的解决策略。