SpringCloud Alibaba(一) - Nacos 服务注册与发现,OpenFeign远程调用
1、基础项目过目介绍
1.1 数据库创建

1.2 项目模块分布

1.3 测试http接口调用
1.3.1 http接口调用配置类
//http接口调用配置类
@Configuration
public class RestTemplateConfig {
@Bean
//@LoadBalanced //支持注册中心使用服务名调用,并支持负载均衡
//第一次测试先不加 @LoadBalanced 注解
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
1.3.2 请求方法
@Slf4j
@RestController
public class KgcMallOrderController {
@Autowired
private RestTemplate restTemplate;
/**
* @author : zhukang
* @param : [java.lang.Integer, java.lang.Integer]
* @return : com.kgc.scda.bean.KgcMallOrder
* @description : 模拟用户下单
*/
@GetMapping("/createOrder")
public KgcMallOrder createOrder(@RequestParam Integer uid, @RequestParam Integer pid){
log.info("------ 用户编号:{},商品编号:{},模拟下单", uid, pid);
// 查询用户详情
KgcMallUser mallUser = restTemplate.getForObject("http://localhost:9602/mallUser?uid=" + uid, KgcMallUser.class);
// 查询商品详情
KgcMallProduct mallProduct = restTemplate.getForObject("http://localhost:9603/mallProduct?pid=" + pid, KgcMallProduct.class);
// 封装订单实体,入库
KgcMallOrder mallOrder = KgcMallOrder.builder()
.userId(mallUser.getId())
.userName(mallUser.getUserName())
.prodId(mallProduct.getId())
.prodName(mallProduct.getProdName())
.totalPrice(mallProduct.getProdPrice())
.build();
// 调用订单业务接口,插入订单
kgcMallOrderService.saveMallOrder(mallOrder);
log.info("------ 用户编号:{},商品编号:{},下单成功", uid, pid);
// 返回订单详情
return mallOrder;
}
}
1.3.3 测试结果

2、Nacos 服务注册与发现
2.1 单机 启动Nacos
startup.cmd -m standalone

2.2 登录nacoe界面
用户名:nacos
密码:nacos

2.3 服务注册 nacos依赖
<!-- nacos 依赖 三个服务都添加 -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
2.4 服务注册 配置
application.yml
# 服务到nacos注册中心
spring:
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
2.5 注解 @EnableDiscoveryClient
@EnableDiscoveryClient
2.6 测试http接口调用
2.6.0 查询服务注册情况

2.6.1 请求方法
//将站点请求换成,服务名请求(突然记得,负载均衡就是基于服务名请求作为基础的)
KgcMallUser mallUser = restTemplate.getForObject("http://kgcmall96-user/mallUser?uid=" + uid, KgcMallUser.class);
KgcMallProduct mallProduct = restTemplate.getForObject("http://kgcmall96-prod/mallProduct?pid=" + pid, KgcMallProduct.class);
2.6.1 直接 测试结果

2.6.2 添加 @LoadBalanced 注解

2.6.3 再次测试

2.6.4 再次使用 http通过站点+端口 路径请求
请求失败,说明使用 @LoadBalanced 注解后,RestTemplate 不能再使用站点+端口的方式请求。

3、OpenFeign
3.1 依赖
<!-- openfeign 远程调用 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>2.1.1.RELEASE</version>
</dependency>
3.2 注解
//基本用法跟feign 差不多
//主启动类上的注解:
@EnableFeignClients
//接口上的注解: 方法调用不再 赘述
@FeignClient(value = "kgcmall96-prod")
@FeignClient(value = "kgcmall96-user")
3.3 测试
测试方法不在赘述;

3.4 OpenFeign远程调用日志
3.4.1 全局日志
3.4.1.1 指定日志级别
# 指定日志级别,要配置在 远程调用的客户端,配合openFeign全局日志使用
logging:
level:
com.kgc.scda.service: debug
3.4.1.2 全局日志配置
/**
* Created On : 24/11/2022.
* <p>
* Author : huayu
* <p>
* Description: OpenFeign 全局日志配置类
*/
@Configuration //全局日志配置,如果使用@FeignClient(value = "kgcmall96-user",configuration = OpenFeignLogConfig.class)的局部日志,全局配置就不可以使用
public class OpenFeignLogConfig {
/**
* @author : huayu
* @date : 24/11/2022
* @param : []
* @return : feign.Logger.Level
* @description : openFeignLogLevel
*/
@Bean
public Logger.Level openFeignLogLevel(){
//适用于开发测试中,记录接口远程调用的全部日志
return Logger.Level.FULL;
}
}
3.4.3.3 测试

3.4.2 局部日志 注解方式
3.4.2.1 使用局部日志后,全局日志需要关闭

3.4.2.2 局部配置注解 (比较麻烦不推荐)
@FeignClient(value = "kgcmall96-user",configuration = OpenFeignLogConfig.class)
3.4.2.3 测试

3.4.3 局部日志 配置文件方式
3.4.3.1 application.yml配置
# 局部日志配置方式2:在核心配置文件中,指定局部远程调用服务的日志级别,不需要全局配置类的支持,实现@FiegnClient 只用局部日志解耦
# 顶格写
feign:
client:
config:
kgcmall96-prod:
loggerLevel: FULL
# kgcmall96-user:
# loggerLevel: FULL
3.4.3.2测试

SpringCloud Alibaba(一) - Nacos 服务注册与发现,OpenFeign远程调用的更多相关文章
- Spring Cloud Alibaba | Nacos服务注册与发现
目录 Spring Cloud Alibaba | Nacos服务注册与发现 1. 服务提供者 1.1 pom.xml项目依赖 1.2 配置文件application.yml 1.3 启动类Produ ...
- Spring Cloud Alibaba(一) 如何使用nacos服务注册和发现
Nacos介绍 Nacos 致力于帮助您发现.配置和管理微服务.Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现.服务配置.服务元数据及流量管理. Nacos 帮助您更敏捷和容易地构 ...
- Alibaba Nacos 学习(三):Spring Cloud Nacos Discovery - FeignClient,Nacos 服务注册与发现
Alibaba Nacos 学习(一):Nacos介绍与安装 Alibaba Nacos 学习(二):Spring Cloud Nacos Config Alibaba Nacos 学习(三):Spr ...
- Spring Cloud Alibaba Nacos 服务注册与发现功能实现!
Nacos 是 Spring Cloud Alibaba 中一个重要的组成部分,它提供了两个重要的功能:服务注册与发现和统一的配置中心功能. 服务注册与发现功能解决了微服务集群中,调用者和服务提供者连 ...
- 2021升级版微服务教程4—Nacos 服务注册和发现
2021升级版SpringCloud教程从入门到实战精通「H版&alibaba&链路追踪&日志&事务&锁」 默认文件1610014380163 教程全目录「含视 ...
- SpringCloud(二)- 服务注册与发现Eureka
离上一篇微服务的基本概念已经过去了几个月,在写那篇博客之前,自己还并未真正的使用微服务架构,很多理解还存在概念上.后面换了公司,新公司既用了SpringCloud也用了Dubbo+Zookeeper, ...
- 实战二:nacos服务注册与发现,openfeign服务调用
一,参照上一篇创建好微服务结构后,按业务需求编写各微服务逻辑 二,服务注册 1,安装nacos:下载,解压,运行startup.cmd 2,访问 http://localhost:8848/nacos ...
- Spring Cloud Alibaba 实战 之 Nacos 服务注册和发现
服务注册与发现,服务发现主要用于实现各个微服务实例的自动化注册与发现,是微服务治理的核心,学习 Spring Cloud Alibaba,首先要了解框架中的服务注册和发现组件——Nacos. 一.Sp ...
- nacos服务注册与发现原理解析
前言:nacos 玩过微服务的想必不会陌生,它是阿里对于springcloud孵化出来的产品,用来完成服务之间的注册发现和配置中心,其核心作用我就不废话了 大致流程:每个服务都会有一个nacos cl ...
- 微服务架构 | *3.5 Nacos 服务注册与发现的源码分析
目录 前言 1. 客户端注册进 Nacos 注册中心(客户端视角) 1.1 Spring Cloud 提供的规范标准 1.2 Nacos 的自动配置类 1.3 监听服务初始化事件 AbstractAu ...
随机推荐
- [解决方案] 几种通过 iproute2 来打通不同节点间容器网络的方式
几种通过 iproute2 来打通不同节点间容器网络的方式 几种通过 iproute2 来打通不同节点间容器网络的方式 host-gw ipip vxlan 背景 之前由于需要打通不同节点间的容器网络 ...
- pdf.js使用
百度上很多例子,都是构建之前的! 我们使用pdf.js,最终只需要构建后的内容,大家可以通过这里进行下载: https://pan.baidu.com/s/14J-m-jeHdvn46cPhPXk54 ...
- 基于Java+SpringBoot+Mysql实现的快递柜寄取快递系统功能实现五
一.前言介绍: 1.1 项目摘要 随着电子商务的迅猛发展和城市化进程的加快,快递业务量呈现出爆炸式增长的趋势.传统的快递寄取方式,如人工配送和定点领取,已经无法满足现代社会的快速.便捷需求.这些问题不 ...
- 浅析JVM内存结构和6大区域
内存作为系统中重要的资源,对于系统稳定运行和高效运行起到了关键的作用,Java和C之类的语言不同,不需要开发人员来分配内存和回收内存,而是由JVM来管理对象内存的分配以及对象内存的回收(又称为垃圾回收 ...
- Golang常见问题汇总
在开始使用golang的时候,经常会遇到各种问题,总结在此 1.unrecognized import path "golang.org/x/.. golang 在 github 上建立了一 ...
- 九、Spring Boot集成Spring Security之授权概述
目录 前言 一.授权概述 二.用户权限 三.用户授权流程 三.Spring Security授权方式 1.请求级别授权 2.方法级别授权 前言 本文介绍什么是授权,Spring Security的授权 ...
- 大语言模型中的MoE
1.概述 MoE代表"混合专家模型"(Mixture of Experts),这是一种架构设计,通过将不同的子模型(即专家)结合起来进行任务处理.与传统的模型相比,MoE结构能够动 ...
- 开源 - Ideal库 - Excel帮助类,ExcelHelper实现(四)
书接上回,前面章节已经实现Excel帮助类的第一步TableHeper的对象集合与DataTable相互转换功能,今天实现进入其第二步的核心功能ExcelHelper实现. 01.接口设计 下面我们根 ...
- CVE-2023-48409 Mali GPU 整数溢出导致堆越界写
CVE-2023-48409 Mali GPU 整数溢出导致堆越界写 https://github.com/0x36/Pixel_GPU_Exploit 漏洞原语:假设分配的大小为 0x3004, ...
- 清理docker logs
1,docker ps找到id [root@mysql3 /]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 1d8 ...