SpringBoot微服务间调用解决方案

在SpringBoot开发中,常有服务间互相调用的需求,使用最简单的方式当然是直接远程调用即可,但是为了避免这种混乱的调用机制,也为了方便维护,需要折中考虑较为方便的形式调用

方式一:中间服务

优势:

  1. 将服务间的耦合度降到最低 ;
  2. 降低服务复杂度,各服务不需要变动;

缺点:

  1. 增加了服务数量,需要维护 ;

实现:
在网关与微服务间构建一个中间服务(汇聚服务),需要多个服务共同完成业务时,由该服务调用多个微服务

	@Autowired
	private LoadBalancerClient loadBalancerClient;
	@Value("${fire_base_service.serviceId}")
	private String firebaseservice;// 基础服务


	JSONObject result = new JSONObject();
	// 获取片区的单位、人员、建筑、设备信息
	Map<String, Object> buildfloorparams = new HashMap<String, Object>();
	JSONObject baseresult = RestTempleUtil.getForObject(loadBalancerClient, firebaseservice, "/basezone/base/" + code, buildfloorparams);
	if (HttpStatus.OK.value() == baseresult.getInt("status")) {
		JSONObject base = baseresult.getJSONObject("data");
		result.putAll(base);
	}

方式二:互相调用

优势

  1. 维持原有服务数量;

缺点

  1. 增加了业务的复杂性 ;
  2. 服务的主次难以决定

实现
需要多个服务共同完成业务时,选其中一个服务作为调用方,调用其他服务接口
步骤与方式一类似

方式三:两者组合使用

优势

  1. 既保留方式一的灵活性,又拥有方式二的自主性

实现
由于某些场景下,汇聚服务操作业务过于复杂,可以选择性的使用相互调用的方式

问题及解决

  1. 远程调用put时需要封装Header,但是RestTemplate的put方法没有提供这个功能

    /**
    * put请求
    *
    * @param loadBalancerClient
    * @param serviceId
    * @param url
    * @param params
    * @return
    */
    public static void put(LoadBalancerClient loadBalancerClient, String serviceId, String url, Map<String, Object> params) {
    RestTemplate restTemplate = new RestTemplate();
    restTemplate.getMessageConverters().set(1, new StringHttpMessageConverter(StandardCharsets.UTF_8));// 中文参数处理
    ServiceInstance firebusinessseviceInstance = loadBalancerClient.choose(serviceId); // PRODUCT为注册到中心的服务名
    String firebusinessseviceUrl = String.format(“http://%s:%s”, firebusinessseviceInstance.getHost(), firebusinessseviceInstance.getPort()) + url;

    	HttpHeaders headers = new HttpHeaders();//header参数
        headers.setContentType(MediaType.APPLICATION_JSON);
        JSONObject jsonObj = JSONObject.fromObject(params);
    	HttpEntity<String> formEntity = new HttpEntity<String>(jsonObj.toString(), headers);
        ResponseEntity<String> response = restTemplate.exchange(firebusinessseviceUrl,HttpMethod.PUT,formEntity,String.class);
    }
    

直接使用exchange方法操作。

博文说明:文章通过亲身使用及参考其他博客,若有雷同,敬请见谅!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Springboot中,服务接口之间相互调用可以使用RestTemplate或FeignClient。 1. RestTemplate RestTemplate是Spring提供的用于访问Rest服务的客户端。通过RestTemplate,我们可以直接访问其他服务的Rest接口,获取返回结果。 使用RestTemplate,我们需要进行如下步骤: - 创建RestTemplate实例 - 构造请求参数 - 发送请求 - 解析返回结果 示例代码: ``` RestTemplate restTemplate = new RestTemplate(); String url = "http://localhost:8080/user/{id}"; Map<String, String> params = new HashMap<>(); params.put("id", "1"); User user = restTemplate.getForObject(url, User.class, params); ``` 2. FeignClient FeignClient是Spring Cloud提供的一种声明式的HTTP客户端,它简化了服务接口之间调用。我们只需要定义一个接口,然后在接口上添加注解即可实现调用。 使用FeignClient,我们需要进行如下步骤: - 定义FeignClient接口 - 添加注解 - 调用接口 示例代码: ``` @FeignClient(name = "user-service") public interface UserFeignClient { @GetMapping("/user/{id}") User getUserById(@PathVariable("id") Long id); } @RestController public class UserController { @Autowired private UserFeignClient userFeignClient; @GetMapping("/user/{id}") public User getUserById(@PathVariable("id") Long id) { return userFeignClient.getUserById(id); } } ``` 以上是Springboot中服务接口之间相互调用的两种方式,具体使用哪种方式,需要根据项目需求和实际情况来选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值