Spring Cloud 学习系列:(七)实现声明式 RESTful 风格服务调用——Feign

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

spring:

application:

name: microservice-provider-service-hi

eureka:

client:

service-url:

defaultZone: http://localhost:8761/eureka/

3、建立一个服务消费者

(1)、pom.xml 继承父 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 https://maven.apache.org/xsd/maven-4.0.0.xsd”>

4.0.0

com.riemann

microservice-eureka-feign

0.0.1-SNAPSHOT

com.riemann

microservice-provider-service-feign

0.0.1-SNAPSHOT

jar

microservice-provider-service-feign

Eureka Feign Client

org.springframework.cloud

spring-cloud-starter-netflix-eureka-client

org.springframework.boot

spring-boot-starter-web

org.springframework.cloud

spring-cloud-starter-openfeign

(2)、在工程的配置文件指定服务的注册中心地址为http://localhost:8761/eureka/,程序名称为 microservice-provider-service-feign,程序端口为8763。application.yml 如下:

server:

port: 8763

spring:

application:

name: microservice-provider-service-feign

eureka:

client:

service-url:

defaultZone: http://localhost:8761/eureka/

(3)、在程序的启动类 MicroserviceProviderServiceFeignApplication,加上@EnableFeignClients 注解开启 Feign 的功能

package com.riemann.microserviceproviderservicehi;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;

import org.springframework.cloud.netflix.eureka.EnableEurekaClient;

import org.springframework.cloud.openfeign.EnableFeignClients;

import org.springframework.context.annotation.Bean;

import org.springframework.web.client.RestTemplate;

@SpringBootApplication

@EnableEurekaClient

@EnableDiscoveryClient

@EnableFeignClients

public class MicroserviceProviderServiceFeignApplication {

public static void main(String[] args) {

SpringApplication.run(MicroserviceProviderServiceFeignApplication.class, args);

}

}

(4)、定义一个 Feign 接口,通过 @FeignClient(“服务名”),来指定调用哪个服务。比如在代码中调用了 microservice-provider-service-hi 服务的“/hi”接口,代码如下:

package com.riemann.microserviceproviderservicehi.client;

import org.springframework.cloud.openfeign.FeignClient;

import org.springframework.stereotype.Service;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestMethod;

import org.springframework.web.bind.annotation.RequestParam;

@FeignClient(value = “microservice-provider-service-hi”)

public interface FeignClientServiceHi {

@RequestMapping(value = “/hi”,method = RequestMethod.GET)

String sayHiFromFeignClient(@RequestParam(value = “name”) String name);

}

(5)、在 controller 层,对外暴露一个"/hi"的 API 接口,通过上面定义的 Feign 客户端FeignClientServiceHi 来消费服务。代码如下:

package com.riemann.microserviceproviderservicehi;

import org.springframework.boot.SpringApplication;

最后

总而言之,面试官问来问去,问的那些Redis知识点也就这么多吧,复习的不够到位,知识点掌握不够熟练,所以面试才会卡壳。将这些Redis面试知识解析以及我整理的一些学习笔记分享出来给大家参考学习

还有更多学习笔记面试资料也分享如下:

都是“Redis惹的祸”,害我差点挂在美团三面,真是“虚惊一场”

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
mg-OPqXJ3Mg-1713426393549)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-nJTgoKhH-1713426393549)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 25
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值