【微服务-Ribbon】如何通过代码方式实现Ribbon+RestTemplate的服务通信

前面我们了解了负载均衡的作用以及负载均衡的一些负载策略,这篇我们来看一下,在微服务(SpringCloud)架构中,如何来实现服务间的高可用通信。

我们先来了解下SpringCloud自带的RestTemplate对象,RestTemplate 对象是Spring Cloud 封装的 RESTful 通信对象,它封装了基于 HTTP 协议的操作,通过简单的API便可发起 HTTP 请求并自动处理响应。RestTemplate 天然与 Ribbon 兼容,两者配合可以极大简化服务间通信过程。Ribbon + RestTemplate 提供了两种开发模式:代码模式注解模式

下面我们来看一下两种开发模式的具体代码实现。

一、代码模式

代码模式是指通过纯 Java 代码实现微服务间通信,虽然工作中代码模式很少使用,但它却是理解 Ribbon+RestTemplate 最直观的途径,所以我们先来看他。该模式使用主要分为两个阶段:

1、创建服务提供者

服务提供者也就是请求的实际处理者,也是标准的springboot工程,利用controller对外暴露RESTful API供服务消费者调用。

(1)创建provider-service微服务

其中pom.xml要确保引用了web和nacos-discovery两个依赖。

<dependency>

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

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

</dependency>

<dependency>

    <groupId>com.alibaba.cloud</groupId>

    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>

</dependency>

(2)在application.yml中调整微服务与Nacos的通信配置

spring:

  application:

    name: provider-service #应用/微服务名字

  cloud:

    nacos:

      discovery:

        server-addr: 106.14.221.171:8848 #nacos服务器地址

        username: nacos #用户名密码

        password: nacos

server:

  port: 80

(3)创建ProviderController,通过controller控制器对外暴露接口

package com.example.providerservice.controller;

import org
  • 22
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我爱娃哈哈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值