欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

一、项目介绍

程序员文章站 2022-03-10 16:59:14
一、项目介绍邑起购商城项目是最新推出的完整大型分布式架构电商平台,技术全面、业务深入,全网无出其右。技术涵盖:微服务架构+分布式+全栈+集群+部署+自动化运维+可视化CICD,对标阿里P6/P7,冲击40-60w。项目由业务集群系统+后台管理系统构成,打通了分布式开发及全栈开发技能,包含前后分离全栈开发、Restful接口、数据校验、网关、注册发现、配置中心、熔断、限流、降级、链路追踪、性能监控、压力测试、系统预警、集群部署、持续集成、持续部署…邑起购 大型分布式电商项目【分布式基础_全栈开发篇】...

一、项目介绍

邑起购商城项目是最新推出的完整大型分布式架构电商平台,技术全面、业务深入,全网无出其右。技术涵盖:微服务架构+分布式+全栈+集群+部署+自动化运维+可视化CICD,对标阿里P6/P7,冲击40-60w。

项目由业务集群系统+后台管理系统构成,打通了分布式开发及全栈开发技能,包含前后分离全栈开发、Restful接口、数据校验、网关、注册发现、配置中心、熔断、限流、降级、链路追踪、性能监控、压力测试、系统预警、集群部署、持续集成、持续部署…

邑起购 大型分布式电商项目

【分布式基础_全栈开发篇】

使用SpringBoot+Vue+element-ui+逆向工程搭建全套后台管理系统,基于Docker环境,通过前后分离方式,以商品系统为例,手把手教大家进行全栈开发。

【分布式高级_微服务架构篇】

开发整个商城系统,掌握微服务的全套方案。使用SpringBoot+SpringCloud并配套SpringCloud Alibaba系列,引入全套微服务治理方案:Nacos注册中心/配置中心、Sentinel流量保护系统、Seata分布式事务&RabbitMQ柔性事务方案、SpringCloud-Gateway网关、Feign远程调用、Sleuth+Zipkin链路追踪系统、Spring Cache缓存、SpringSession跨子域Session同步方案、基于ElasticSearch7全文检索、异步编排与线程池、压力测试调优、Redisson分布式锁、分布式信号量等。

【高可用集群_架构师提升篇】

基于kubernetes集群,整合kubesphere可视化界面,搭建全套系统环境。使用集群化部署,包括Redis Cluster集群,MySQL主从与分库分表(使用ShardingSphere完成)集群,RabbitMQ镜像队列集群,ElasticSearch高可用集群。基于kubesphere整合Jenkins全可视化CICD,全套Pipeline流水线编写,参数化构建+手动确认模式保证。

1、项目背景

邑起购是一个B2C模式的电商平台。

2、项目架构图

一、项目介绍
一、项目介绍

3、项目技术&特色

  • 前后端分离开发,并开发基于Vue的后台管理系统

  • SpringCloud全新的解决方案

  • 应用监控、限流、网关、熔断降级等分布式方案 全方法涉及

  • 透彻讲解分布式事务、分布式锁等分布式系统的难点

  • 分析测试与性能优化

  • 各种集群技术的区别以及使用

  • CI/CD使用

4、项目前置要求

学习项目的前置知识

  • 熟悉SpringBoot以及常见整合方案
  • 了解SpringCloud
  • 熟悉git,maven
  • 熟悉linux,redis,docker基本操作
  • 了解html,css,js,vue
  • 熟练使用idea开发项目

二、邑起购电商项目整体效果展示

三、分布式基础概念

1、微服务

微服务架构风格,就像是把一个单独应用程序开发为一套小服务,每个小服务在自己的进程中,并使用轻量级机制通信,通常是HTTP API。这些服务围绕业务能力来构建,并通过完全自动化部署机制来独立部署。这些服务使用不同的编程语言书写,以及不同数据存储技术,并保持最低限度的集中式管理。

简而言之:拒绝大型单体应用,基于业务边界进行服务微化拆分,各个服务独立运行。

一、项目介绍

2、集群&分布式&节点

集群是个物理形态,分布式是个工作方式。

只要是一堆机器,就可以交集群,他们是不是一起协作干活,这个谁也不知道。

分布式是指将不同的业务分布在不同的地方。

集群指的是将几万台服务器集中在一起,实现同一业务。

例如:京东就是一个分布式系统,众多业务运行在不同的机器,所有业务构成了一个大型的业务集群。每一个小的业务,比如用户系统,访问压力大的时候一台服务器就不够了,我们就应该将用户系统部署到多个服务器中。也就是每个业务系统也可以叫做集群化。

分布式中的每一个节点,都可以做集群,而集群不一定是分布式的。

节点:集群中的一个服务器。

3、远程调用

在分布式系统中,各个服务可能处于不同的主机,但是服务之间不可避免相互调用,我们称为远程调用。

SpringCloud中使用Http+JSON的方式完成远程调用。

一、项目介绍

4、负载均衡

一、项目介绍

分布式系统中,A服务需要调用B服务,B服务在多台机器中都存在,A调用任意一个服务器即可完成功能。

为了使每一个服务器都不要太忙或者太闲,我们可以负载均衡的调用每一个服务器。提升网站的性能。

常见的负载均衡算法:

轮询:为第一个请求选择健康池的第一个后端服务器。然后按顺序往后依次选择,直到最后一个,然后循环。

最小连接:优先选择连接数最少,也就是压力最小的后端服务器。在会话较长的情况下可以考虑采取这种方式。

散列算法:根据请求源IP的散列来选择要转发的服务器。

5、服务注册/发现&注册中心

A服务调用B服务,A服务并不知道B服务当前在那几台服务器有,哪些正常,那些服务已经下线,解决这个问题可以进入注册中心。

一、项目介绍

如果某些服务下线,我们其他人可以实时的感知到其他服务的状态,从而避免调用不可用的服务。

6、配置中心

一、项目介绍

每一个服务最终都有大量的配置,并且每一个服务都可能部署在多台服务器上,我们经常需要变更配置。我们可以让每一个服务在配置中心获取自己的配置。

配置中心来集中管理服务器的配置信息。

7、服务熔断&服务降级

在服务架构中,微服务之间通过网络进行通信,存在相互依赖,当其中一个服务不可用时,有可能会造成雪崩。要防止这样的情况,必须要有错误机制来保护服务。
一、项目介绍

1)、服务熔断

​ 设置服务的超时,当被调用的服务经常失败达到某个阈值,我们可以开启断路保护机制,后来的请求不在去调用这个服务,本地直接返回默认的数据。

2)、服务降级

​ 在运维期间,当系统处于高峰期,系统资源紧张,我们可以让非核心降级运行。降级:某些服务不处理,或者简短处理【抛异常,返回MULL,调用Mock数据,调用FallBack处理逻辑】

8、API网关

在微服务中,API GateWay作为整体架构的最要部件,它抽象了微服务中都需要的公共功能,同时提供了客户端负载均衡,服务自动熔断,灰度发布,统一认证,限流流控,日志统计等丰富的功能,帮助我们解决很多API管理难题。

一、项目介绍

、API网关

在微服务中,API GateWay作为整体架构的最要部件,它抽象了微服务中都需要的公共功能,同时提供了客户端负载均衡,服务自动熔断,灰度发布,统一认证,限流流控,日志统计等丰富的功能,帮助我们解决很多API管理难题。

本文地址:https://blog.csdn.net/aaa_56234/article/details/108842771