Eureka Client搭建:
一、引入pom依赖
org.springframework.cloud
spring-cloud-starter-netflix-eureka-client
【springcloud学习之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浅尝(六)——Bus
- SpringCloud浅尝(三)——Eureka
- SpringCloud浅尝(十)——Sleuth ZipKin
- SpringCloud浅尝(九)——Hystrix Dashboard
- SpringCloud浅尝(八)——Hystrix
- SpringCloud(三)多节点高可用Eureka注册中心集群
- springcloud搭建eureka服务
- SpringCloud之 Eureka 的服务治理
- 搭建微服务(服务提供者与服务消费者)
- springcloud 服务调用成功几次之后都会失败