上次我們說到 微服務架構的前世今生(七):微服務架構生態體系 ,這次我們在說說微服務架構的技術支持。作者 哈嘍沃德先生,歡迎關註。 一、Spring Cloud Spring Cloud Netflix Eureka:服務註冊中心。 Spring Cloud Zookeeper:服務註冊中心。 Sp ...
上次我們說到 微服務架構的前世今生(七):微服務架構生態體系 ,這次我們在說說微服務架構的技術支持。作者 哈嘍沃德先生,歡迎關註。
一、Spring Cloud
Spring Cloud Netflix Eureka
:服務註冊中心。Spring Cloud Zookeeper
:服務註冊中心。Spring Cloud Consul
:服務註冊和配置管理中心。Spring Cloud Netflix Ribbon
:客戶端負載均衡。Spring Cloud Netflix Hystrix
:服務容錯保護。Spring Cloud Netflix Feign
:聲明式服務調用。Spring Cloud OpenFeign(可替代 Feign)
:OpenFeign 是 Spring Cloud 在 Feign 的基礎上支持了 Spring MVC 的註解,如 @RequesMapping等等。OpenFeign 的 @FeignClient 可以解析 SpringMVC 的 @RequestMapping 註解下的介面,並通過動態代理的方式產生實現類,實現類中做負載均衡並調用其他服務。Spring Cloud Netflix Zuul
:API 網關服務,過濾、安全、監控、限流、路由。Spring Cloud Gateway(可替代 Zuul)
:Spring Cloud Gateway 是 Spring 官方基於 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技術開發的網關,Spring Cloud Gateway 旨在為微服務架構提供一種簡單而有效的統一的 API 路由管理方式。Spring Cloud Gateway 作為 Spring Cloud 生態系中的網關,目標是替代 Netflix Zuul,其不僅提供統一的路由方式,並且基於 Filter 鏈的方式提供了網關基本的功能,例如:安全,監控/埋點,和限流等。Spring Cloud Security
:安全認證。Spring Cloud Config
:分散式配置中心。配置管理工具,支持使用 Git 存儲配置內容,支持應用配置的外部化存儲,支持客戶端配置信息刷新、加解密配置內容等。Spring Cloud Bus
:事件、消息匯流排,用於在集群(例如,配置變化事件)中傳播狀態變化,可與 Spring Cloud Config 聯合實現熱部署。Spring Cloud Stream
:消息驅動微服務。Spring Cloud Sleuth
:分散式服務跟蹤。Spring Cloud Alibaba Nacos
:阿裡巴巴開源產品,一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平臺。Spring Cloud Alibaba Sentinel
:面向分散式服務架構的輕量級流量控制產品,把流量作為切入點,從流量控制、熔斷降級、系統負載保護等多個維度保護服務的穩定性。Spring Cloud Alibaba RocketMQ
:一款開源的分散式消息系統,基於高可用分散式集群技術,提供低延時的、高可靠的消息發佈與訂閱服務。Spring Cloud Alibaba Dubbo
:Apache Dubbo™ 是一款高性能 Java RPC 框架,用於實現服務通信。Spring Cloud Alibaba Seata
:阿裡巴巴開源產品,一個易於使用的高性能微服務分散式事務解決方案。Spring Cloud Alibaba OSS
:阿裡雲對象存儲服務(Object Storage Service,簡稱 OSS),是阿裡雲提供的海量、安全、低成本、高可靠的雲存儲服務。您可以在任何應用、任何時間、任何地點存儲和訪問任意類型的數據。Spring Cloud Alibaba SchedulerX
:阿裡中間件團隊開發的一款分散式任務調度產品,提供秒級、精準、高可靠、高可用的定時(基於 Cron 表達式)任務調度服務。Spring Cloud Alibaba SMS
:覆蓋全球的簡訊服務,友好、高效、智能的互聯化通訊能力,幫助企業迅速搭建客戶觸達通道。
二、其他大哥
RibbitMQ
:RabbitMQ 是部署最廣泛的開源消息中間件。是實現了高級消息隊列協議(AMQP)的開源消息中間件。Kafka
:Kafka 是由 Apache 軟體基金會開發的一個開源流處理平臺,由Scala和Java編寫。Kafka 是一種高吞吐量的分散式發佈訂閱消息系統。Redis
:Redis(Remote Dictionary Server ),即遠程字典服務,是一個開源的使用 ANSI C 語言編寫、支持網路、可基於記憶體亦可持久化的日誌型、Key-Value 資料庫,並提供多種語言的 API。MongoDB
:MongoDB 是一個介於關係資料庫和非關係資料庫之間的產品,是非關係資料庫當中功能最豐富,最像關係資料庫的。它支持的數據結構非常鬆散,是類似 json 的 bson 格式,因此可以存儲比較複雜的數據類型。Elasticsearch
:Elasticsearch 是一個基於 Lucene 的搜索伺服器。它提供了一個分散式多用戶能力的全文搜索引擎,基於 RESTful web 介面。Elasticsearch 是最受歡迎的企業搜索引擎,其次是 Apache Solr,也是基於 Lucene。MySQL
:MySQL 是一種開放源代碼的關係型資料庫管理系統(RDBMS),免費、簡單、占資源少、強大好用。Oracle
:世界上最昂貴的資料庫,一般金融系統使用居多。FastDFS
:FastDFS是一個開源的輕量級分散式文件系統,它對文件進行管理,功能包括:文件存儲、文件同步、文件訪問(文件上傳、文件下載)等,解決了大容量存儲和負載均衡的問題。特別適合以文件為載體的線上服務,如相冊網站、視頻網站等等。HDFS
:Hadoop 生態組件,可以支持千萬級的大型分散式文件系統。XX-JOB
:輕量級分散式任務調度平臺,其核心設計目標是開發迅速、學習簡單、輕量級、易擴展。現已開放源代碼並接入多家公司線上產品線,開箱即用。TX-LCN
:分散式事務解決防範,LCN 並不生產事務,LCN 只是本地事務的搬用工(事務的協調工)。LCN 是一個高性能的分散式事務框架,相容 Dubbo、Spring Cloud,支持 RPC 框架拓展,支持各種 ORM 框架、NoSQL、負載均衡、事務補償。Zipkin
:Twitter 公司開發貢獻的一款開源的分散式實時數據追蹤系統(Distributed Tracking System),基於 Google Dapper 的論文設計而來,其主要功能是聚集各個異構系統的實時監控數據。Skywalking
:Apache Skywalking 是一個開源的,用於收集、分析,聚合,可視化來自於不同服務和本地基礎服務的數據的可觀察的平臺。特別為分散式系統而設計的數據觀察和監控系統。Apollo
:攜程框架部門研發的分散式配置中心,能夠集中化管理應用不同環境、不同集群的配置,配置修改後能夠實時推送到應用端,並且具備規範的許可權、流程治理等特性,適用於微服務配置管理場景。ConfigKeeper
:隨行付架構部基於 Spring Cloud 研發的分散式配置中心。與 Spring Boot、Spring Cloud 應用無縫相容。JWT
:JSON Web Token(JWT)是一個非常輕巧的規範。這個規範允許我們使用 JWT 在用戶和伺服器之間傳遞安全可靠的信息。Nginx
:Nginx 是一款輕量級的 Web 伺服器/反向代理伺服器及電子郵件(IMAP/POP3)代理伺服器,其特點是占有記憶體少,併發能力強,中國大陸使用 Nginx 網站用戶有:百度、淘寶、騰訊、京東、新浪、網易等。Git
:開源的分散式版本控制系統,可以有效、高速地處理從很小到非常大的項目版本管理。Docker
:Docker 是一個開源的應用容器引擎,讓開發者可以打包他們的應用以及依賴包到一個可移植的鏡像中,然後發佈到任何流行的 Linux 或 Windows 機器上,也可以實現虛擬化。容器是完全使用沙箱機制,相互之間不會有任何介面。Kubernetes
:Kubernetes,簡稱 k8s,是用 8 代替 8 個字元“ubernete”而成的縮寫。Kubernetes 脫胎於 Google 的 Borg 系統,是一個開源的功能強大的容器編排系統,用於管理雲平臺中多個主機上的容器化的應用,實現了容器集群的自動化部署、擴容以及運維的開源平臺。Kubernetes 的目標是讓部署容器化的應用簡單並且高效。(推薦微服務架構詳細深入學習視頻教程:spring微服務架構視頻教程)