美文网首页
2019-06-12 两种rpc调用方式

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

作者: zz云飞扬 | 来源:发表于2019-06-12 14:58 被阅读0次

1、pom文件

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

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

    <modelVersion>4.0.0</modelVersion>

    <parent>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-starter-parent</artifactId>

        <version>2.1.5.RELEASE</version>

        <relativePath/> <!-- lookup parent from repository -->

    </parent>

    <groupId>com.zbiti.zz</groupId>

    <artifactId>order</artifactId>

    <version>0.0.1-SNAPSHOT</version>

    <name>order</name>

    <description>Demo project for Spring Boot</description>

    <properties>

        <java.version>1.8</java.version>

        <spring-cloud.version>Greenwich.SR1</spring-cloud.version>

    </properties>

    <dependencies>

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-web</artifactId>

        </dependency>

        <dependency>

            <groupId>org.springframework.cloud</groupId>

            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>

        </dependency>

        <dependency>

            <groupId>org.springframework.cloud</groupId>

            <artifactId>spring-cloud-starter-feign</artifactId>

            <version>1.4.0.RELEASE</version>

        </dependency>

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-test</artifactId>

            <scope>test</scope>

        </dependency>

    </dependencies>

    <dependencyManagement>

        <dependencies>

            <dependency>

                <groupId>org.springframework.cloud</groupId>

                <artifactId>spring-cloud-dependencies</artifactId>

                <version>${spring-cloud.version}</version>

                <type>pom</type>

                <scope>import</scope>

            </dependency>

        </dependencies>

    </dependencyManagement>

    <build>

        <plugins>

            <plugin>

                <groupId>org.springframework.boot</groupId>

                <artifactId>spring-boot-maven-plugin</artifactId>

            </plugin>

        </plugins>

    </build>

</project>

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调用方式

    1、pom文件

  • 高性能异步RPC框架 kiss-rpc-flatbuffer介绍

    kiss-rpc特性: 轻量级,简单易用。支持idl和手动编写协议两种方式。模拟函数式调用方式,更加符合rpc远程...

  • Rpc Restful

    进程间通信方式主要有两种,一种是基于HTTP协议的RESTFul API方式,另一种则是RPC调用。RPC 可以基...

  • 微服务服务的调用方式

    服务之间是怎么通信的? 两种方式:rpc和http RPC远程服务调用,将请求序列化,通过网络传输,在接收端进行反...

  • golang-rpc

    参考 golang中的RPC调用服务器方法 golang rpc的两种调用方法 Go官方库RPC开发指南 示例 s...

  • SpringCloud微服务治理一(介绍,环境搭建,Eureka

    1.远程调用方式 了解一下微服务的调用方式 1.1.RPC RPC,即 Remote Procedure Call...

  • 【RPC | 远程调用】

    RPC,是一种远程调用方式(Remote Procedure Call),通过RPC我们可以像调用本地方法一样调用...

  • httpClient 表单提交通用模板

    Java Web中涉及大量的请求调用,常用的方式一般就是RPC和Http两种方式,本篇主要利用Apache的htt...

  • 接口规范想哪说哪

    java服务型RPC框架所选用的远程调用方式有两种风格:用jar包和纯REST方式。 jar包方式的好处是用了对方...

  • grpc原理

    RPC 框架原理 RPC 框架的目标就是让远程服务调用更加简单、透明,RPC 框架负责屏蔽底层的传输方式(TCP ...

网友评论

      本文标题:2019-06-12 两种rpc调用方式

      本文链接:https://www.haomeiwen.com/subject/thrlfctx.html