美文网首页SpringCloud分布式&高可用分布式架构
SpringCloud上手实战 一、初始搭建SpringClo

SpringCloud上手实战 一、初始搭建SpringClo

作者: 廖小明的赖胖子 | 来源:发表于2020-01-15 19:51 被阅读0次

    慢慢来比较快,虚心学技术

    原文链接(欢迎造访,多多支持):https://www.yuque.com/keep_zero/spring_cloud/fax77c

    SpringBoot和SpringCloud?

    SpringBoot

    Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。

    简单来说,SpringBoot是一个基于Spring框架之上的开源框架,是Spring的一套快速搭建脚手架,它提供了一种更加简单快捷的方式来配置和运行web应用程序,从而不需要去设置整个Spring配置。其基本特征是:“约定优于配置”(提供基于常见开发中常见配置的默认处理)和“开箱即用”(Out Of The Box)

    其主要目标如下:

    • 为所有Spring开发提供一个从根本上更快和更广泛使用的入门经验
    • 开箱即用,但你可以通过不采用默认设置来摆脱这种方式
    • 提供一系列大型项目常用的非功能性特征(如内嵌服务器、安全等)
    • 绝不需要代码生成和XML配置

    SpringCloud

    Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

    简单来说,SpringCloud基于SpringBoot的一套微服务架构体系解决方案,用于整合微服务应用

    包括两个组成:

    1、对现有的成熟框架SpringBoot的封装和抽象,相当于SpringBoot项目的集合

    2、对一部分分布式系统的基础设施的实现,如配置中心,服务治理中心,监控中心等

    SpringBoot & SpringCloud

    • SpringBoot是基于Spring的一套快速搭建脚手架,可以用于快速开发单个微服务应用
    • SpringCloud是基于SpringBoot的一套微服务架构体系**解决方案,用于整合微服务应用
    • SpringBoot专注于单个微服务应用,而SpringCloud专注于全局的微服务治理
    • SpringBoot可以离开SpringCloud独立开发应用,SpringCloud离不开SpringBoot

    搭建SpringCloud的初始环境

    SpringCloud的版本:

    大多数Spring项目都是以“主版本号.次版本号.增量版本号.里程碑版本号”的形式命名版本号

    例如Spring Framework稳定版本4.3.5.RELEASE、里程碑版本5.0.0.M4等。其中,主版本号表示项目的重大重构;次版本号表示新特性的添加和变化;增量版本号一般表示bug修复;里程碑版本号表示某版本号的里程碑。

    本项目选用核心依赖版本说明:

    • Spring Cloud Greenwich.SR2
    • Spring Boot 2.1.3.RELEASE
    • Spring Platform Cairo-SR7

    创建空Maven项目(父项目)

    SpringBoot支持JDK1.6以上版本

    在pom.xml中引入基本依赖

    原始pom.xml文件内容如下:

    <pre class="cm-s-default" style="color: rgb(89, 89, 89); margin: 0px; padding: 0px; background: none 0% 0% / auto repeat scroll padding-box border-box rgba(0, 0, 0, 0);"><?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.springcloud</groupId> <artifactId>com.springcloud.demo</artifactId> <packaging>pom</packaging> <version>1.0-SNAPSHOT</version> </project></pre>
    

    1、继承Spring Boot Starter,声明自身是SpringBoot项目

    spring-boot-starter-parent 是一个特殊的starter,它用来提供相关的Maven默认依赖。使用它之后,常用的包依赖可以省去version标签

    <pre class="cm-s-default" style="color: rgb(89, 89, 89); margin: 0px; padding: 0px; background: none 0% 0% / auto repeat scroll padding-box border-box rgba(0, 0, 0, 0);"><!-- 引入spring boot starter的依赖 --> <parent>  <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.3.RELEASE</version> </parent></pre>
    

    2、统一版本管理(可有可无)

    <pre class="cm-s-default" style="color: rgb(89, 89, 89); margin: 0px; padding: 0px; background: none 0% 0% / auto repeat scroll padding-box border-box rgba(0, 0, 0, 0);"> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <java.version>1.8</java.version> <project.version>1.0-SNAPSHOT</project.version>   <spring-boot.version>2.1.3.RELEASE</spring-boot.version> <spring-cloud.version>Greenwich.RELEASE</spring-cloud.version> <spring-platform.version>Cairo-SR7</spring-platform.version>   <druid.version>1.1.10</druid.version> <mysql.version>5.1.45</mysql.version> <hutool.version>4.4.5</hutool.version> <mybatis-plus.version>3.1.0</mybatis-plus.version> </properties>   <dependencyManagement>  <dependencies> <!--统一管理spring boot相关依赖版本--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--统一管理spring cloud相关依赖版本--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--spring版本管理工具--> <!--使用这一依赖可以实现spring相关第三方依赖自动适配版本号而不需要填写version--> <dependency> <groupId>io.spring.platform</groupId> <artifactId>platform-bom</artifactId> <version>${spring-platform.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement></pre>
    

    3、安装Maven插件spring-boot-maven-plugin (作为父工程实际上可以没有,此处引入亦可)

    该插件可以以Maven的方式为应用提供Spring Boot的支持,即****能够将Spring Boot应用打包为可执行的jar或war文件,然后以通常的方式运行Spring Boot应用

    <pre class="cm-s-default" style="color: rgb(89, 89, 89); margin: 0px; padding: 0px; background: none 0% 0% / auto repeat scroll padding-box border-box rgba(0, 0, 0, 0);"><build>  <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build></pre>
    

    4、强制使用阿里云仓库(覆盖maven的setting配置,可有可无)

    <pre class="cm-s-default" style="color: rgb(89, 89, 89); margin: 0px; padding: 0px; background: none 0% 0% / auto repeat scroll padding-box border-box rgba(0, 0, 0, 0);"><repositories>  <repository> <id>aliyun</id> <name>aliyun</name> <url>https://maven.aliyun.com/repository/public</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories></pre>
    

    完整pom.xml文件:

    <pre class="cm-s-default" style="color: rgb(89, 89, 89); margin: 0px; padding: 0px; background: none 0% 0% / auto repeat scroll padding-box border-box rgba(0, 0, 0, 0);"><?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.springcloud</groupId> <artifactId>com.springcloud.demo</artifactId> <packaging>pom</packaging> <version>1.0-SNAPSHOT</version> <!-- 引入spring boot starter的依赖 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.3.RELEASE</version> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <java.version>1.8</java.version> <project.version>1.0-SNAPSHOT</project.version>  <spring-boot.version>2.1.3.RELEASE</spring-boot.version> <spring-cloud.version>Greenwich.RELEASE</spring-cloud.version> <spring-platform.version>Cairo-SR7</spring-platform.version>  <druid.version>1.1.10</druid.version> <mysql.version>5.1.45</mysql.version> <hutool.version>4.4.5</hutool.version> <mybatis-plus.version>3.1.0</mybatis-plus.version> </properties> <dependencies> <!-- 引入Lombok --> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency>  <!--引入测试依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-test</artifactId> <scope>test</scope> </dependency>  <!--引入测试依赖--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <scope>test</scope> </dependency> </dependencies> <dependencyManagement> <dependencies> <!--统一管理spring boot相关依赖版本--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--统一管理spring cloud相关依赖版本--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--spring版本管理工具--> <!--使用这一依赖可以实现spring相关第三方依赖自动适配版本号而不需要填写version--> <dependency> <groupId>io.spring.platform</groupId> <artifactId>platform-bom</artifactId> <version>${spring-platform.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <!-- 添加spring-boot的maven插件,不能少,打jar包时得用 --> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> <!--强制使用阿里云仓库--> <repositories> <repository> <id>aliyun</id> <name>aliyun</name> <url>https://maven.aliyun.com/repository/public</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories> </project></pre>
    

    总结

    1、SpringBoot是基于Spring的一套快速搭建脚手架,可以用于快速开发单个微服务应用

    2、SpringCloud是基于SpringBoot的一套微服务架构体系解决方案,用于整合微服务应用

    如有贻误,还请评论指正

    点击关注,持续更新哦

    相关文章

      网友评论

        本文标题:SpringCloud上手实战 一、初始搭建SpringClo

        本文链接:https://www.haomeiwen.com/subject/fkqxzctx.html