企业网站的宣传功能体现在()./搜索广告和信息流广告区别
1. 介绍
本博客探讨的内容如下所示
- 什么是微服务?
- 什么是springcloud?
- 微服务和springcloud有什么关系?
首先,没有在接触springcloud之前,我写的项目都是单体结构, 但随着网站的用户量越来越大,需求也会越来越多,流量也会越来越大。单体架构的弊端也就随之浮现了:
- 后端服务器的压力越来越大,负载越来越高,甚至出现无法访问的情况。
- 业务场景逐渐复杂,为了满足用户的需求,单体应用也会越来越大,各个业务代码之间的耦合度也会越来越高,并且出现任何一个问题,都需要对整个项目重新编译和发布。
- 一个微小的问题,可能会导致整个应用挂掉。
以上这三种问题,我打算通过一个例子进行讲解:
比如:现有一个超市,因为服务好价格便宜,而火遍全网,就会用户量越来越大,需求也就会越来越多,上面的问题就会随之出现:
- 顾客多了,但服务员的数量不变,所以服务员就会忙不过来,甚至有些顾客压根就找不到服务员在哪里。
- 需求多了,我们就需要对超市进行改进,比如说本来超市只是卖日用品。有些人给出建议,可不可以卖把菜也卖了,我就不需要去别的地方了,所以我们为了满足用户的需求,我们就需要进行的开发,耦合度就是:比如添加一个卖菜市场,此时菜货源就需要问服务员菜放哪里,等问题就需要各个业务的交互。
- 名气出来了,关注的人就越来越多,突然有一次有人在网上发文,本家超市菜品质量有问题,不新鲜,这时候就会在网上发酵,可能会导致这个超市的销量大幅度下降,因为大家都是绑在一根绳上的蚂蚱,然后部分出现问题都会影响整体。
2. 解决方案
- 横向:添加服务器(集群)
- 纵向:把一整块业务划分成不同模块(分布式)
应用:最开始机器只有一千个用户,后来增加到了一百万用户
- 横向:扩容机器。扩展到100台机器,每台承担1000用户。
- 纵向:按照功能进行划分,分别部署到不同机器中。
上面简单介绍了:什么是分布式什么事集群,下面介绍概念:
2.1 集群和分布式
- 集群(cluster)是将一个系统完整的部署到多个服务器上,每个服务器都能提供系统的所有服务,多个服务器通过负载均衡调度完成任务.每个服务器称为集群的节点(node)
- 分布式是将一个系统拆分为多个子系统,多个子系统部署在多个服务器上,多个服务器上的子系统协同合作完成一个特定任务.
举例
餐馆
- 只有一个厨师,这个厨师负责做饭相关的所有工作
- 随着餐馆的生意的好转,一个厨师忙不过来
横向: 招聘一个厨师,这两个厨师都可以独立做饭
纵向: 厨师的工作分为: 洗菜,切菜, 配菜,炒菜 - 招聘一个配菜师,负责洗菜,切菜,配菜
- 生意更加好了
再招聘多个配菜师,多个厨师
2.2 集群和分布式区别和联系
- 从概念上看
集群是多个计算机做同样的事,分布式是多个计算机做不同的事 - 从功能上看
集群的每一个节点功能是相同的,并且可以替代的,分布式也是多个节点组成的系统,但是每个节点完成的业务是不同的,一个节点出现问题,这个业务就不可访问了. - 从关系上看
分布式和集群在实践中,很多时候是互相配合使用的
比如分布式的某一个节点,可能由一个集群来代替,分布式架构人多是建立在集群上的,所以实际的分布式架构设计中并不会把分布式和集群单独区分,而是统称:分布式架构.
2.3 微服务
如果你第一次接触微服务,你肯定会想所谓微服务就是微小的服务呗 !
还不瞒你说,你真猜对了,正是微小的服务,通常情况下,我们认为一个微服务只做一件事。
微服务是一种分布式架构方案,只不过是更加细微的拆分,微服务一般提供的就是个位数的接口。
2.4 微服务和分布式的区别和联系
- 分布式: 服务拆分,拆了就行.
- 微服务: 指非常微小的服务,更细粒度的垂直拆分,通常指不能再拆的服务
举例:
岗位划分: 前端,后端, 运维,数据库管理员等等
分布式: 划分了就可以了
微服务: 不仅仅划分,还拆分的很细,比如后端开发,分为: 系统开发,数据开发,策略开发等等...
- 分布式架构侧重于服务的分散(压力分散),微服务侧重于能力分散(更加细微的拆分)
- 微服务是分布式服务的子集
2.5 扩展:架构的发展介绍
架构分为:单体架构 -> 垂直架构 -> 分布式 -> 微服务架构
- 具体选用什么样的架构,取决于你的业务,有时候需要考虑成本,就比如你在写一个项目本身就少的功能,你还有必要拆分出这么多的微服务接口吗 ?
- 如果业务增多可以进行拆分成更高的架构
- 也没必要都又单体进行修改,如果预值到业务比较大,可以选择更大的架构
总之架构没有什么好与坏,都是为了义务来衡量好与坏的。局部的好与坏。
下面是微服务架构的例子
2.6 微服务的优势和挑战(问题)
优势
- 易开发和维护:每个微服务负责的业务比较清晰,体量小,开发和维护成本降低。
- 容错性高:一个服务发生故障,可以使故障隔离在单个服务中,不影响整体服务的故障。
- 扩展性好:每个服务都是独立运行的,我们可以根据项目实际情况进行扩展,按需伸缩。
- 技术选型灵活,每个微服务都是由单独的团队来运维,可以根据业务特点和团队特点选择适合的技术栈。
简单概括一下上述吧
- 清晰(见名知意),体积小,开发和维护就比较简单。
- 容错性好,一个服务挂了,不太影响整体的服务故障。
- 扩展性好,每个都是独立运行的,可以在每个模块都自定义需求。
比如说学校系统,保洁和老师上班的时间是不同的,我们可以在不同的服务设置自定义的考勤规则。
也可以按照不同的需求进行,选择扩容,比如商品模板访问量比较大,但订单管理比较少,可以让商品管理部署五台机器,订单管理部署两台机器,可以按需进行伸缩。 - 技术选型比较灵活
比如一个微服务比较偏业务可以使用java,有些偏算法就可以使用python。
挑战
虽然微服务具备很多的优势,但由于服务数的增加,服务治理也是我们面临的巨大挑战。人多了,管理就比较困难了,各部分工作人员怎么进行沟通呢?
- 服务依赖:随着服务的数量增多,服务之间的关系也会变得更加复杂,一个服务的更改需要考虑对其他服务的影响。
- 运维成本:一个业务流程会涉及多个微服务共同完成,有更多的服务需要编译、部署、运行,甚至可能是不同的编程语言、不同的运行环境,当然也需要集群来处理故障转移等,这对于运维人员而言挑战是巨大的。
- 开发和测试:一个业务流程可能涉及多个微服务共同完成,服务调用引入网络延迟、不可靠的网络,如何进行容错处理等问题,这对开发和测试而言难度也会提升。
- 服务监控:在一个单体结构中,很容易实现服务的监控,因为所有功能都在一个服务中。微服务架构下,不仅需要对整个链路进行监控,还需要对每一个服务实现监控。
- 负载均衡:微服务架构中的服务实例数量可能非常庞大,因此需要有效的服务发现和负载均衡机制来管理请求流量和保证高可用性。
什么是负载均衡?
集群部署的时候,到底哪个人来做呢,这就需要负载均衡。
现在你应该会有这样的疑惑?springcloud呢?那么我将介绍springcloud。
2.7 SpringCloud概念
SpringCloud就是为了解决这些自己开发微服务出现的问题。解决方案:使用springcloud提供的工具解决。
Spring Cloud 是一站式的分布式微服务架构的解决方案,集成了多种技术,包括:
- Distributed/versioned configuration:分布式版本配置
分布式管理配置:每个版本所有配置的信息都不同。- Service registration and discovery:服务注册和发现
服务注册和发现比如服务挂掉了和新增服务了,都会被记录和通知。- Routing:路由
请求发到哪个服务- Service-to-service calls:服务间调用
服务之间的联系- Load balancing:负载均衡
机器有100个,如何根据流量分配这100个机器均匀不让有些非常忙有些非常闲。- Circuit Breakers:断路器
断路器是一种用于处理分布式系统中服务调用失败的机制,断路器的工作原理类似于电路中的断路器,当检测到服务调用失败率达到一定阈值时,断路器会打开(即触发熔断),停止向该服务发起请求,而是直接返回一个预先定义的错误响应(通常是快速失败),从而避免进一步的资源消耗和降低系统的负载。- Distributed messaging:分布式消息
Spring Cloud 提供了这些功能来帮助开发人员快速构建和部署微服务架构,简化了微服务之间的通信和协调,提高了系统的弹性和可靠性。通过Spring Cloud,开发人员可以更加专注于业务逻辑的实现,而不必过多关注底层的分布式系统架构实现细节。
Spring Cloud 是针对微服务架构中遇到的各种问题,各大公司在寻找解决方案时发现了一些好的模块和技术,而 Spring Cloud 就是基于 Spring Boot 风格,整合了这些优秀的模块和技术,进一步封装了复杂的配置和功能,为开发人员提供了简单而强大的工具,帮助他们更轻松地构建和部署微服务系统。
3. 总结
这篇博客详细介绍了微服务架构、SpringCloud以及它们的关系,以及在实际应用中的解决方案和优势挑战。文章通过生动的比喻和实例,清晰地阐述了单体架构的局限性以及引入微服务架构的必要性。此外,还介绍了集群和分布式的概念以及微服务与分布式的区别和联系。最后,对SpringCloud进行了详细介绍,说明其作为一站式的分布式微服务架构的解决方案所涵盖的技术和功能。文章内容全面且通俗易懂,对于想要了解微服务架构和SpringCloud的读者来说是一份很好的参考资料。
此外祝大家六一儿童节快乐玩的开心!
相关文章:

