一、精灵商场项目架构设计
1.1 电商行业特点
1.2 传统架构项目设计
缺点:采用传统的架构设计时,将所有的模块都写在一起,如果当模块出现问题时,将导致整个项目乃至tomcat服务器都不能正常执行
1.3 分布式架构
1.3.1 分布式概念
特点:对外统一,对内独立
根据特定的规则将项目进行拆分,一部分出现问题不会影响整个服务器运行,分布式实现了系统间架构之间的松耦合
1.3.1.1 项目垂直拆分
按照业务的功能(模块)将项目进行拆分
1.3.1.2 项目水平拆分
在垂直拆分的基础之上,按照代码调用的"层级"进行拆分
1.3.2 高并发
概念:单位时间内,有大量的用户访问服务器会造成高并发.
影响:官网不能访问,用户访问受限等.
常识:tomcat服务器 220个/秒 150个/秒
1.3.3 集群
概念:由多台(tomcat)服务器组成共同为用户提供服务的配置称之为集群
1.3.4 高可用
当服务器出现了问题,可以实现自动化的故障迁移;一般搭建集群时,都需要实现高可用
1.3.5 海量数据的处理
项目每天都会产生大量的数据,需要大数据技术
1.4 分布式系统优化
1.4.1 jar包如何维护
利用父级项目管理jar包.子级项目只需要继承即可
1.4.2 工具ApI如何管理
采用工具类项目的形式进行管理,项目需要依赖工具类
二、精灵项目创建
2.1 创建父级工程
通过
spring Initializr
直接创建父工程
项目名:
jl
Springboot版本为2.1.9
项目结构
父工程的pom.xml配置
注意 : 因为父工程没有启动类,所以父级项目中 不要添加插件,否则不法打包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.9.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.jl</groupId>
<artifactId>jl</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<name>jl</name>
<description>jlmall</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!--springBoot动态的引入springMVC全部的配置 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter