SpringCloud如何使用Eureka实现服务之间的传递数据

作者:IT界刘德华 时间:2022-02-17 18:47:37 

相信大家最关心的肯定不是什么一大堆的破理论,然后还似懂非懂的,最关心得莫过于服务之间的参数传递,数据获取。

Ok,今天就告诉大家三种微服务之间传输数据的方式,分别是:

1、最基本的利用Ip端口进行请求访问接口实现数据的传输

2、使用Eureka取代Ip(硬编码)的方式实现数据的传输

3、使用Feign更加快捷"分服务"的方式实现微服务之间的数据传输(对Feign一点不了解的暂时不用理解,就是SpringCloud的组成的一部分后期会进行详细讲解,在此处讲解只是为自己mark一下)

前提:搭建好Eureka注册中心,假设现在有一个订单微服务(服务消费者),一个用户微服务(服务提供者),然后需要订单微服务调用用户微服务,获取用户的信息,并且两个服务都能正常运行,为了方便此处使用SpringJpa的方式获取数据。

一、使用RestTemplate+Ip方式:

1、传递数据大部分就是以集合和对象的形式进行传递,所以在这里就用集合和对象的方式为例

在用户微服务(服务提供者)中写好被调用的查询方法


@RestController
@RequestMapping("/user")
public class UserController {

@Resource
   private UserRepository userRepository;

@GetMapping("/getallUser")
   public List<User> getUserPage(){
       return userRepository.findAll();
   }

@GetMapping("/getUser")
   public User getUser(Long userId){
       return userRepository.getOne(userId);
   }
}

@Repository
public interface UserRepository extends JpaRepository<User,Long> {
}

@Entity
@Table(name="TM_USER")
@JsonIgnoreProperties(value={"hibernateLazyInitializer","handler","fieldHandler"})
public class User implements Serializable, Cloneable {

@Id
   @GeneratedValue(strategy= GenerationType.AUTO)
   private Long userId;

/**
    * 登录名
    */
   @Column(name = "USER_NAME")
   private String userName;

/**
    * 用户名
    */
   @Column
   private String name;

/**
    * 薪水
    */
   @Column
   private BigDecimal balance;

/**
    * 年龄  get set方法已省略 自行添加
    */
   @Column
   private int age;}

Ok,服务提供者已经写好,下面开始编写服务消费者

2、在订单微服务(服务消费者)的启动类中添加生成RestTemplate的Bean


