spring-cloud的两种调用方式

spring-cloud的两种调用方式

第一种:ribbon

  1. 新建一个spring-cloud项目
  2. 引入依赖包

			org.springframework.cloud
			spring-cloud-starter-eureka
		
		
			org.springframework.cloud
			spring-cloud-starter-ribbon
		
  1. 修改配置文件
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
  port: 8764
spring:
  application:
    name: service-ribbon

网址是服务注册中心的地址

  1. 在工程的启动类中,通过@EnableDiscoveryClient向服务中心注册;并且向程序的ioc注入一个bean: restTemplate;并通过@LoadBalanced注解表明这个restRemplate开启负载均衡的功能。
@SpringBootApplication
@EnableDiscoveryClient
public class ServiceRibbonApplication {

	public static void main(String[] args) {
		SpringApplication.run(ServiceRibbonApplication.class, args);
	}

	@Bean
	@LoadBalanced
	RestTemplate restTemplate() {
		return new RestTemplate();
	}

}
  1. 所有都配置好后,你就可以通过注入restTemplate,来调用其他服务
 @Autowired
    RestTemplate restTemplate;

    public String hiService(String name) {
        return restTemplate.getForObject("http://SERVICE-HI/hi?name="+name,String.class);
    }

在ribbon中它会根据服务名来选择具体的服务实例,根据服务实例在请求的时候会用具体的url替换掉服务名(service-hi)
另外:这里面还有一个负载均衡的点(@LoadBalanced)
当restTemplate调用service-hi的hi接口时,因为用ribbon进行了负载均衡,如果service-hi在服务注册中心上面注册了多个实例,这时候就会轮流的调用service-hi多个端口的不同接口;

Feign调用(默认集成ribbon调用)

  1. 新建spring-cloud项目
  2. 导入依赖包

		org.springframework.cloud
		spring-cloud-starter-feign

  1. 配置文件(同上)
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
  port: 8765
spring:
  application:
    name: service-feign
  1. 在程序的启动类ServiceFeignApplication ,加上@EnableFeignClients注解开启Feign的功能:
  2. 这时候就可以定义一个feign接口,通过@ FeignClient(“服务名”),来指定调用哪个服务。比如在代码中调用了service-hi服务的“/hi”接口,
@FeignClient(value = "service-hi")
public interface SchedualServiceHi {
    @RequestMapping(value = "/hi",method = RequestMethod.GET)
    String sayHiFromClientOne(@RequestParam(value = "name") String name);
}
  1. 这时候你就可以在你所需的位置通过注入该接口去调用该服务:如:
 @Autowired
    SchedualServiceHi schedualServiceHi;
    @RequestMapping(value = "/hi",method = RequestMethod.GET)
    public String sayHi(@RequestParam String name){
        return schedualServiceHi.sayHiFromClientOne(name);
    }

你可能感兴趣的:(spring,eureka,ribbon)