1、Eureka常见问

1.1、Eureka Enviroment 的配置

eureka.enviroment=product

  参考 https://github.com/Netflix/eureka/wiki/Configuring-Eureka

1.2、Eureka Datacenter 的配置

eureka.datacenter=cloud 

  配置eureka.datacenter=cloud,这样eureka就知道是在AWS云上

1.3、Eureka 开启自我保护的提示

EMERGENCY! EUREKA MAY BE INCORRECTLY CLAIMING INSTANCES ARE UP WHEN THEY'RE NOT.
RENEWALS ARE LESSER THAN THRESHOLD AND HENCE THE INSTANCES ARE NOT BEING EXPIRED JUST TO BE SAFE.

  Eureka进入保护模式时,不会踢出已关闭的节点。

1.4、Eureka 注册服务慢的问题如何解决?

1.5、如何解决Eureka Server不踢出已关闭的节点的问题?

Server端
  #关闭eureka的自我保护
  eureka.server.enable-self-preservation=false
  #清理间隔时间,单位为毫秒
  eureka.server.eviction-interval-timer-in-ms=0 Client端
  #开启健康检查(需要spring-boot-starter-actuator依赖)
  eureka.client.healthcheck.enabled=true
  #租期到期时间,默认90秒
  eureka.instance.lease-expiration-duration-in-seconds=30
  #租赁更新时间间隔,默认30,即30秒发送一次心跳
  eureka.instance.lease-renewal-interval-in-seconds=10

  注意:更改Eureka更新频率将打破服务器的自我保护能力,生产环境中一般不推荐修改。

1.6、Eureka 配置instanceId显示IP

eureka.client.serviceUrl.defaultZone=http://user:password@localhost:8761/eureka
#设置注册ip
eureka.instance.prefer-ip-address=true
eureka.instance.instanceId=${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}

  

2、Ribbon

2.1、自定义配置时,@Configuration和@ComponentScan所在包不应该重叠

2.2、使用RestTemplate时,想要获得一个List时,应该用数组,而不应该直接用List。

  在microservice-provider-user项目中添加如下代码,返回list

  @GetMapping("/list-all")
public List<User> listAll(){
List<User> list = new ArrayList<User>();
User user = new User(1,"zahngsan");
User user2 = new User(2,"zahngsan2");
User user3 = new User(3,"zahngsan3");
list.add(user);
list.add(user2);
list.add(user3);
return list;
}

直接访问此项目,得到如下结果:

  

  在microservice-consumer-movie-ribbon-list项目中通过RestTemplate访问以上内容:

@GetMapping("/list-all")
public List<User> list() {
List<User> list = this.template.getForObject("http://microservice-provider-user:7900/list-all", List.class);
for(User u:list){
System.out.println(u.getId());
}
return list;
}

  报错:

java.lang.ClassCastException: java.util.LinkedHashMap cannot be cast to com.wyl.microservicesimpleconsumemovie.entity.User

  可看出RestTemplate得到的是LinkedHashMap对象,不是List对象。则通过以下代码解析:

User[] list = this.template.getForObject("http://microservice-provider-user:7900/list-all", User[].class);
for(User u:list){
  System.out.println(u.getId());
}

3、Feign

3.1、自定义配置时,@Configuration和@Component所在包不应该重叠

3.2、@FeignClient所在的接口中,不支持@GetMapping等组合注解

3.3、使用@PathVariable时,需要制定其value

3.4、Feign暂时不支持复杂对象作为一个参数

