SpringCloud学习之微服务开发篇(三)1.1 - 微服务概述及治理

目录

一、微服务概述

1、初始SpringCloud及微服务

2、什么是微服务

3、什么是Spring Cloud

4、参考文章

二、Eureka-Server服务注册中心

1、Eureka-Server的pom.xml

2、配置application.yml文件

3、编辑启动类

三、Eureka-Client客户端服务提供者

1、pom.xml

2、配置application.yml文件

3、编辑启动类

4、测试说明


一、微服务概述

1、初始SpringCloud及微服务

在传统的软件架构中,我们通常采用的是单体应用来构建一个系统,一个单体应用糅合了各种业务模块。

起初在业务规模不是很大的情况下,对于单体应用的开发维护也相对容易。但随着企业的发展,业务规模与日递增,单体应用变得愈发臃肿。

由于单体应用将各种业务模块聚合在一起,并且部署在一个进程内,所以通常我们对其中一个业务模块的修改也必须将整个应用重新打包上线。

为了解决单体应用变得庞大脯肿之后产生的难以维护的问题,微服务架构便出现在了大家的视线里。

2、什么是微服务

微服务 (Microservices) 是一种软件架构风格,起源于Peter Rodgers博士于 2005 年度云端运算博览会提出的微 Web 服务 (Micro-Web-Service) 。

微服务主旨是将一个原本独立的系统 拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间通过基于HTTP的RESTful API进行通信协作。

SpringCloud学习之微服务开发篇(三)1.1 - 微服务概述及治理_第1张图片

3、什么是Spring Cloud

Spring Cloud是一个基于Spring Boot实现的微服务架构开发工具。

它为微服务架构中涉及的配置管理、服务治理、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等操作提供了一种简单的开发方式。

Spring Cloud的诞生并不是为了解决微服务中的某一个问题,而是提供了一套解决微服务架构实施的综合性解决方案。

4、参考文章

https://mrbird.cc/Spring-Cloud%20and%20MicroService.html

http://blog.cuicc.com/blog/2015/07/22/microservices/

二、Eureka-Server服务注册中心

新建Eureka-Server服务注册中心项目:

新建springboot项目名称为:eureka-service,然后在pom.xml中,引入相关的依赖,如下所示(当前使用springboot1.5.1.RELEASE版本用于练习)

eureka-service为集群1,可复制一份名称为eureka-service-2的集群2(更改pom.xml中的eureka-service-2即可)

1、Eureka-Server的pom.xml



    4.0.0
    org.yabin
    eureka-service
    0.0.1-SNAPSHOT
    eureka-service
    Demo project for Spring Boot

    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.1.RELEASE
         
    

    
        1.8
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                Edgware.SR3
                pom
                import
            
        
    

    
        
            org.springframework.cloud
            spring-cloud-starter-eureka-server
        

        
            org.springframework.boot
            spring-boot-starter
        

        
            org.springframework.boot
            spring-boot-devtools
            runtime
            true
        

        
            org.projectlombok
            lombok
            true
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
                
                    
                        
                            org.projectlombok
                            lombok
                        
                    
                
            
        
    

2、配置application.yml文件

eureka.instance.hostname指定www.yabin.com(作为本地测试集群1的配置),

可在位置C:\Windows\System32\drivers\etc修改hosts

服务注册中心-集群1的配置:

server:
  port: 8080

spring:
  application:
    name: Eureka-Server

eureka:
  instance:
    # 指定了Eureka服务端的IP(集群1)
    hostname: www.yabin.com
  client:
    # 表示是否将服务注册到Eureka服务端,由于自身就是Eureka服务端;若集群则为true,否则设置为false
    register-with-eureka: true
    # 表示是否从Eureka服务端获取服务信息;若集群则为true,否则设置为false
    fetch-registry: true
    service-url:
      # 指定Eureka服务端的地址,若非集群模式,指定自己的地址即可;若是则指定其它集群地址
      defaultZone: http://windows10.microdone.cn:8081/eureka/
  server:
    # 保护模式:false表示关掉
    enable-self-preservation: false

服务注册中心-集群2的配置:

server:
  port: 8081

spring:
  application:
    name: Eureka-Server

