当前位置:网站首页>一. 基础概念
一. 基础概念
2022-07-07 18:09:00 【orange_?】
单纯的做一个学习笔记,哔哩哔哩上面有视频。
1. 微服务
微服务架构风格,就是把一个单独的应用程序 开发成一套 小服务,每一个小服务都是一个独立的进程。并使用轻量级的通信保持服务之间的沟通,通常是HTTP。这些服务围绕着业务能力来构建,并通过完全的自动化部署机制来独立部署。这些服务可以使用不同的语言编写,以及不同数据存储技术,并保持最低度的集中式管理。
简而言之:拒绝大型单体应用,基于业务边界进行服务微化拆分,各个服务独立运行部署。
2. 集群 & 分布式 & 节点
集群是物理形态,分布式是个工作方式。
只要是一堆机器,就可以叫集群,他们是不是一起协作着工作,这个谁也不知道。
《分布式系统原理与规范》定义:
“ 分布式系统是诺干独立于计算机的集合,这些计算机对于用户来说就像单个相关系统 ”
分布式系统是建立在网络之上的软件系统。
(1) 分布式是指将不同的业务分布在不同的地方
(2) 集群指的是将几台服务器集中在一起,实现同一业务
(3) 分布式中的每一个节点,都可以叫做集群。而集群并不一定就是分布式
3. 远程调用
在分布式系统中,各个服务可能处于不同主机,但是服务之间不可避免的需要互相调用,我们称为远程调用。
SpringCloud 中使用 HTTP + JSON 的方式完成远程调用。
4. 负载均衡
分布式系统中,A服务需要调用B服务,B服务在多台机器中都存在,A调用任意一个服务器均可完成功能。
为了使每一个服务器都不要太忙或者太闲,我们可以负载均衡的调用每一个服务器,提升网站的性能。
常见的负载均衡算法:
轮询:为第一个请求选择健康池中的第一个后端服务器,然后按顺序往后一次选择,直到最后一个,然后循环。
最小连接:优先选择连接数量最少,也就是压力最小的后端服务器,在会话
散列:根据请求源 IP 的散列(hash)来选择要转发的服务器。这种方式可以一定程度上保证特定用户能连接到相同的服务器。如果你的应用需要处理状态而要求用户能连接到和之前相同的服务器,可以考虑这种方式。
5. 服务注册/发现 & 注册中心
A服务调用B服务,A服务不知道B服务当前在哪几台服务器有,哪些正常的,哪些服务已经下线。解决这个问题可以引入注册中心。
6. 配置中心
每一个服务最终都有大量的配置,并且每个服务都可能部署在多台机器上。我们经常需要变更配置,我们可以让每个服务在配置中心获取自己的配置。
7. 服务熔断 & 服务降级
8. API网关
在微服务架构中,API Gateway 作为整体架构的重要组件,它抽象了微服务中需要的公共功能,同时提供了客户端负载均衡,服务自动熔断,灰度发布,统一认证,限流流控,日志统计等丰富的功能,帮助我们解决很多API管理的难题。
谷丽架构图
边栏推荐
猜你喜欢
使用高斯Redis实现二级索引
Classification automatique des cellules de modules photovoltaïques par défaut dans les images de lecture électronique - notes de lecture de thèse
About cv2 dnn. Readnetfromonnx (path) reports error during processing node with 3 inputs and 1 outputs [exclusive release]
九章云极DataCanvas公司获评36氪「最受投资人关注的硬核科技企业」
Simulate the implementation of string class
【哲思与实战】程序设计之道
Implement secondary index with Gaussian redis
CSDN语法说明
Ways to improve the utilization of openeuler resources 01: Introduction
干货分享|DevExpress v22.1原版帮助文档下载集合
随机推荐
Vulnhub tre1
torch.nn.functional.pad(input, pad, mode=‘constant‘, value=None)记录
毕业季|遗憾而又幸运的毕业季
Creation of kubernetes mysql8
Machine learning notes - explore object detection datasets using streamlit
Force buckle 88 Merge two ordered arrays
Compiler optimization (4): inductive variables
Version selection of boot and cloud
Boot 和 Cloud 的版本选型
R language ggplot2 visualization: use the ggviolin function of ggpubr package to visualize the violin diagram, set the palette parameter to customize the filling color of violin diagrams at different
Semantic SLAM源码解析
【mysql篇-基础篇】事务
Kubernetes——kubectl命令行工具用法详解
vulnhub之school 1
Graduation season | regretful and lucky graduation season
Openeuler prize catching activities, to participate in?
R language dplyr package mutate_ At function and min_ The rank function calculates the sorting sequence number value and ranking value of the specified data column in the dataframe, and assigns the ra
R language dplyr package select function, group_ The by function, filter function and do function obtain the third largest value of a specific numerical data column in a specified level in a specified
R language ggplot2 visualization: use the ggstripchart function of ggpubr package to visualize the dot strip plot, set the position parameter, and configure the separation degree of different grouped
Simulate the implementation of string class