SpringBoot之间内部调用

本文详细介绍了如何在SpringBoot中使用RestTemplate进行RESTful API的设计与实现,包括JSON字符串类型的返回及PageData对象的处理过程。通过具体的代码示例,展示了根据不同用户状态调用不同URL获取数据的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@Autowired
private RestTemplate restTemplate ;//自动装配restTemplate 
-------------------返回json字符串类型----------------------------------
@RequestMapping("/selectHospatal")
	@ResponseBody
	public String selectHospatal()
			throws Exception {
        //返回结果  pageNum
		PageData result = new PageData();
		PageData pageData =getPageData();
        int page=Integer.parseInt(pageData.getString("page"));
		int limit=Integer.parseInt(pageData.getString("limit"));
		String name="";
		name=pageData.getString("name");
		User user = (User) SecurityUtils.getSubject().getPrincipal();
			/*	管理员注册为0	患者为1药厂注册为3	医生注册为4
			 */
			if(name==null){
				name="";
			}
		String forObject="";
		int status=user.getStatus();//类型
		String zsId=user.getType_id();//类型id
		if(status==5){//诊室注册为5//getManageurl是别的springboot服务的地址如:localhost:8080
			String url = getManageurl+"/doctorController/selectHospatal?crid="+zsId+"&name="+name+"&page="+page+"&limit="+limit;
			forObject = restTemplate.getForObject(url, String.class);
		}
		if(status==6){//科室注册为6
			String url = getManageurl+"/doctorController/selectHospatal?dtid="+zsId+"&name="+name+"&page="+page+"&limit="+limit;
			forObject = restTemplate.getForObject(url, String.class);
        }
		if(status==2){//医院注册为2
     String url = getManageurl+"/doctorController/selectHospatal?houid="+zsId+"&name="+name+"&page="+page+"&limit="+limit;
	forObject = restTemplate.getForObject(url, String.class);
		}
    	return forObject;//返回的是json字符串类型
	}
--------------返回PageData对象---------------------------------
/**
 *   查询数据
	 * @return
	 * @throws Exception
	 */
	@RequestMapping("/viewd")
    @ResponseBody
	public PageData viewd() throws Exception{


		//参数
		PageData pageData = getPageData();
		try {
			String url = getManageurl+"/doctorController/view?id="+pageData.getString("id");
		//	String forObject = restTemplate.getForObject(url, String.class);
  			ResponseEntity<PageData> userResponseEntity = RestTemplateUtil.postJson(url, "", PageData.class, restTemplate);
			PageData body = userResponseEntity.getBody();
			return body;

		} catch (Exception e) {
			logger.error(e.toString());
			throw new Exception(e.toString());
		}

	}
Spring Boot Feign是一个基于RestTemplate的声明式Web Service客户端,它简化了微服务之间的远程调用。Feign通过注解方式定义接口,内部封装了负载均衡和服务熔断的功能,提供了一种更简洁、更方便的方式进行服务之间的通信。 熔断机制是一种保护机制,用于防止由于服务不可用或无法正常响应而导致的服务雪崩效应。假设某个微服务在高峰期间不可用,当其他微服务不断向该服务发送请求时,由于无法得到正常的响应,会占用大量的线程和资源,最终导致整个系统崩溃。为了解决这个问题,可以使用熔断器。 熔断器是Feign中的一种机制,用于处理服务调用失败或超时的情况。当服务调用超时或出现错误时,熔断器会暂时中断对该服务的调用,并返回给客户端一个预先定义的默认值或错误信息,而不是一直等待响应。这样可以保护系统不受故障服务的影响,提高系统的可用性和稳定性。 在Spring Boot中使用Feign进行服务调用熔断的具体步骤如下: 1. 在使用Feign的微服务项目中引入相应的依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 2. 创建Feign接口,并使用@FeignClient注解指定要调用的微服务的名称: ```java @FeignClient(value = "service-name", fallback = ServiceFallback.class) public interface ServiceClient { @GetMapping("/api/path") String invokeService(); } ``` 3. 实现熔断的回退逻辑,创建一个Fallback类,实现Feign接口并定义相应的错误处理方法: ```java @Component public class ServiceFallback implements ServiceClient { @Override public String invokeService() { return "Fallback message"; } } ``` 4. 在应用主类上添加@EnableFeignClients注解启用Feign和熔断功能: ```java @SpringBootApplication @EnableFeignClients public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 通过以上步骤,当微服务调用超时或出现错误时,Feign会自动调用相应的熔断器回退逻辑并返回默认值,确保系统的稳定性。可以根据实际情况自定义熔断处理逻辑,比如记录日志、发送警报等操作,以便及时处理故障。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值