从零搭建一个SpringCloud项目之Feign搭建

简介:

从零搭建一个SpringCloud项目之Feign搭建

工程简述

目的:实现trade服务通过feign调用user服务的功能。因为trade服务会用到user里的一些类和接口,所以抽出了其他服务需要的东西到user-api工程。避免trade直接依赖user导致依赖多余的东西。

一、创建User接口工程user-api
新建一个module,取名为study-user-api
引入pom文件

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
</dependencies>

创建一个User实体类
编写一个UserApi接口,value里的study-user对应后面user实现工程的spring.application.name的值
@FeignClient(value = "study-user")
public interface UserApi {

@RequestMapping(value = "/getUserById",method = RequestMethod.GET)
User getUserById(Integer id);

}

二、创建User实现工程
创建一个module用于对user接口提供实现,项目名为study-user
加入pom依赖

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!--  本地依赖-->
    <dependency>
        <artifactId>study-user-api</artifactId>
        <groupId>com.mmc</groupId>
        <version>1.0-SNAPSHOT</version>
    </dependency>
</dependencies>

配置文件
server.port=8003

注册到eureka服务端的微服务名称

spring.application.name=study-user

注册到eureka服务端的地址

eureka.client.service-url.defaultZone=http://localhost:9000/eureka/

security.login.username=root
security.login.pass=123456789
eureka.client.service-url.defaultZone=http://${security.login.username}:${security.login.pass}@localhost:9000/eureka/

点击具体的微服务,是否显示ip

eureka.instance.prefer-ip-address=true
eureka.instance.instance-id=study-user-8003
写user接口实现,一个UserController
@RestController
@RequestMapping("/user")
public class UserController {

@RequestMapping("/getUserById")
public User getUserById(Integer id){
    User user = new User();
    user.setId(1);
    user.setName("小明");
    return user;
}

}
三、创建交易工程
新建一个module,项目名为study-trade
引入pom依赖

        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

    <!--  本地依赖-->
    <dependency>
        <artifactId>study-user-api</artifactId>
        <groupId>com.mmc</groupId>
        <version>1.0-SNAPSHOT</version>
    </dependency>

编写配置文件
server.port=8005

注册到eureka服务端的微服务名称

spring.application.name=study-trade

注册到eureka服务端的地址

eureka.client.service-url.defaultZone=http://localhost:9000/eureka/

security.login.username=root
security.login.pass=123456789
eureka.client.service-url.defaultZone=http://${security.login.username}:${security.login.pass}@localhost:9000/eureka/

点击具体的微服务,是否显示ip

eureka.instance.prefer-ip-address=true
eureka.instance.instance-id=study-trade-8005
写controller调用user服务
/**

  • @description:
  • @author: mmc
  • @create: 2020-04-05 11:41
    **/

@RestController
@RequestMapping("/trade")
public class TradeController {

@Autowired
private UserApi userApi;

@RequestMapping(value = "/testTrade/{userid}",method = RequestMethod.GET)
public String testTrade(@PathVariable Integer userid){
    User user= userApi.getUserById(userid);
    String name = user.getName();
    System.out.println("用户"+name+"下单成功....");
    return "用户"+name+"下单成功";
}

}

启动类配置启用feign注解
@SpringBootApplication
@EnableFeignClients(basePackages = "com.mmc.user")
public class TradeApplication {

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

}
测试
依次启动eureka Server,user工程,trade工程。输入网址测试

http://localhost:8005/trade/testTrade/1

github地址:https://github.com/mmcLine/spring-cloud-study

原文地址https://www.cnblogs.com/javammc/p/12638109.html

相关文章
|
1月前
|
SpringCloudAlibaba Java 网络架构
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(二)Rest微服务工程搭建
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(二)Rest微服务工程搭建
52 0
|
1月前
|
SpringCloudAlibaba Java 持续交付
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
【构建一套Spring Cloud项目的大概步骤】&【Springcloud Alibaba微服务分布式架构学习资料】
151 0
|
1月前
|
SpringCloudAlibaba Java 网络架构
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(七)Spring Cloud Gateway服务网关
99 0
|
1月前
|
消息中间件 JSON Java
Spring Boot、Spring Cloud与Spring Cloud Alibaba版本对应关系
Spring Boot、Spring Cloud与Spring Cloud Alibaba版本对应关系
553 0
|
2天前
|
Java Nacos 开发者
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
|
14天前
|
JSON 前端开发 Java
统一异常处理:让Spring Boot项目异常更优雅
统一异常处理:让Spring Boot项目异常更优雅
24 1
|
17天前
|
Nacos
SpringCloud Feign使用
SpringCloud Feign使用
23 1
|
24天前
|
开发框架 负载均衡 Java
Spring boot与Spring cloud之间的关系
总之,Spring Boot和Spring Cloud之间的关系是一种构建和扩展的关系,Spring Boot提供了基础,而Spring Cloud在此基础上提供了分布式系统和微服务架构所需的扩展和工具。
18 4
Spring boot与Spring cloud之间的关系
|
1月前
|
SpringCloudAlibaba 负载均衡 Java
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(目录大纲)
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(目录大纲)
65 1
|
1月前
|
Java Nacos Sentinel
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(九)Nacos+Sentinel+Seata
201 0