eureka:
  instance:
    # 指定了Eureka服务端的IP(集群2)
    hostname: windows10.microdone.cn
  client:
    # 表示是否将服务注册到Eureka服务端,由于自身就是Eureka服务端;若集群则为true,否则设置为false
    register-with-eureka: true
    # 表示是否从Eureka服务端获取服务信息;若集群则为true,否则设置为false
    fetch-registry: true
    service-url:
      # 指定Eureka服务端的地址,若非集群模式,指定自己的地址即可;若是则指定其它集群地址
      defaultZone: http://www.yabin.com:8080/eureka/
  server:
    # 保护模式:false表示关掉
    enable-self-preservation: false

3、编辑启动类

3-1、在启动类中,增加@EnableEurekaServer注解;因本地搭建的是集群,可以在两个服务注册中心项目入口类中增加启动服务注解。

3-2、测试结果

集群1服务:http://127.0.0.1:8080

集群2服务:http://127.0.0.1:8081

SpringCloud学习之微服务开发篇(三)1.1 - 微服务概述及治理_第2张图片

3-3、项目排布

SpringCloud学习之微服务开发篇(三)1.1 - 微服务概述及治理_第3张图片

三、Eureka-Client客户端服务提供者

1、pom.xml

与eureka-server项目的pom.xml引用的jar依赖一样。

项目名称可设置未:集群1:eureka-client;集群2:eureka-client2

2、配置application.yml文件

2-1、集群1:

server:
  port: 8082

spring:
  application:
    # 指定服务名称为Server-Provider
    name: Server-Provider
  profiles:
    # 指定配置环境
    active: dev

eureka:
  client:
    # 表示是否将服务注册到Eureka服务端
    register-with-eureka: true
    # 表示是否从Eureka服务端获取服务信息
    fetch-registry: true
    service-url:
      # 指定Eureka服务端的地址
      defaultZone: http://www.yabin.com:8080/eureka/,http://windows10.microdone.cn:8081/eureka/

2-2、集群2:

server:
  port: 8083

spring:
  application:
    # 指定服务名称为Server-Provider
    name: Server-Provider
  profiles:
    # 指定配置环境
    active: dev

eureka:
  client:
    # 表示是否将服务注册到Eureka服务端
    register-with-eureka: true
    # 表示是否从Eureka服务端获取服务信息
    fetch-registry: true
    service-url:
      # 指定Eureka服务端的地址
      defaultZone: http://www.yabin.com:8080/eureka/,http://windows10.microdone.cn:8081/eureka/

3、编辑启动类

需要在启动类上加注解:@EnableDiscoveryClient

4、测试说明

① 对外提供接口让消费者调用(控制层)

@RestController
public class EurekaClientController {

    @Resource
    private Registration registration;
    @Resource
    private DiscoveryClient client;

    @GetMapping("info")
    public String info() {
        ServiceInstance instance = getLocalServiceInstance();
        if (instance == null) {
            return "服务提供者1:实例化是空的";
        }
        String info = "服务提供者1:host: "+ instance.getHost() +",serviceId: "+ instance.getServiceId() +", port: "+ instance.getPort();
        log.info(info);
        return info;
    }

    private ServiceInstance getLocalServiceInstance() {
        String instanceId = registration.getServiceId();
        log.info("服务提供者1:获取本地服务ID:{}", instanceId);
        List list = client.getInstances(instanceId);
        if (list != null && list.size() > 0) {
            for (ServiceInstance instance : list) {
                if (instance.getPort() == 8082) {
                    return instance;
                }
            }
        }
        return null;
    }
}

② 建立一个消费者项目service-consumer,调用提供者服务eureka-server对外的接口;引用的pom.xml与eureka-server的pom.xml一样。编写控制层代码,如下:

@RestController
public class ServiceConsumerController {

    @Resource
    private RestTemplate restTemplate;

    /**
     * 使用RestTemplate对象均衡的去获取服务并消费
     *
     * 可以看到我们使用服务名称(Server-Provider)去获取服务的,而不是使用传统的IP加端口的形式。
     * 这就体现了使用Eureka去获取服务的好处,我们只要保证这个服务名称不变即可,IP和端口不再是我们关心的点。
     */
    @GetMapping("info")
    public String getInfo() {
        log.info("进入消费者方法getInfo()");
        return restTemplate.getForEntity("http://Server-Provider/info", String.class).getBody();
    }
}

③ 消费者启动类加上注解:@EnableDiscoveryClient

消费者访问地址:http://localhost:9010/info

 

你可能感兴趣的:(spring,cloud,spring,cloud)