初探Spring Cloud-Netflix

都说好记性不如烂笔头,每天写一点,从量变到质变的开始!废话不多说,以下所有内容均来自本人实际操作:

Spring Cloud Netflix通过自动配置并绑定到Spring Environment和其他Spring编程模型习惯用法,为Spring Boot应用程序提供Netflix OSS集成。通过一些简单的注释,您可以快速启用和配置应用程序内部的通用模式,并使用经过实战检验的Netflix组件构建大型分布式系统。提供的模式包括服务发现(Eureka),断路器(Hystrix),智能路由(Zuul)和客户端负载平衡(Ribbon)。

1.Spring Cloud Netflix功能

  • 服务发现:可以注册Eureka实例,并且客户端可以使用Spring托管的Bean发现实例

  • 服务发现:可以使用声明性Java配置创建嵌入式Eureka服务器

  • 断路器:Hystrix客户端可以使用简单的注释驱动的方法装饰器构建

  • 断路器:具有声明性Java配置的嵌入式Hystrix仪表板

  • 声明式REST客户端:Feign创建一个用JAX-RS或Spring MVC注释修饰的接口的动态实现。

  • 客户端负载均衡器:功能区

  • 外部配置:从Spring Environment到Archaius的桥梁(使用Spring Boot约定启用Netflix组件的本机配置)

  • 路由器和过滤器:Zuul过滤器的自动注册,以及用于反向代理创建的简单配置约定

2.搭建Spring Cloud项目-注册中心

2.1 导入依赖

父项目

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.1</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    

 版本控制

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>2020.0.0</spring-cloud.version>
    </properties> 
   
    <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>

项目依赖

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>

2.2 yml配置

server:
  port: 8761
eureka:
  server:
    #防止由于Eureka的机制导致Client被错误显示在线,仅在开发环境使用,生产环境需缓存此信息,防止因网络波动导致服务频繁上下线
    enable-self-preservation: false
  client:
    #不向注册中心注册自己
    register-with-eureka: false
    service-url:
      #其他应用向注册中心注册的注册地址,注册中心集群直接以","分隔
      defaultZone: http://localhost:8761/eureka/
spring:
  application:
    name: spring-cloud-register

 2.3 开启服务(@EnableEurekaServer)

@SpringBootApplication
@EnableEurekaServer
public class SpringCloudRegisterApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringCloudRegisterApplication.class, args);
    }

}

2.4 启动项目查看效果(http://localhost:8761)

 可以看到目前没有实例被注册

3.搭建Spring Cloud项目-服务中心

3.1 导入依赖

父项目

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.1</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    

 版本控制

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>2020.0.0</spring-cloud.version>
    </properties> 
   
    <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>

项目依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

3.2 yml配置

server:
  port: 8888
eureka:
  client:
    service-url:
      #向注册中心注册的注册地址,注册中心集群直接以","分隔
      defaultZone: http://localhost:8761/eureka/
spring:
  application:
    name: spring-cloud-producer

3.3 添加一个服务

@RestController
public class HelloController {

    @RequestMapping("/hello")
    public String hello(@RequestParam String name) {
        return "hello "+name+",producer is ready";
    }
}

3.4 开启客户端注册(@EnableEurekaClient)

/**
 * 增加@EnableEurekaClient,如果是其他注册中心可以使用注解@EnableDiscoveryClient来进行服务的注册
 */
@SpringBootApplication
@EnableEurekaClient
public class SpringCloudProducerApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringCloudProducerApplication.class, args);
    }

}

 3.5 启动项目并访问注册中心查看(http://localhost:8761)

4.搭建Spring Cloud项目-消费中心

4.1 导入依赖

父项目

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.1</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    

 版本控制

    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>2020.0.0</spring-cloud.version>
    </properties> 
   
    <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>

项目依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

4.2 yml配置

server:
  port: 9999
eureka:
  client:
    service-url:
      #向注册中心注册的注册地址,注册中心集群直接以","分隔
      defaultZone: http://localhost:8761/eureka/
spring:
  application:
    name: spring-cloud-consumer

4.3 开启客户端注册和Feign客户端服务(@EnableEurekaClient@EnableFeignClients)

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class SpringBootConsumerApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringBootConsumerApplication.class, args);
    }

}

4.4 新建一个类调用消费中心的服务

@RestController
public class HelloController {

    /**
     * name:远程服务名,及spring.application.name配置的名称
     * 此类中的方法和远程服务中contoller中的方法名和参数需保持一致
     */
    @FeignClient(name = "spring-cloud-producer")
    static interface HelloRemote {
        @RequestMapping(value = "/hello")
        public String hello(@RequestParam(value = "name") String name);
    }

    /**
     * spring cloud 提供的类可以查看注册中心的服务
     */
    @Autowired
    public DiscoveryClient discoveryClient;
    @Autowired
    public HelloRemote helloRemote;

    /**
     * 查看服务中心信息
     */
    @GetMapping("/getProducer")
    public ResponseEntity<List<ServiceInstance>> getInstances() {
        try {
            List<ServiceInstance> instances = this.discoveryClient.getInstances("spring-cloud-producer");
            return ResponseEntity.ok(instances);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
    }

    /**
     * 调用远程服务
     */
    @GetMapping("/hello/{name}")
    public String index(@PathVariable("name") String name) {
        return helloRemote.hello(name);
    }
}

4.5 启动项目查看效果

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值