springcloud学习之Eureka Client搭建和服务间调用

Eureka Client搭建:

一、引入pom依赖



    org.springframework.cloud
    spring-cloud-starter-netflix-eureka-client

二、启动类推荐添加@EnableEurekaClient注解

就是如果选用的注册中心是eureka,那么就推荐@EnableEurekaClient,
如果是其他的注册中心(zookeeper,consul等),那么推荐使用@EnableDiscoveryClient。

三、配置文件添加:

#eureka
spring.application.name=producer
#注册中心地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
#是否把自己注册
eureka.client.register-with-eureka=true
#是否搜索服务信息
eureka.client.fetch-registry=true

#使用ip地址注册
eureka.instance.prefer-ip-address=true
#注册中心列表显示的状态
eureka.instance.instance-id=${spring.cloud.client.ip-address}:${server.port}

 

服务调用:

有两种方式:

一、ribbon(负载均衡)+restTemplate

启动类添加:

	@Bean
	@LoadBalanced//负载均衡
	public RestTemplate initRestTemplate() {
		return new RestTemplate();//
	}

	@Bean//负载均衡的规则,下面的是其中之一:随机,还有权重,轮询等
	public IRule initIRule() {
		return new RandomRule();
	}

RandomRule表示随机策略

RoundRobinRule表示轮询策略(默认)

WeightedResponseTimeRule表示加权策略

BestAvailableRule表示请求数最少策略

然后在controller中自动装配RestTemplate后使用 restTemplate.getForObject()调用。

二、feign(推荐)

1、引入pom依赖


    org.springframework.cloud
    spring-cloud-starter-openfeign
    2.1.1.RELEASE

2、启动类添加@EnableFeignClients注解

3、创建一个接口,

package com.sumengnan.test.web;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

@FeignClient(name = "eureka",fallback = HtystrixEurekaFallback.class)//调用失败后回滚执行方法
public interface EurekaServiceApi {
    @GetMapping("test")
    String test();
}

回滚的方法:

package com.sumengnan.test.web;

/**
 * eureka熔断回调类
 */
public class HtystrixEurekaFallback implements EurekaServiceApi {
    @Override
    public String test() {
        return "连接失败,请稍后再试!";
    }
}

4、然后在controller中自动装配EurekaServiceApi后使用eurekaServiceApi.test()调用。

 

你可能感兴趣的:(springcloud)