SpringCloud入门-前期准备

前言

在写这一系列的文章以前,以为颇有必要阐述一下什么是Spring Cloud。不像Spring(Spring Framework),大致上可以理解为它是一个管理bean的容器。也不想SpringBoot,能够理解为它是增强版的Spring,集成了SSM和其它一些框架,而且大量支持和推荐注解开发。web

可是对于Spring Cloud,它是一个微服务架构的框架,它不是单独的某个项目,是多个项目的集成。也就是说若是想学习Spring Cloud,其实是在学习多个有关微服务的项目。spring

所谓微服务呢,就是把本来一站式解决的业务拆分红具体的某个模块,每一个模块只作一个事情,而后还顺便衍生出了统一管理这些服务的模块,以及服务的保护措施等模块。归结起来就是5个核心,服务发现(注册)、负载均衡、断路器、服务网关和分布式配置。apache

如何创建一个module

在几个星期前,当我想建一个模块的时候,可能会选择采用Spring Initializer 来建立,可是最近以为仍是直接创建一个新模块比较舒服。每一个人的习惯都不同,本身怎么舒服怎么来。架构

下面就演示一下如何利用maven建立一个module负载均衡

image-20210514155036945

修改模块名就能够建立想要的模块,这样的好处是可以集成父模块中导入的依赖,相比于Spring Initializer 会简单多了,由于后者须要手动配置模块的父子关系才能够(或者懂怎么搞的小伙伴也能够留言一手)。框架

前期准备

为了更好的学习,首先创建了一个总的工程,一样是用了maven来创建一个项目,创建完后结构以下所示maven

接下来要作的就是把整个src目录给删掉,由于后续也用不到它;其次就是修改pom文件分布式

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.cutey.none</groupId>            
    <artifactId>springcloud-demo</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>


    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
    
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.3.0.RELEASE</version>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <!--spring boot 2.3.0-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>2.3.0.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!--spring cloud Hoxton.SR11-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Hoxton.SR11</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

</project>

各位小伙伴须要修改的第7和第8行的groupIdartifactId。这样对于必须用的依赖,能够在根模块中,也就是该pom文件声明便可。好比上面的spring-boot-starter-web 在全部的子模块中都有整个依赖。spring-boot

甚至若是足够懒,那你彻底能够把全部的依赖都写在父模块中,这样后续创建子模块的过程当中就能够无论pom文件了。微服务