认识微服务,认识Spring Cloud
1. 介绍 本博客探讨的内容如下所示 什么是微服务?什么是springcloud?微服务和springcloud有什么关系? 首先,没有在接触springcloud之前,我写的项目都是单体结构, 但随着网站的用户量越来越大,…...

电脑设置密码怎么设置?让你的电脑更安全!
在如今信息化的社会中,保护个人电脑的安全至关重要。设置密码是最基本的电脑安全措施之一,它可以有效防止未经授权的访问和保护个人隐私,可是电脑设置密码怎么设置?本文将介绍三种设置电脑密码的方法,帮助您加强电脑的…...

搜维尔科技:SenseGlove Nova2使用主动接触反馈来模拟手掌的感觉,结合力反馈和振动触觉反馈,使其成为市场上第一款具有手掌反馈的无线触觉手套
SenseGlove Nova2使用主动接触反馈来模拟手掌的感觉,结合力反馈和振动触觉反馈,使其成为市场上第一款具有手掌反馈的无线触觉手套。 搜维尔科技:SenseGlove Nova2使用主动接触反馈来模拟手掌的感觉,结合力反馈和振动触觉反馈&…...

基于Python的实验室管理系统的设计与实现(论文+源码)_kaic
摘 要 随着实验室设备越来越多,实验室及其设备管理工作变得越来越繁重,还存在些管理模式仍旧处于手工管理模式和一些抢占实验室的不文明现象,传统的手工模式已经满足不了日益增长的管理需求,而本系统摒弃传统模式,开启…...

Windows系统WDS+MDT网络启动自动化安装
Windows系统WDS+MDT网络启动自动化安装 适用于在Windows系统上WDS+MDT网络启动自动化安装 1. 安装准备 1.下载windows server 2019、windows 10 pro的ISO文件,并安装好windows server 2019 2.下载windows 10 2004版ADK及镜像包 1.1 安装平台 Windows 111.2. 软件信息 软件…...

Apple开发者证书创建完整过程
1.创建CSR文件: 打开钥匙串访问程序 选择从证书颁发机构请求 创建证书 保存CSR文件到桌面 成功如下: 开始创建证书: 选择...

for深入学习
目录 练习: 例1: 求解0-100中整除3的数有哪些 例2: 求0-100中含数字9个个数 作业: 练习: 例1: 求解0-100中整除3的数有哪些 代码: #include<stdio.h> int main() {printf("整…...

引用(C++)和内联函数
前言:本文主要讲解C语法中引用如何使用和使用时的一些技巧 基本语法 引用就是取别名 #include <iostream> using namespace std; int main() {int a 10;int& b a;//给a取别名为bcout << a << endl;cout << b << endl;return 0…...

【stm32/CubeMX、HAL库】swjtu嵌入式实验七 ADC 实验
相关电路与IO引脚 注意:串口打印重定向后使用printf打印需要在keil里勾选 Use MicroLIB ,否则会卡住。 参看:https://zhuanlan.zhihu.com/p/565613666 串口重定向: /* USER CODE BEGIN Includes */#include <stdio.h>//…...

