当前位置:网站首页>一. 基础概念
一. 基础概念
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管理的难题。
谷丽架构图

边栏推荐
- SQL common optimization
- Force buckle 674 Longest continuous increasing sequence
- Kubernetes -- detailed usage of kubectl command line tool
- Navicat连接2002 - Can‘t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock‘解决
- gorilla官方:golang开websocket client的示例代码
- Version selection of boot and cloud
- Compiler optimization (4): inductive variables
- 九章云极DataCanvas公司摘获「第五届数字金融创新大赛」最高荣誉!
- 如何在软件研发阶段落地安全实践
- Yolov6:yolov6+win10--- train your own dataset
猜你喜欢

Automatic classification of defective photovoltaic module cells in electroluminescence images-论文阅读笔记

School 1 of vulnhub

Open source heavy ware! Chapter 9 the open source project of ylarn causal learning of Yunji datacanvas company will be released soon!

Ways to improve the utilization of openeuler resources 01: Introduction

php 获取图片信息的方法

剑指 Offer II 013. 二维子矩阵的和

LeetCode_7_5

The boundary of Bi: what is bi not suitable for? Master data, Martech? How to expand?

Welcome to the markdown editor

vulnhub之tre1
随机推荐
LeetCode_7_5
力扣 643. 子数组最大平均数 I
Opencv learning notes high dynamic range (HDR) imaging
Open source heavy ware! Chapter 9 the open source project of ylarn causal learning of Yunji datacanvas company will be released soon!
Browse the purpose of point setting
【mysql篇-基础篇】事务
数据孤岛是企业数字化转型遇到的第一道险关
RESTAPI 版本控制策略【eolink 翻译】
Machine learning notes - explore object detection datasets using streamlit
Welcome to the markdown editor
[auto.js] automatic script
BI的边界:BI不适合做什么?主数据、MarTech?该如何扩展?
Traversal of Oracle stored procedures
【剑指offer】剑指 Offer II 012. 左右两边子数组的和相等
The boundary of Bi: what is bi not suitable for? Master data, Martech? How to expand?
Nunjuks template engine
ASP. Net gymnasium integrated member management system source code, free sharing
torch. nn. functional. Pad (input, pad, mode= 'constant', value=none) record
模拟实现string类
Force buckle 1790 Can two strings be equal by performing string exchange only once