Eureka、Ribbon、Feign常见问题及解决的更多相关文章

  1. 0409-服务注册与发现-Eurek Ribbon Feign常见问题及解决

    一.Eureka 1.1.Eureka Environment的配置: eureka.environment: 字符串 参考文档: https://github.com/Netflix/eureka/ ...

  2. Spring Cloud中五大神兽总结(Eureka/Ribbon/Feign/Hystrix/zuul)

    Spring Cloud中五大神兽总结(Eureka/Ribbon/Feign/Hystrix/zuul) 1.Eureka Eureka是Netflix的一个子模块,也是核心模块之一.Eureka是 ...

  3. 【一起学源码-微服务】Eureka+Ribbon+Feign阶段性总结

    前言 想说的话 这里已经梳理完Eureka.Ribbon.Feign三大组件的基本原理了,今天做一个总结,里面会有一个比较详细的调用关系流程图. 说明 原创不易,如若转载 请标明来源! 博客地址:一枝 ...

  4. 微服务:Eureka+Zuul+Ribbon+Feign+Hystrix构建微服务架构

    原文地址:http://blog.csdn.net/qq_18675693/article/details/53282031 本案例将打架一个微服务框架,参考来源官方参考文档 微服务:是什么?网上有一 ...

  5. springcloud微服务实战:Eureka+Zuul+Feign/Ribbon+Hystrix Turbine+SpringConfig+sleuth+zipkin

    相信现在已经有很多小伙伴已经或者准备使用springcloud微服务了,接下来为大家搭建一个微服务框架,后期可以自己进行扩展.会提供一个小案例: 服务提供者和服务消费者 ,消费者会调用提供者的服务,新 ...

  6. springcloud-知识点总结(二):Ribbon&Feign

    1.Ribbon简介 前面讲了eureka服务注册与发现,但是结合eureka集群的服务调用没讲. 这里的话 就要用到Ribbon,结合eureka,来实现服务的调用: Ribbon是Netflix发 ...

  7. eureka和feign的使用

    1 eureka和feign的简介(copy来的) eureka:Eureka是Netflix开发的服务发现组件,本身是一个基于REST的服务.Spring Cloud将它集成在其子项目spring- ...

  8. NHibernate常见问题及解决方法

    NHibernate常见问题及解决方法 曾经学过NHibernate的,但是自从工作到现在快一年了却从未用到过,近来要巩固一下却发现忘记了许多,一个"in expected: <end ...

  9. WebView加载本地html、js文件常见问题及解决办法

    声明:基于android studio平台,php语言搭建服务器 目录: 一.JavaScript脚本语言没有反应 二.alert无法弹出 三.html页面之间不能跳转 四.屏幕缩放没有达到预期效果 ...

随机推荐

  1. Web开发之容器

    Web开发之容器 主题 Servlet容器.Web容器.应用服务器 参考资料   Servlet容器.Web容器.应用服务器         Servlet容器的主要任务是管理Servlet的生命周期 ...

  2. JavaScript中label与break配合使用

    语法 label: statement 说明 label语句可以在代码中添加标签,以便将来使用.定义的标签可以在将来由break或continue语句引用.加标签的语句一般都要与for语句等循环语句配 ...

  3. a标签里面包含img标签,出现a标签的高度高于img标签好几个px

    问题:a标签里面包含img标签,出现a标签的高度高于img标签好几个px 解决: a元素下有一个匿名文本,这个文本外有一个匿名行级盒子,它有的默认vertical-align是baseline的,而且 ...

  4. SpringBoot + Thymeleaf + Validate验证

    在开发业务时,不可避免的需要处理一些校验, 如果是写 if-else 这种代码去校验, 那会有一大段这样的代码.不过还好有个校验插件: javax.validation.validation-api  ...

  5. 如何修改本地hosts文件?

    1.window7修改本地hosts文件 # window7系统hosts文件位置 C:\Windows\System32\drivers\etc 2.linux # linux系统hosts文件位置 ...

  6. 使用Kotlin开发Android应用(IV):自定义视图和Android扩展

    在读完扩展函数和默认值这篇文章之后,那么接下来要介绍什么呢?在本系列第一篇文章中我们说过,Kotlin使得Android开发更加简单,本文我们将进一步作介绍. 自定义视图 你应该还记得,在说到Kotl ...

  7. 找出n的阶乘末尾有几个零

    原理:因为10由2*5组成,而构成2的因数比5多 所以最终转换成求5的个数 int getNumber(int n) { int count = 0; while(n) { n = n/5; coun ...

  8. SAP内存、ABAP内存、共享内存的 区别

    区别: (1)SAP内存使用 SET/GET parameters 方法: SET  PARAMETER  ID  ‘MAT’ field P_MATNR. GET  PARAMETER  ID  ‘ ...

  9. 剑指offer 面试28题

    面试28题: 题目:对称的二叉树题: 请实现一个函数,用来判断一颗二叉树是不是对称的.注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的 解题思路: 可以定义一种遍历算法,先遍历右子节点再遍 ...

  10. Ubuntu 下 java 版本的切换

    切换的方法很简单,使用下面的两个命令即可: update-alternatives --config java update-alternatives --config javac eg: root@ ...