springboot 解耦、隔离、异步的原则以及实战
在Spring Boot中实现解耦、隔离和异步的原则,能够提升应用程序的可维护性、可扩展性和性能。下面我会先介绍这三个原则的基本概念和意义,然后通过实战示例展示如何在Spring Boot应用中应用这些原则。 解耦 解耦是减少或消除应用程序组件之间依赖关系的过程,以提高模块的独…...

设计模式详解(八):外观模式——Facade
目录导航 什么是外观模式现实生活类比实战示例门面模式的好处门面模式源码举例 什么是外观模式 外观模式的英文名是Facade,意思是the front of a building,即建筑物的正面(门面),我个人更喜欢翻译成门面模式。门面模式…...

R语言绘图 | 双Y轴截断图
教程原文:双Y轴截断图绘制教程 本期教程 本期教程,我们提供的原文的译文,若有需求请回复关键词:20240529 小杜的生信笔记,自2021年11月开始做的知识分享,主要内容是R语言绘图教程、转录组上游分析、转录组…...

使用PNP管控制MCU是否需要复位
这两台用到一款芯片带电池,希望电池还有电芯片在工作的时候插入电源不要给芯片复位,当电池没电,芯片不在工作的时候,插入电源给芯片复位所以使用一个PNP三极管,通过芯片IO控制是否打开复位,当芯片正常工作的…...

二重,三重积分和曲面,曲线积分的关系和区别
这是我在学习完曲面曲线积分概念后容易和二重三重积分混淆而大概总结和区分了一下,如果有错误请大佬指出,多谢!!!...

处理STM32 DMA方式下的HAL_UART_ERROR_ORE错误
1. 检查并调整DMA和UART配置 确保初始化顺序:需要确保USART的CR寄存器UE位开关留到最后打开,即完成USART和DMA的所有配置初始化后再使能USART。这样可以避免初始化顺序不当导致的通信问题。配置合适的DMA缓冲区:确保DMA缓冲区足够大…...

初学者如何对大模型进行微调?
粗略地说,大模型训练有四个主要阶段:预训练、有监督微调、奖励建模、强化学习。 预训练消耗的时间占据了整个训练pipeline的99%,其他三个阶段是微调阶段,更多地遵循少量 GPU 和数小时或数天的路线。预训练对于算力和数据的要求非…...

【Qt知识】disconnect
在Qt框架中,disconnect函数用于断开信号与槽之间的连接。当不再需要某个信号触发特定槽函数时,或者为了防止内存泄漏和重复执行问题,你可以使用disconnect来取消这种关联。disconnect函数的基本用法可以根据不同的需求采用多种形式࿰…...