@SpringBootApplication
@EnableEurekaClient  //启用eureka客户端
public class MicroserviceSimplecConsumerOrderServerApplication {

@Bean
public RestTemplate restTemplate(){
 return new RestTemplate();
}

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

在订单微服务(服务消费者)配置文件yml中添加,其中localhost:9021改为用户微服务(服务提供者的Ip和端口)


user:
 urlPath: http://localhost:9021

订单服务控制层编写,此处的User为用户微服务的复制然后去掉@Column、@Table等注释只是一个临时存储对象和数据库没有任何关联


@RestController
@RequestMapping("/order")
public class OrderServerController {

@Autowired
   private RestTemplate restTemplate;

@Value("${user.urlPath}")
   private String urlPath;
   //获取集合方式
   @GetMapping("/allUser")
   private List<User> getAllUser(){
       ResponseEntity<List<User>> responseEntity = restTemplate.exchange("urlPath"+/user/getallUser?",
               HttpMethod.GET, null, new ParameterizedTypeReference<List<User>>() {});
       return responseEntity.getBody();
   }
   //获取单个对象方式
   @GetMapping("/getUser")
   private User getUser(Long userId){
       User user = restTemplate.getForObject("urlPath"+/user/getUser?userId="+userId,User.class);
       return user;
   }
}

二、使用Eureka的方式获取

很简单就是直接把订单微服务(服务消费者)OrderServerController中的userPath替换为注册Eureka上面的服务名即可就是这么简单。假设用户微服务的服务名为:microservice-privider-user


spring:
 application:
   name: microservice-privider-user

然后就可以直接进行替换处理,即:


@GetMapping("/allUser")  //返回集合
  private List<User> getAllUser(){
       ResponseEntity<List<User>> responseEntity = restTemplate.exchange("microservice-privider-user"+"/user/getallUser", HttpMethod.GET, null, new ParameterizedTypeReference<List<User>>() {});
       return responseEntity.getBody();
   }
//返回对象
   @GetMapping("/getUser")
   private User getUser(Long userId){
       User user = restTemplate.getForObject("microservice-privider-user"+/user/getUser?userId="+userId,User.class);
       return user;
   }

Ok,使用第二种方式已经编写完成

使用服务名替换了固定的ip,解决了Ip硬编码不容易维护的问题

至于第三种Feign的方式会在以后讲解“Feign:声明性Rest客户端”的时候进行详细讲解

gitHub地址:https://github.com/mackjie/microservice-spring-cloud因为配置了RabbitMQ,所以请先阅读ReadMe然后进行启动项目,否则会启动报错

springcloud学习之Eureka Client搭建和服务间调用

Eureka Client搭建:

一、引入pom依赖


<!-- Eureka Client -->
<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

二、启动类推荐添加@EnableEurekaClient注解

就是如果选用的注册中心是eureka,那么就推荐@EnableEurekaClient,

如果是其他的注册中心(zookeeper,consul等),那么推荐使用@EnableDiscoveryClient。

三、配置文件添加:


#eureka
spring.application.name=producer
#注册中心地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
#是否把自己注册
eureka.client.register-with-eureka=true
#是否搜索服务信息
eureka.client.fetch-registry=true

#使用ip地址注册
eureka.instance.prefer-ip-address=true
#注册中心列表显示的状态
eureka.instance.instance-id=${spring.cloud.client.ip-address}:${server.port}

服务调用:

有两种方式:

一、ribbon(负载均衡)+restTemplate

启动类添加:


@Bean
@LoadBalanced//负载均衡
public RestTemplate initRestTemplate() {
return new RestTemplate();//
}

@Bean//负载均衡的规则,下面的是其中之一:随机,还有权重,轮询等
public IRule initIRule() {
 return new RandomRule();
}

RandomRule表示随机策略

RoundRobinRule表示轮询策略(默认)

WeightedResponseTimeRule表示加权策略

BestAvailableRule表示请求数最少策略

然后在controller中自动装配RestTemplate后使用 restTemplate.getForObject()调用。

二、feign(推荐)

1、引入pom依赖


<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-openfeign</artifactId>
   <version>2.1.1.RELEASE</version>
</dependency>

2、启动类添加@EnableFeignClients注解

3、创建一个接口,


package com.sumengnan.test.web;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

@FeignClient(name = "eureka",fallback = HtystrixEurekaFallback.class)//调用失败后回滚执行方法
public interface EurekaServiceApi {
   @GetMapping("test")
   String test();
}

回滚的方法:


package com.sumengnan.test.web;

/**
* eureka熔断回调类
*/
public class HtystrixEurekaFallback implements EurekaServiceApi {
   @Override
   public String test() {
       return "连接失败,请稍后再试!";
   }
}

4、然后在controller中自动装配EurekaServiceApi后使用eurekaServiceApi.test()调用。

来源:https://blog.csdn.net/qq_31150503/article/details/79919563

标签:SpringCloud,Eureka,传递,数据
0
投稿

猜你喜欢

  • Java中ArrayList集合的常用方法大全

    2023-09-01 15:23:30
  • Java的关键字与保留字小结

    2021-05-30 10:20:50
  • Java和C++通过new创建的对象有何区别?

    2022-02-07 10:06:10
  • Java中Validated、Valid 、Validator区别详解

    2023-11-11 13:53:31
  • 手把手带你了解Java-Stream流方法学习及总结

    2023-11-25 19:30:15
  • 详解Maven私 服Nexus的安装与使用

    2023-11-24 12:34:02
  • IDEA配置使用Maven Helper插件的方法(详细配置)

    2022-07-17 03:09:21
  • eclipse中maven插件安装教程

    2023-06-23 17:08:23
  • java 非常好用的反射框架Reflections介绍

    2022-11-25 01:25:52
  • Java面试synchronized偏向锁后hashcode存址

    2023-08-09 09:15:06
  • java实现代码统计小程序

    2022-03-08 23:15:24
  • Java应用开源框架实现简易web搜索引擎

    2023-08-22 20:20:54
  • Flutter 使用fluro的转场动画进行页面切换

    2023-06-17 11:49:26
  • Spring Boot学习入门之AOP处理请求详解

    2023-11-27 10:55:17
  • java10下编译lombok注解代码分享

    2023-06-06 11:02:35
  • 详解Spring MVC CORS 跨域

    2023-11-25 08:04:37
  • 浅谈virtual、abstract方法和静态方法、静态变量理解

    2022-08-29 02:29:14
  • Mapper批量插入Oracle数据@InsertProvider注解

    2023-02-11 15:13:40
  • C++ Cmake的构建静态库和动态库详解

    2023-06-28 08:28:15
  • 详解springboot和vue前后端分离开发跨域登陆问题

    2023-08-07 00:48:38
  • asp之家 软件编程 m.aspxhome.com