spring cloud 之客户端调用使用(feign)

spring cloud 进行服务调用的时候,客户端有2种方式,第一种方式是通过rest方式,第二种方式是通过feign方式。而第一种方式在
【《spring cloud 之客户端调用使用(restTemplate)和负载均衡》https://www.jianshu.com/p/baa5bacae3f6】文章中介绍了通过rest方式进行调用。今天我们通过fegin方式作为客户端来进行调用。整个项目的演示还是基于上篇文章的订单服务和会员服务之中展开。

1.POM.xml进行配置


            org.springframework.boot
            spring-boot-starter
        
        
            org.springframework.cloud
            spring-cloud-starter-eureka-server
            1.4.5.RELEASE
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
        
            org.springframework.cloud
            spring-cloud-starter-feign
            1.4.5.RELEASE
  

这块需要注意的是spring-cloud-starter-feign这个包的版本需要和spring-cloud-starter-eureka-server这个包的版本得一致,否则启动的时候会出现错误。

2.会员服务不需要改动,需要变动订单服务,更改订单服务的通讯方式,更改为fegin方式,配置文件还是一样,application.yml

server:
  port: 8087
spring:
  application:
    name: service-order
eureka:
  instance:
    prefer-ip-address: true
  client:
    register-with-eureka: true
    healthcheck:
      enabled: true
    serviceUrl:
      defaultZone: http://zzh:[email protected]:8086/eureka/

3.新增MemberService接口用来调用会员服务的接口

@FeignClient(name = "service-member")
public interface MemberService {

    @RequestMapping("/member/getAllMemberInfo")
    String getAllMemberInfo();
}

@FeignClient(name = "service-member") 该注解中的name指向的是会员服务中的设置的

spring:
  application:
    name: service-member

这个参数。

4.修改controller中的调用方式

@RestController
@RequestMapping("/order")
public class OrderController {

//    @Autowired
//    private RestTemplate restTemplate;

    @Autowired
    private MemberService memberService;

    @RequestMapping("/getAllOrderInfo")
    @ResponseBody
    public String getAllOrderInfo(){
//        String result = restTemplate.getForObject("http://service-member/member/getAllMemberInfo", String.class);
        String result=memberService.getAllMemberInfo();
        return result;
    }
}

5.修改服务启动类

@SpringBootApplication
//开启服务发现功能
@EnableDiscoveryClient
//开启Feign功能
@EnableFeignClients(basePackages = "com.itshirui")
@EnableEurekaClient
@ComponentScan(basePackages = "com.itshirui")
//@RibbonClient(name = "ribbonclient",configuration = RibbonConfig.class)
public class ServiceOrderApplication {

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

@EnableFeignClients(basePackages = "com.itshirui") 这个注解中必须加上basePackages指定对应的service的包路径,否则服务启动的时候会出现找不到对应的service。

6.服务启动,看效果,会出现如下效果图

image.png

image.png

通过订单服务调用会员服务成功,并且也实现了负载均衡的效果,如果想更改负载均衡的策略,可以参考《spring cloud 之负责均衡第二篇》 https://www.jianshu.com/p/12f15e8270e5,这篇文章,讲的比较详细。
通过fegin调用就到这里了。

你可能感兴趣的:(spring cloud 之客户端调用使用(feign))