String,StringBuffer,StringBuilder的区别?
String是不可变的,StringBuffer和StringBuilder是可变的。StringBuffer是线程安全的,StringBuilder是非线程安全的。 String的 是如何实现的 使用拼接字符串,其实只是Java提供的一个语法糖。 其实String的 底层是new 了一个StringBuilde…...

vue基础知识点
一、Vue 1. 简介 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的 JavaScript 框架 它基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型 由个人维护:尤雨溪,华人 官网 Vue.js - 渐进…...

正则表达式三
运算符的优先级 相同优先级的从左到右计算,不同优先级,优先级高得先运算。从高到低为: 转义字符: 圆括号或方括号:(),[] 限定符:指限定前面元素的次数如:*,,?,{n},{n,},{n,m} 字符…...

MYSQL数据库细节详细分析
MYSQL数据库的数据类型(一般只需要用到这些) 整型类型:用于存储整数值,可以选择不同的大小范围来适应特定的整数值。 TINYINTSMALLINTMEDIUMINTINTBIGINT 浮点型类型:用于存储带有小数部分的数值,提供了单精度(FLOA…...

vue 将图片url转base64
<img :src"imgList[0]" width"600" error"handleImageError" alt"0" load"onloadImg" />//当图片加载完成时,将图片url转成base64onloadImg(event) {this.urlTobase64(event.target.src, event.target.alt…...

Unity之XR Interaction Toolkit如何使用XRSocketInteractable组件
前言 在虚拟现实(VR)和增强现实(AR)开发中,交互性是提升用户体验的关键。Unity作为一个领先的游戏开发引擎,提供了多种工具支持VR/AR开发。Unity的OpenXR插件扩展了这一功能,提供了更强大和灵活的交互系统。其中一个非常有用的组件是XRSocketInteractable。本文将详细介…...

flutter3-os:基于flutter3.x+dart3+getx手机版os管理系统
flutter3-os-admin跨平台手机后台OS系统。 原创Flutter3.22Dart3.4Getxfl_chart等技术开发仿ios手机桌面OA管理系统。自研栅格化布局引擎、自定义桌面壁纸、小部件、底部Dock菜单、可拖拽悬浮球等功能。 全新自研栅格化OS菜单布局引擎。 使用技术 编辑器:VScode技术…...

C++ 用数组模拟队列
在C中,使用数组模拟队列通常涉及到两个主要的操作:入队(enqueue)和出队(dequeue)。由于数组是一个固定大小的数据结构,当使用数组模拟队列时,需要手动管理队列的头部和尾部位置。以下…...

每日一题34:数据分组之查找每个员工花费的总时间
一、每日一题 表: Employees ------------------- | Column Name | Type | ------------------- | emp_id | int | | event_day | date | | in_time | int | | out_time | int | ------------------- 在 SQL 中,(emp_id, event_day, in_time) 是…...

语言模型解构——Tokenizer
1. 认识Tokenizer 1.1 为什么要有tokenizer? 计算机是无法理解人类语言的,它只会进行0和1的二进制计算。但是呢,大语言模型就是通过二进制计算,让你感觉计算机理解了人类语言。 举个例子:单1,双2&#x…...

前端经验:导出表格为excel并设置样式
应用场景 将网页上的table标签内容导出为excel,并且导出的excel携带样式,比如字色、背景色、对齐等等 实施步骤 必备引入包 npm install xlsx-js-style步骤1:准备好table table可以是已经存在与页面中的,也可以动态创建。 行…...

UFS协议—新手快速入门(二)【5-6】
目录 五、UFS协议栈 六、UFS技术演进与详解 1、UFS应用层 设备管理器 任务管理器 2、UFS传输层 3、UFS互联层 UFS协议—新手快速入门(一)【1-4】 五、UFS协议栈 UFS(Universal Flash Storage)协议是针对固态存储设备&…...

手机建站介绍
随着科技的不断进步和移动互联网的普及,手机应用已经成为人们生活中最不可或缺的一部分。而手机建站作为一种新兴技术,在这一领域也有着广泛的应用。本文将为大家介绍手机建站的概念、优势和应用。 什么是手机建站? 手机建站是指将传统的网络…...