浅浅入门SpringCloud

举报
QGS 发表于 2023/05/28 20:13:08 2023/05/28
【摘要】 浅浅入门SpringCloud

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

 

Spring Cloud的子项目,大致可分成两类,一类是对现有成熟框架”Spring Boot的封装和抽象,也是数量最多的项目;第二类是开发了一部分分布式系统的基础设施的实现,如Spring Cloud Stream扮演的就是kafka, ActiveMQ这样的角色。对于我们想快速实践微服务的开发者来说,第一类子项目就已经足够使用,如:

 

    Spring Cloud Netflix  是对Netflix开发的一套分布式服务框架的封装,包括服务的发现和注册,负载均衡、断路器、REST客户端、请求路由等。

    Spring Cloud Config  将配置信息中央化保存, 配置Spring Cloud Bus可以实现动态修改配置文件

    Spring Cloud Stream  分布式消息队列,是对Kafka, MQ的封装

    Spring Cloud Security  对Spring Security的封装,并能配合Netflix使用

    Spring Cloud Zookeeper  对Zookeeper的封装,使之能配置其它Spring Cloud的子项目使用

    Spring Cloud Eureka Spring Cloud Netflix 微服务套件中的一部分,它基于Netflix Eureka 做了二次封装,主要负责完成微服务架构中的服务治理功能。

 

Spring Cloud对于中小型互联网公司来说是一种福音,因为这类公司往往没有实力或者没有足够的资金投入去开发自己的分布式系统基础设施,使用Spring Cloud一站式解决方案能在从容应对业务发展的同时大大减少开发成本。同时,随着近几年微服务架构和Docker容器概念的火爆,也会让Spring Cloud在未来越来越化的软件开发风格中立有一席之地,尤其是在五花八门的分布式解决方案中提供了标准化的、全站式的技术方案,意义可能会堪比当年Servlet规范的诞生,有效推进服务端软件系统技术水平的进步。

 

微服务:就是将一个大的应用,拆分成多个小的模块,每个模块都有自己的功能和职责,每个模块可以进行交互,这就是微服务

CI/CD

Jenkins

SpringCloud常用组件表

服务的注册和发现。( eureka,nacos, consul)

服务的负载均衡。( ribbon,dubbo)

服务的相互调用。(openFeign,dubbo)

服务的容错。( hystrix, sentinel)

服务网关。( gatewayzuu1)

服务配置的统一管理。( config- server,nacos,apollo)

服务消息总线。(bus)

服务安全组件。( security, Oauth2.0)

服务监控。( admin) (jvm)

链路追踪。(sleuth+ zipkin)

eureka入门

eureka

 

注册发现中心

Eureka来源于古希腊词汇,意为发现了。在软件领域, EurekaNetf1ix在线影片公司开源的一个服务注册与发现的组件,和其他Netf1iⅹ公司的服务组件(例如负载均衡、熔断器、网关等)一起, Spring cloud社区整合为 Spring Cloud Nett1ix模块。EurekaNetf1×贡献给 Spring cloud的一个框架!Netf1ix Spring cloud贡献了很多框架,后面我们会学习到!

 

Spring cloud Eureka Zookeeper的区别

CAP原则

CAP原则又称CAP定理,指的是在一个分布式系统中,

一致性( Consistency)

可用性( Availabi1ity)

分区容错性( Partition tolerance):由于网络或者不可抵制力会导致机器中的数据短暂不一致(该特性是不可避免的)

CAP原则指的是,这三个要素最多只能同时实现两点,不可能三者兼顾

https://spring.io/projects/spring-cloud-consul

http://nacos.io/zh-cn/

搭建注册中心

Server

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.3.12.RELEASE</version>

        <relativePath/> <!-- lookup parent from repository -->

    </parent>

    <groupId>com.example</groupId>

    <artifactId>eureka-server</artifactId>

    <version>0.0.1-SNAPSHOT</version>

    <name>eureka-server</name>

    <description>eureka-server</description>



    <properties>

        <java.version>1.8</java.version>

        <spring-cloud.version>Hoxton.SR12</spring-cloud.version>

    </properties>



    <dependencies>

        <dependency>

            <groupId>org.springframework.cloud</groupId>

            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>

        </dependency>



        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-test</artifactId>

            <scope>test</scope>

        </dependency>

    </dependencies>



    <dependencyManagement>

        <dependencies>

            <dependency>

                <groupId>org.springframework.cloud</groupId>

                <artifactId>spring-cloud-dependencies</artifactId>

                <version>${spring-cloud.version}</version>

                <type>pom</type>

                <scope>import</scope>

            </dependency>

        </dependencies>

    </dependencyManagement>



    <build>

        <plugins>

            <plugin>

                <groupId>org.springframework.boot</groupId>

                <artifactId>spring-boot-maven-plugin</artifactId>

            </plugin>

        </plugins>

    </build>



</project>

 

 

application.yml

server:

  port: 8761  #eureka默认端口

spring:

  application:

    name: eureka-server #应用名称

 

添加@EnableEurekaServer注解

@SpringBootApplication

@EnableEurekaServer   //开启eureka注册中心功能

public class EurekaServerApplication {



    public static void main(String[] args) {

        SpringApplication.run(EurekaServerApplication.class, args);

    }



}

Client

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.3.12.RELEASE</version>

        <relativePath/> <!-- lookup parent from repository -->

    </parent>

    <groupId>com.example</groupId>

    <artifactId>eureka-client-01</artifactId>

    <version>0.0.1-SNAPSHOT</version>

    <name>eureka-client-01</name>

    <description>eureka-client-01</description>

    <properties>

        <java.version>1.8</java.version>

        <spring-cloud.version>Hoxton.SR12</spring-cloud.version>

    </properties>

    <dependencies>

        <dependency>

            <groupId>org.springframework.cloud</groupId>

            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>

        </dependency>



        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-test</artifactId>

            <scope>test</scope>

        </dependency>

    </dependencies>

    <dependencyManagement>

        <dependencies>

            <dependency>

                <groupId>org.springframework.cloud</groupId>

                <artifactId>spring-cloud-dependencies</artifactId>

                <version>${spring-cloud.version}</version>

                <type>pom</type>

                <scope>import</scope>

            </dependency>

        </dependencies>

    </dependencyManagement>



    <build>

        <plugins>

            <plugin>

                <groupId>org.springframework.boot</groupId>

                <artifactId>spring-boot-maven-plugin</artifactId>

            </plugin>

        </plugins>

    </build>



</project>

 

Application.yml

server:

  port: 8088 #客户端端口无要求

spring:

  application:

    name: eureka-client



  #注册client信息,发送到server

  eureka:

    client:

      service-url:

        defaultZone: http://localhost:8761/eureka

 

@SpringBootApplication

@EnableEurekaClient  //开启eureka客户端功能

public class EurekaClient01Application {

    public static void main(String[] args) {

        SpringApplication.run(EurekaClient01Application.class, args);

    }
}

 

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。