news 2026/3/23 3:34:53

Nacos+OpenFeign-----帮助解决单体项目拆分成微服务项目的关键技术

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Nacos+OpenFeign-----帮助解决单体项目拆分成微服务项目的关键技术

目录

为什么需要这么个东西,他解决了什么痛点?

方法一 RestTemplate:

引入概念:注册中心:

方法二 nacos服务:

其他


为什么需要这么个东西,他解决了什么痛点?

我们在初始学习微服务时候,会拆分单体项目。会遇到这么一个问题:“远程调用问题:我这个微服务,要用到另一个微服务的一个service,在单体项目中,直接注入一个service用就可以。但微服务代码数据库都是分开的,在微服务中有没有什么好方法?”

方法一RestTemplate

RestTemplate,由spring提供,可以方便的发送Http请求。

用法:创一个RestTemplate并注入容器,用的时候注入,并调用其exchange方法。(还有很多其他方法,可以查阅了解,不做详细介绍)
缺点:服务的治理问题:url是写死的。如果A想调用B的某个接口,但B有多个服务部署了,不是道调用哪一个。而且如果一个B服务挂掉了,或者新的B服务启动了,A都不知道,没法处理。

引入概念:注册中心:

既然有这个缺点,我们能不能找个中间人?就像找家政一样,我们就让A不要去直接找B,而是找“家政中心”,有啥事你去找“家政中心”,他里面管理了B的各个服务的信息。(也就是注册中心)

当A找上门来,注册中心就去看看那个阿姨有空。安排给你提供服务。(也就是负载均衡)

当B某个服务新增或者挂掉了,能及时反映给“家政中心”。(也就是心跳续约)

方法二 nacos服务:

注册nacos服务:

1: 数据库中创建nacos表,方便存储。

2:docker部署nacos容器。

服务治理:

  • 服务注册:引入nacos discovery依赖,配置Nacos地址。
  • 服务发现:引入nacos discovery依赖,配置Nacos地址。然后调用,传入参数(手写负 载均衡)。

问题:服务发现手写比较麻烦。

OpenFeign:

  • 引入依赖,OpenFeign和SpringCloudLoadBalancer。
  • 通过@EnableFeiClients,开启OpenFeign功能。
  • 编写FeignClient。@FeignClient("item-service"):声明服务名称@GetMapping:声明请求方式@GetMapping("/items"):声明请求路径@RequestParam("ids") Collection<Long> ids:声明请求参数List<ItemDTO>:返回值类型
@FeignClient("item-service") public interface ItemClient { @GetMapping("/items") List<ItemDTO> queryItemByIds(@RequestParam("ids") Collection<Long> ids); }
  • 使用FeignClient。注入对应的client类,然后调用对应的方法。

其他

日志配置:省略。

开启连接池:

  • 引入连接池依赖
  • feign: okhttp: enabled: true # 开启OKHttp功能

client类实现在A中,不合理,代码重复率高,两种抽取思路:

  • 思路1:抽取到微服务之外的公共module

  • 思路2:每个微服务自己抽取一个module

  • 实现:1.引入对应的依赖坐标。2. @EnableFeignClient扫描到对应的包。com.hmall.api.client

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/21 1:57:08

YOLO训练时GPU显存不足怎么办?

YOLO训练时GPU显存不足怎么办&#xff1f; 在部署一个工业质检项目时&#xff0c;团队卡在了最基础的环节&#xff1a;YOLO模型刚一启动训练&#xff0c;就抛出 CUDA out of memory 错误。设备是单张RTX 3080&#xff08;10GB显存&#xff09;&#xff0c;数据集为640640分辨率…

作者头像 李华
网站建设 2026/3/15 23:17:30

开源界的ChatGPT平替?LobeChat真实使用感受分享

开源界的ChatGPT平替&#xff1f;LobeChat真实使用感受分享 在大模型应用遍地开花的今天&#xff0c;越来越多开发者不再满足于调用OpenAI的API做简单问答。我们更想要一个能真正掌控、可定制、够安全的“私人AI助手”——既能连自家部署的LLaMA 3&#xff0c;又能接入通义千问…

作者头像 李华
网站建设 2026/3/19 15:41:26

基于西门子PLC1200的钢板恒张力放卷收卷系统大揭秘

基于西门子PLC1200的钢板恒张力放卷收卷系统&#xff0c;一共有6种不同的要求&#xff0c;自己注意仔细甄别&#xff0c;防止交错在工业生产中&#xff0c;钢板的放卷与收卷过程保持恒张力至关重要&#xff0c;这直接影响到产品的质量与生产效率。西门子PLC1200凭借其强大的功能…

作者头像 李华
网站建设 2026/3/15 23:17:27

如何通过LangFlow降低AI开发门槛?一文读懂

如何通过 LangFlow 降低 AI 开发门槛&#xff1f; 在大模型技术席卷各行各业的今天&#xff0c;越来越多团队开始尝试构建基于大语言模型&#xff08;LLM&#xff09;的应用——从智能客服到知识库问答&#xff0c;从自动化报告生成到个性化推荐系统。然而&#xff0c;现实往往…

作者头像 李华
网站建设 2026/3/19 7:01:32

深度学习环境搭建指南:TensorFlow + 清华源 + Docker

深度学习环境搭建新范式&#xff1a;TensorFlow 清华源 Docker 在人工智能项目落地的过程中&#xff0c;最让人头疼的往往不是模型设计本身&#xff0c;而是“为什么代码在我机器上能跑&#xff0c;在服务器却报错&#xff1f;”——这个看似简单的问题背后&#xff0c;是依…

作者头像 李华
网站建设 2026/3/21 5:57:31

Qwen3-32B Docker镜像5分钟快速部署指南

Qwen3-32B Docker镜像5分钟快速部署指南 在智能研发工具逐渐成为标配的今天&#xff0c;你有没有遇到过这样的窘境&#xff1a;团队急需一个能读文档、写代码、解释复杂逻辑的AI助手&#xff0c;结果试了一圈开源模型&#xff0c;不是“上下文一长就失忆”&#xff0c;就是“连…

作者头像 李华