广告
返回顶部
首页 > 资讯 > 后端开发 > Python >SpringCloud如何使用Eureka实现服务之间的传递数据
  • 756
分享到

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

2024-04-02 19:04:59 756人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

相信大家最关心的肯定不是什么一大堆的破理论,然后还似懂非懂的,最关心得莫过于服务之间的参数传递,数据获取。 Ok,今天就告诉大家三种微服务之间传输数据的方式,分别是: 1、最基本的利

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

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;
 
    
    @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;
 

public class HtystrixEurekaFallback implements EurekaServiceApi {
    @Override
    public String test() {
        return "连接失败,请稍后再试!";
    }
}

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: SpringCloud如何使用Eureka实现服务之间的传递数据

本文链接: https://www.lsjlt.com/news/127923.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SpringCloud如何使用Eureka实现服务之间的传递数据
    相信大家最关心的肯定不是什么一大堆的破理论,然后还似懂非懂的,最关心得莫过于服务之间的参数传递,数据获取。 Ok,今天就告诉大家三种微服务之间传输数据的方式,分别是: 1、最基本的利...
    99+
    2022-11-12
  • 怎么在SpringCloud中使用Eureka实现服务之间的传递数据
    这期内容当中小编将会给大家带来有关怎么在SpringCloud中使用Eureka实现服务之间的传递数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、使用RestTemplate+Ip方式:1、传递数据...
    99+
    2023-06-15
  • SpringCloud网关(Zuul)如何给多个微服务之间传递共享参数
    目录1、使用场景解决方案1解决方案22、代码实现3、成果展现4、总结1、使用场景 因为最近项目需要国际化,但是以前国际化的语言切换是放置在未进行微服务化之前的一个独立的SpringB...
    99+
    2022-11-13
  • Android应用中怎么实现Activity之间的数据传递
    本篇文章为大家展示了Android应用中怎么实现Activity之间的数据传递,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。MainActivitypublic class MainActivity...
    99+
    2023-05-31
    android roi activity
  • 【使用multipart/form-data方式传递MultipartFile参数,实现服务间文件的传递】
    目录 一、代码实现二、MultipartFile工具类三、HttpClient使用四、参考链接 一、代码实现 1、A服务接收前端上传文件并发送至B服务 引入依赖 org.apa...
    99+
    2023-09-06
    前端 java
  • HTML5中如何使用postMessage实现两个网页间传递数据
    本篇内容主要讲解“HTML5中如何使用postMessage实现两个网页间传递数据”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML5中如何使用postMe...
    99+
    2022-10-19
  • 如何使用UniApp传递数据到服务器
    UniApp是一款开发跨平台应用的框架,使用它可以快速地开发出同时在不同平台上工作的应用程序。在应用程序中,我们经常需要向服务器传递数据,这里我们介绍如何使用UniApp传递数据到服务器。一、UniApp发送网络请求UniApp提供了一个A...
    99+
    2023-05-14
  • ASP中如何使用数组传递给接口并实现数据交互?
    在ASP开发中,我们经常需要将数据传递给后端接口进行处理。而在某些场景下,我们需要传递的数据不是单个变量,而是一个数组。那么,在ASP中如何使用数组传递给接口并实现数据交互呢?本文将为大家详细介绍。 一、ASP中数组的基本概念 在ASP中...
    99+
    2023-07-31
    数组 打包 接口
  • 如何在springcloud中使用bytetcc实现数据的强一致性
    今天就跟大家聊聊有关如何在springcloud中使用bytetcc实现数据的强一致性,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1 使用背景和约束公司使用的是springclou...
    99+
    2023-06-06
  • 如何使用nodeJS实现一个mock数据服务器
    这篇文章主要介绍如何使用nodeJS实现一个mock数据服务器,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!对于前端开发者而言,javascript正扮演着越来越重要的地位,它不仅能...
    99+
    2022-10-19
  • 如何使用MongoDB实现数据的时间序列分析功能
    如何使用MongoDB实现数据的时间序列分析功能引言:随着大数据时代的到来,时间序列分析越来越受到人们的关注和重视。在众多时间序列分析工具中,MongoDB因其高性能、易扩展和灵活性等特点成为了热门选择。本文将介绍在MongoDB中如何实现...
    99+
    2023-10-22
    MongoDB 时间序列分析
  • 分布式系统中如何使用ASP.NET实现高效的数据传输?
    在现代互联网应用中,数据传输是一个关键的问题。随着网络带宽的增加,数据传输的速度也得到了显著的提升。然而,对于分布式系统而言,数据传输仍然是一个需要考虑的关键问题。本文将介绍如何使用ASP.NET实现高效的数据传输,以满足分布式系统的需求...
    99+
    2023-10-22
    leetcode 分布式 unix
  • 数据库中如何实现查询表空间使用情况的脚本
    这篇文章将为大家详细讲解有关数据库中如何实现查询表空间使用情况的脚本,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。脚本如下:Select Distinct a....
    99+
    2022-10-18
  • 如何使用python实现时间序列预测中的数据滑窗操作
    这篇文章主要为大家展示了“如何使用python实现时间序列预测中的数据滑窗操作”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用python实现时间序列预测中的数据滑窗操作”这篇文章吧。撰写...
    99+
    2023-06-29
  • 了解如何使用容器在Go、Laravel和NumPy之间进行数据交换的最佳实践?
    引言: 在软件开发中,数据交换一直是一个非常重要的话题。在不同的编程语言和框架之间进行数据交换,往往需要花费大量的精力和时间。但是,使用容器可以大大简化数据交换的过程,使得不同的编程语言和框架之间的数据交换变得更加容易。本文将介绍如何使用容...
    99+
    2023-08-23
    laravel 容器 numpy
  • 如何使用PHP微服务实现分布式数据存储和检索
    引言:随着互联网技术的不断发展,数据的规模也在迅速增长。传统的数据存储和检索方式往往面临着各种限制,例如单机存储容量限制、性能瓶颈、单点故障等等。为了解决这些问题,微服务架构逐渐兴起,并逐渐应用于各个领域。本文将介绍如何使用PHP微服务来实...
    99+
    2023-10-21
    数据检索 PHP微服务 分布式数据存储
  • 分布式系统中如何使用Java关键字和API实现高效的数据传输?
    随着互联网技术的不断发展,分布式系统越来越受到人们的关注。在分布式系统中,数据传输是一个非常重要的问题。而Java作为一种广泛应用于分布式系统的编程语言,其关键字和API可以帮助我们实现高效的数据传输。本文将从以下三个方面来探讨如何使用J...
    99+
    2023-10-23
    关键字 分布式 api
  • 如何用两台服务器实现数据库的主从同步与分离
    这期内容当中小编将会给大家带来有关如何用两台服务器实现数据库的主从同步与分离,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。使用背景:在网联网不断发展的时代,人们对数据的使...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作