微服务开发过程当中,并且是在进行多项目开发时,难免的会出现调用别人开发的接口获取数据这种场景,但是到这里通常可以以下两种方式进行调用获取。(后端调用)
- 通过openFegin进行接口转发直接调用
- 通过ribbon负载均衡获取ip进行拼接url调用
通过openFegin实现
可参考该文 4.3 Spring Cloud 微服务解决方案 详解
通过ribbon负载均衡实现
首先我们将服务发现进行注入进来
@Autowiredprivate DiscoveryClient discoveryClient;
之后我们封装一个方法,用于通过服务名称来再通过Ribbon的负载均衡进行转发到对应的机器,获取其IP
public String getUri(String serviceName) {AtomicReference<URI> uri = new AtomicReference<>();List<ServiceInstance> serviceInstances = discoveryClient.getInstances(serviceName);serviceInstances.forEach(serviceInstance -> {uri.set(serviceInstance.getUri());});return uri.get().toString();}
最后我们通过拼接url再使用hutools的Http工具进行调用进行发送请求
JSONObject object = new JSONObject();String url = getUri("service-lzq-ticket") + "/service-lzq-ticket/demo";String res = HttpRequest.post(url).body(String.valueOf(object)).execute().body();log.info("object json ============>>>>>>>>>{}", String.valueOf(object));log.info("res =================>>>>>>> {}", res);
最后我们通过JSON工具对字符串转成实体对象
User data = JSONUtil.toBean(res, com.lzq.common.User.class, false);