很早搭的一个springcloud测试服务,一个gateway,两个eureka server,两个eureka client,client中有两个测试接口,一个是登录页面访问接口,一个是获取用户信息接口;服务全部起来后看了下后台日志一切运行正常。
然后访问其中一个server,开浏览器输入地址:http://192.168.1.13:8088/login
由于启用了安全验证因此需要输入用户名和密码,然后进入spring eureka的监控页面:
显示5个服务都起来了。
然后使用postman进行接口测试,第一个登录页面访问接口测试地址为
http://192.168.1.22:9000/ec?token=123
因为在gateway中有如下路由配置:
因此只要请求地址中含有/ec这个路径就会被转发到eureka-client上,看上图监控截图,eureka-client服务对应两个地址,也就是说上面地址请求会转发到这两client其中一个上(负载均衡策略可以自己在框架中配置);测试结果截图如下:
可以看到获取到登录页面,测试成功。现在进行第二个接口测试,访问地址如下:
http://192.168.1.22:9000/ec/eureka/single/login?token=123
和上一个测试不一样这是个post请求,需要发送json格式的用户名数据才能请求到对应的用户信息,测试了发现竟然无法请求
直接在client上测试发现没有问题,看样子问题是出在gateway上。不用路由转发配置直接在地址上写入client服务名测试一下,地址如下:
http://192.168.1.22:9000/EUREKA-CLIENT/ec/eureka/single/login?token=123
测试结果如下:
竟然成功了,那肯定是gateway路由转发配置有问题,仔细看了下测试地址和路由配置,发现竟然犯了一个非常低级的错误,因为我路由中没有针对多级地址的转发配置所以会转发失败,正确配置如下:
记录一下,就这个简单问题费了我大半个下午进行测试查找。