2019-06-12 两种rpc调用方式

1、pom文件

        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

    4.0.0

   

        org.springframework.boot

        spring-boot-starter-parent

        2.1.5.RELEASE

       

   

    com.zbiti.zz

    order

    0.0.1-SNAPSHOT

    order

    Demo project for Spring Boot

   

        1.8

        Greenwich.SR1

   

   

       

            org.springframework.boot

            spring-boot-starter-web

       

       

            org.springframework.cloud

            spring-cloud-starter-netflix-eureka-client

       

       

            org.springframework.cloud

            spring-cloud-starter-feign

            1.4.0.RELEASE

       

       

            org.springframework.boot

            spring-boot-starter-test

            test

       

   

   

       

           

                org.springframework.cloud

                spring-cloud-dependencies

                ${spring-cloud.version}

                pom

                import

           

       

   

   

       

           

                org.springframework.boot

                spring-boot-maven-plugin

           

       

   

2、application.yml

server:

  port: 1007

spring:

  application:

    name: order

eureka:

  client:

    service-url:

      defaultZone: http://localhost:1005/eureka/

    register-with-eureka: true

    fetch-registry: true

3.1 RestTemplate 方式需要准备一个 配置bean

@Configuration

public class RestTemplateMothedBeans {

@Bean

@LoadBalanced//这是ribbon 负载均衡

    public RestTemplate restTemplate(){

        return new RestTemplate();

    }

}

3.2 需要定义一个feign客户端接口

//value 是被调用服务名称,注册在eureka里的名称

@FeignClient(value ="member")

public interface MemberApiFeign {

//服务中方法的映射路径。照搬member 服务中的映射和方法,只是么有方法体

    @RequestMapping("/getMember")

    public String getMember();

}

3.3远程调用member 服务中的方法

@RestController

public class OrderApiController {

#RestTemplate方式需要注入上面方法中的bean

    @Autowired

    private RestTemplate restTemplate;

#feign 客户端方式,直接注入上面定义的接口

    @Autowired

    private MemberApiFeign memberApiFeign;

    @RequestMapping("/remote/member")

public String orderRemoteGetMember(){

        String url="http://member/getMember";//当使用ribbon 负载均衡调用微服务时,这里就可以直接 将ip和端口替换为注册的服务名

        String s = restTemplate.getForObject(url, String.class);

        System.out.println(s);

        return s;

    }

    @RequestMapping("/feign/remote")

    public String feignRemoteGetMember(){

        return memberApiFeign.getMember();

    }

}

你可能感兴趣的:(2019-06-12 两种rpc调用方式)