SpringCloud微服务架构之服务的调用

个人博客传送门


微服务架构中,业务都会被拆分成一个独立的服务,服务与服务的通讯是基于http restful的。Spring cloud有两种服务调用方式,一种是ribbon+restTemplate,另一种是feign。接下来分别对这两种的进行讲解。服务的调用还是在上一节服务的注册和发现的基础上进行的。
一. 准备工作,服务的调用基于上一节,服务的注册和发现进行的,因此我们需要先启动上一节的服务注册中心,然后再启动我们需要注册的服务service-hi,然后修改service 的端口号重新启动,访问http://localhost:8761/,你会看到如下图则表示我们的准备工作已经完成了。
SpringCloud微服务架构之服务的调用_第1张图片

二. 创建一个基于Ribbon+restTemplate的服务消费者:ribbon是一个负载均衡客户端,可以很好的控制htt和tcp的一些行为。
1. 新建一个module,分别引入如下的包,然后finish

SpringCloud微服务架构之服务的调用_第2张图片
2.新建好了之后,RibbonApplication中增加注解@bean 将RestTemplate注入到容器中去,

@SpringBootApplication
public class RibbonApplication {

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

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

3,然后创建一个service类和一个controller类,如图

@Service
public class service {

    @Autowired
    private RestTemplate restTemplate;

    public  String  sayHello(String name){
        return  this.restTemplate.getForObject("http://service-hi/hi?name=" + name,String.class);
    }

}

Service中需要注入的是resttemplate接口,并且可以去访问对应的服务和服务的接口。
在创建一个

@RestController
public class controller {

    @Autowired
    private service service;

    @RequestMapping(value = "/hello",method = {RequestMethod.GET,RequestMethod.POST})
    public String sayHello(String name){
        return  service.sayHello(name);
    }

}

4,接下来我们需要修改下我们前一节所写的服务,如图:

@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class ServiceApplication {

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

   @Value("${server.port}")
   String port;

   @RequestMapping(value = "/hi",method = {RequestMethod.GET,RequestMethod.POST})
   public String sayHello(String name){
      return "I am service-hi ,my port is :" + port + "my name is " + name;
   }
}

5,然后一次重启所有的服务:serverservice1service2Ribbon,然后访问http://localhost:8080/hello?name=kk,你会发现界面上会重复交替出现两个服务service1和service2的端口号和传递过去的参数。
SpringCloud微服务架构之服务的调用_第3张图片

到此Ribbon和restTemplate的消费服务已经完成,接下来我们看看Feign的服务。
三. 创建一个基于Feign去消费服务
Feign 采用的是基于接口的注解
Feign 整合了ribbon
1.同理我们也是需要在一的步骤下进行的,必须先开启服务注册中心,并且将我们的服务注册进去,然后新建一个Feign,如图:
SpringCloud微服务架构之服务的调用_第4张图片

然后需要创建一个Iservice接口和FeignController类:
创建该接口用来调用服务@FeignClient(value = “service-hi”) 注解配置的是服务的名称

@RequestMapping("/hi") //配置的调用的接口
@FeignClient(value = "service-hi")
@Service
public interface Iservice {

    @RequestMapping("/hi")
     String SayHello(@RequestParam(value = "name") String name);
}
@RestController
public class FeignController {

    @Autowired
    private Iservice iservice;

    @RequestMapping(value = "/feign/hello")
    public String sayHello(String name){
        return   iservice.SayHello(name);
    }

}

配置下该启动类,如下:

@SpringBootApplication
@EnableFeignClients
public class FeignApplication {

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

然后访问:http://localhost:8080/feign/hello?name=kk
你会看到如下的界面:
SpringCloud微服务架构之服务的调用_第5张图片

以上就是服务的消费的两种方式。

附上我的完整的博文:
从零开始学习SpringCloud
代码地址

你可能感兴趣的:(javaWeb技术,springboot,springcloud)