书写这篇文章的目的是告诉大家有闭环思维,使用Feign调用404的事件说明闭环思维的重要性。
具有绑定关系的服务要进行形式绑定,防止出现出现线上事故。
Feign服务在生产环境做了负载,部署了两台机器。用了同一个nacos的命名空间。上线的时候只对其中的一台做了更新,导致请求到另一台的时候产生了404的问题。
fegin是一个声明式的http客户端,使用fegin只需要创建一个接口并使用对应注解,就能支持我们服务之间的调用。
被调用方不需要做任何操作,写正常的接口就可以。
1、引入依赖:
org.springframework.cloud spring-cloud-starter-openfeign
2、使用注解实现nacos注册
3、启动类上添加@EnableFeignClients注解
4、需要的地方进行注入,使用。
5、测试
上边部分只部署了一个服务,现在部署多套服务服务:
我们把上文提到的serviceTwo服务部署两份,由于是在我自己本机上操作,我们使用端口号进行一下区分。
这样我们就模拟出了,serverTwo服务,部署了两份。我们可以看一下nacos,现在serverTwo项目有两个实例。这两个服务的默认权重都是1,也就是如果我再次使用 serverOne对serverTwo进行fegin调用,会走一次9002端口,然后会走一次9004端口。
我们将9004端口对应的服务内容进行一下更改,将serviceTwo/test 接口注释。模拟一下,两个服务不同,即是上文提到的一个服务更新了,另一个服务没有更新,调用到未更新的就会产生404问题。
第二次调用的时候,由于9004对应的serverTwo服务的接口被注销调了,无法调通。这样就复现了上文所出现的问题
一个服务更新了,另一个服务代码没有更新,调用到未更新的就会产生404问题
减少人的操作,可以周期性在jenkins上执行脚本。确保所有代码都更新了。
我们要有连续,相对,无限,运动的思维去解决问题。能交给机器做的都不要让人做。