三、谷粒商城- Spring Cloud Alibaba(3)
🌻🌻 目录 🌻🌻
- 一、SpringCloud Alibaba
- 1.1、SpringCloud Alibaba 简介
- 1.2、SpringCloud Alibaba-Nacos[作为注册中心]
- 1.2.1 将微服务注册到 nacos 中
- 1.2.2 服务注册到 nacos,远程调用
- 1.3、SpringCloud Alibaba-Nacos[作为配置中心]
- 1.4、nacos 进阶
- 1.4.1、核心概念
- 1.4.2、加载多配置文件
- 1.5、网关 Gateway
- 1.5.1、简介
- 1.5.2、核心概念
- 1.5.3、使用
一、SpringCloud Alibaba

1.1、SpringCloud Alibaba 简介
1)、简介
Spring Cloud Alibaba致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

- 依托
Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。

- 官网:https://spring.io/projects/spring-cloud-alibaba
- 社区:https://sca.aliyun.com/
- SpringCloud Alibaba github:https://github.com/alibaba/spring-cloud-alibaba

2)、为什么使用


SpringCloud的几大痛点
SpringCloud部分组件停止维护和更新,给开发带来不便;SpringCloud部分环境搭建复杂,没有完善的可视化界面,我们需要大量的二次开发和定制SpringCloud配置复杂,难以上手,部分配置差别难以区分和合理应用
SpringCloud Alibaba的优势:
- 阿里使用过的组件经历了考验,性能强悍,设计合理,现在开源出来大家用
成套的产品搭配完善的可视化界面给开发运维带来极大的便利,搭建简单,学习曲线低。
结合 SpringCloud Alibaba 我们最终的技术搭配方案:
- SpringCloud Alibaba - Nacos:注册中心(服务发现/注册)
- SpringCloud Alibaba - Nacos:配置中心(动态配置管理)
- SpringCloud - Ribbon:负载均衡
- SpringCloud - Feign:声明式 HTTP 客户端(调用远程服务)
- SpringCloud Alibaba - Sentinel:服务容错(限流、降级、熔断)
- SpringCloud - Gateway:API 网关(webflux 编程模式)
- SpringCloud - Sleuth:调用链监控
- SpringCloud Alibaba - Seata:原 Fescar,即分布式事务解决方案
3)、版本选择
- 由于
Spring Boot 1和Spring Boot 2在Actuator模块的接口和注解有很大的变更,且spring-cloud-commons从1.x.x版本升级到2.0.0版本也有较大的变更,因此我们采取跟SpringBoot版本号一致的版本:
版本适配:如何构建

- ◼ 1.5.x 版本适用于
Spring Boot 1.5.x- ◼ 2.0.x 版本适用于
Spring Boot 2.0.x- ◼ 2.1.x 版本适用于
Spring Boot 2.1.x
4)、项目中的依赖
- 在
common项目中引入如下。进行统一管理

在 common 项目中引入如下。进行统一管理
<dependencyManagement><dependencies><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.0.RELEASE</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>
1.2、SpringCloud Alibaba-Nacos[作为注册中心]
Nacos是阿里巴巴开源的一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。他是使用java编写。需要依赖 java 环境
Nacos 文档地址: https://nacos.io/zh-cn/docs/quick-start.html
1.2.1 将微服务注册到 nacos 中
应用接入: https://github.com/alibaba/spring-cloud-alibaba/




- 1、首先,打开
gulimall-common修改pom.xml文件,引入 Nacos Discovery Starter。

<!--服务发现-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
- 2、官网下载 nacos-server
- https://github.com/alibaba/nacos/releases 或 https://nacos.io/download
- 本地资源库获取

双击startup.cmd直接启动 :

在浏览器访问:http://127.0.0.1:8848/nacos 用户名/密码 都是nacos

- 3、在应用的
/src/main/resources/application.yml配置文
件中配置 Nacos Server 地址

spring:cloud:nacos:server-addr: 127.0.0.1:8848
- 4、使用
@EnableDiscoveryClient开启服务注册发现功能

@EnableDiscoveryClient //需要注册的这里都要加上去,如下的 gulimall-member,gulimall-order
@SpringBootApplication
public class GulimallCouponApplication {public static void main(String[] args) {SpringApplication.run(GulimallCouponApplication.class, args);}
}
为其余都添加上:

- 5、在应用的 /src/main/resources/application.properties 配置文
件中配置 Nacos Server 地址

#注意:每一个应用都应该有名字,这样才能注册上去。修改 application.yml 文件
#需要注册的都要配置
spring:application:name: gulimall-coupon
- 为其余都添加上:
application.yml

- 6、在
idea中启动应用,观察nacos服务列表是否已经注册上服务

- 7、启动
nacos-server- ◼ 双击
bin中的startup.cmd文件- ◼ 访问
http://localhost:8848/nacos/- ◼ 使用默认的
nacos/nacos进行登录

1.2.2 服务注册到 nacos,远程调用
注册更多的服务上去,测试使用 feign 远程调用
- Feign 使用三步
1、导包 openfeign
2、编写接口,进行远程调用
3、开启@EnableFeignClients 功能
- 1、导包 openfeign(
前面已经引入了)

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
- 2、编写接口,进行远程调用

//2.远程服务
@RequestMapping("/member/list")
public R couponmember(){CouponEntity couponEntity = new CouponEntity();couponEntity.setCouponName("优惠券满减,满200减100");return R.ok().put("coupons", Arrays.asList(couponEntity));
}
创建接口:

package com.gansu.gulimall.member.feign;import com.gansu.common.utils.R;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;@FeignClient("gulimall-coupon")
public interface CouponFeignService {//2.远程服务@RequestMapping("copupon/coupon/member/list")public R couponmember();
}
- 3、开启@
EnableFeignClients功能

//开启远程调用功能
@EnableFeignClients(basePackages = "com.gansu.gulimall.member.feign")
- 4、测试(启动服务,访问:
http://localhost:8000/member/member/coupons)

@Autowired
private CouponFeignService couponFeignService;@RequestMapping("/coupons")
public R test(){MemberEntity memberEntity = new MemberEntity();memberEntity.setNickname("张三");R couponmember = couponFeignService.couponmember();return R.ok().put("member",memberEntity).put("coupons",couponmember.get("coupons"));
}

- 4、测试(关闭(类似挂掉)服务
gulimall-coupon,再次访问:http://localhost:8000/member/member/coupons)


- 6、更多配置
https://github.com/alibaba/spring-cloud-alibaba/blob/master/spring-cloud-alibaba-examples/nacos-example/nacos-discovery-example/readme-zh.md#more
1.3、SpringCloud Alibaba-Nacos[作为配置中心]
参考 官网文档:

- 1、pom.xml 引入 Nacos Config Starter。

<!--服务注册-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
- 2、在应用的 /src/main/resources/
bootstrap.properties配置文件中配置Nacos Config元数据

spring.application.name=nacos-config-example
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
#主要配置应用名和配置中心地址
- 3.1 之前是这样配置的:

coupon.user.name=Daniel
coupon.user.age=22
- 3.2 有了nacos现在就直接在界面添加了:
- ① 创建配置

- ② 发布创建修改的配置

- 测试:动态获取配置(刷新配置)

@RefreshScope
/*** 1、如何使用Nases作为配置中心统一管理配置* 1)引入依赖,* <!--服务注册-->* <dependency>* <groupId>com.alibaba.cloud</groupId>* <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>* </dependency>* 2)创建-个bootstrap.properties。* spring.application.name=nacos-config-example* spring.cloud.nacos.config.server-addr=127.0.0.1:8848* 3)需要给配置中心默认添加一个叫 数据集(Data Id)gulimall-coupon.properties。默认规则,应用名.properti给 应用名.properties 添加任何配置* 4)动态获取配置。* @Refreshscope:动态获取并刷新配置@Value("${配置项的名}"):获取到配置。如果配置中心和当前应用的配置文件中都配置了相同的项,优先使用配置中心的配置。*/@Value("${coupon.user.name}")
private String name;
@Value("${coupon.user.age}")
private Integer age;
@RequestMapping("/test")
public R test(){return R.ok().put("name",name).put("age",age);
};
5.启动服务,修改配置参数再次查看显示
http://localhost:7000/copupon/coupon/test


再次查看你:

1.4、nacos 进阶
1.4.1、核心概念
命名空间:
- 用于进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的
Group或Data ID的
配置。Namespace的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生
产环境的资源(如配置、服务)隔离等。
*1)、命名空间:配置隔离;*默认:public(保留空间);默认新增的所有配置都在public空间。*1、开发,测试,生产:利用命名空间来做环境隔离。注意:在bootstrap.properties;配置上,需要使用哪个命名空间下的配置,spring.cloud.nacos.config.namespace=df5f3ec1-ff43-4e4b-8748-89a26557dc1f*2、每一个微服务之间互相隔离配置,每一个微服务都创建自己的命名空间,只加载自己命名空间下的所有配置
① 查看默认的命名空间(2.4.2这里不显示默认的,建议用之前的1.1.3)

② 添加命名空间 (dev:开发命名空间,prod:生产命名空间)

③ 切换到命名空间 dev,并且在命名空间dev下面创建配置,如下所示:
dev:开发命名空间,prod:生产命名空间


④ 在idea中 bootstrap.properties中添加配置

⑤ 重启服务浏览器查看
http://localhost:7000/copupon/coupon/test

配置集 ID:
Nacos 中的某个配置集的 ID。配置集 ID 是组织划分配置的维度之一。Data ID 通常用于组织划分系统的配置集。一个系统或者应用可以包含多个配置集,每个配置集都可以被一个有意义的名称标识。Data ID 通常采用类 Java 包(如com.taobao.tc.refund.log.level)的命名规则保证全局唯一性。此命名规则非强制。
2)、配置集:所有的配置的集合
3)、配置集TD:类似文件名。Data Ip:类似文件名
配置分组:
Nacos 中的一组配置集,是组织配置的维度之一。通过一个有意义的字符串(如 Buy 或Trade )对配置集进行分组,从而区分 Data ID 相同的配置集。当您在 Nacos 上创建一个配置时,如果未填写配置分组的名称,则配置分组的名称默认采用 DEFAULT_GROUP 。配置分组的常见场景:不同的应用或组件使用了相同的配置类型,如 database_url 配置和MQ_topic 配置。
4)、配置分组:默认所有的配置集都属于:DEFAULT_GROUP;比如双11,618,双12
每个微服务创建自己的命名空间,使用配置分组区分环境,dev,test,prod
① 创建分组及配置

coupon.user.name=1111
coupon.user.age=1111
② 在idea中 bootstrap.properties中添加配置

⑤ 重启服务浏览器查看
http://localhost:7000/copupon/coupon/test

1.4.2、加载多配置文件

详细拆分配置如下:
- ① 数据源配置

- ② mybatis-plus配置

- ③ 剩余的配置

④ 最终配置显示

⑤ 注释掉
application.properties里面的文件,随意开启一个服务进行测试,如gulimall-product

1.5、网关 Gateway
1.5.1、简介
网关作为流量的入口,常用功能包括
路由转发、权限校验、限流控制等。而springcloud gateway作为 SpringCloud 官方推出的第二代网关框架,取代了 Zuul 网关。

- 网关提供 API 全托管服务,丰富的 API 管理功能,辅助企业管理大规模的 API,以降低管理成本和安全风险,包括协议适配、协议转发、安全策略、防刷、流量、监控日志等功能。
Spring Cloud Gateway旨在提供一种简单而有效的方式来对 API 进行路由,并为他们提供切面,例如:安全性,监控/指标 和弹性等。
- 官方文档地址:
https://docs.spring.io/spring-cloud-gateway/reference/spring-cloud-gateway/how-it-works.html

Spring Cloud Gateway 特点:
- ⚫ 基于
Spring5,支持响应式编程和SpringBoot2.0- ⚫支持使用任何请求属性进行路由匹配
- ⚫特定于路由的断言和过滤器
- ⚫ 集成
Hystrix进行断路保护- ⚫ 集成服务发现功能
- ⚫ 易于编写
Predicates和Filters- ⚫ 支持请求速率限制
- ⚫ 支持路径重写
思考:
为什么使用 API 网关?
- API 网关出现的原因是微服务架构的出现,不同的微服务一般会有不同的网络地址,而外部客户端可能需要调用多个服务的接口才能完成一个业务需求,如果让客户端直接与各个微服务通信,会有以下的问题:
- ⚫客户端会多次请求不同的微服务,增加了客户端的复杂性。
- ⚫存在跨域请求,在一定场景下处理相对复杂。
- ⚫认证复杂,每个服务都需要独立认证。
- ⚫ 难以重构,随着项目的迭代,可能需要重新划分微服务。例如,可能将多个服务合并成一个或者将一个服务拆分成多个。如果客户端直接与微服务通信,那么重构将会很难实施。
- ⚫某些微服务可能使用了防火墙 / 浏览器不友好的协议,直接访问会有一定的困难。
- 以上这些问题可以借助
API网关解决。API网关是介于客户端和服务器端之间的中间层,所有的外部请求都会先经过API网关这一层。也就是说,API 的实现方面更多的考虑业务逻辑,而安全、性能、监控可以交由 API 网关来做,这样既提高业务灵活性又不缺安全性:
使用 API 网关后的优点如下:
易于监控。可以在网关收集监控数据并将其推送到外部系统进行分析。
- ⚫易于认证。可以在网关上进行认证,然后再将请求转发到后端的微服务,而无须在每个微服务中进行认证。
- ⚫减少了客户端与各个微服务之间的交互次数。
1.5.2、核心概念
- ⚫路由。路由是网关最基础的部分,路由信息有一个 ID、一个目的 URL、一组断言和一组Filter 组成。如果断言路由为真,则说明请求的 URL 和配置匹配
- ⚫断言。
Java8 中的断言函数。Spring Cloud Gateway 中的断言函数输入类型是 Spring5.0 框架中的 ServerWebExchange。Spring Cloud Gateway 中的断言函数允许开发者去定义匹配来自于 http request 中的任何信息,比如请求头和参数等。- ⚫过滤器。一个标准的 Spring webFilter。Spring cloud gateway 中的 filter 分为两种类型的Filter,分别是 Gateway Filter 和 Global Filter。过滤器 Filter 将会对请求和响应进行修改处理
工作原理:
- 官方文档地址:
https://docs.spring.io/spring-cloud-gateway/reference/spring-cloud-gateway/how-it-works.html


- 客户端发送请求给网关,网关
HandlerMapping判断是否请求满足某个路由,满足就发给网关的WebHandler。这个WebHandler将请求交给一个过滤器链,请求到达目标服务之前,会执行所有过滤器的 pre方法。请求到达目标服务处理之后再依次执行所有过滤器的 post 方法。
- 一句话:
满足某些断言(predicates)就路由到指定的地址(uri),使用指定的过滤器(filter)
1.5.3、使用
1、创建网关子模块
gulimall-gateway,引入网关
- ① 创建 子模块
gulimall-gateway

- ② 创建 子模块
gulimall-gateway

- ③ 搜索
gateway如下

- ④ 统一版本引入依赖如下

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
- ⑤ 分别配置nacos服务发现(
application.properties)和服务配置(bootstrap.properties)


spring:application:name: gulimall-gateway

- ⑥ 在
gulimall-gateway下面创建application.properties,application.yml,bootstrap.properties
参考官网:https://docs.spring.io/spring-cloud-gateway

在 gulimall-gateway下面创建 application.properties , application.yml,bootstrap.properties

application.properties
server.port=88spring.application.name=gulimall-gateway
spring.cloud.nacos.server-addr=127.0.0.1:8848
application.yml
spring:application:name: gulimall-gatewaycloud:nacos:discovery:server-addr: 127.0.0.1:8848gateway:routes:# 测试内容- id: test_routeuri: https://www.baidu.compredicates:- Query=url,baidu- id: qq_routeuri: https://www.qq.compredicates:- Query=url,qqdatasource:druid:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://192.168.10.100:3306/gulimall_smsusername: rootpassword: rootmybatis-plus:mapper-locations: classpath:/mapper/**/*.xmlglobal-config:db-config:id-type: auto
bootstrap.properties
spring.application.name=gulimall-gateway
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.config.namespace=68c8750d-50cc-4655-a8b9-bccb38ac99d4
- ⑦ 不开启数据关联
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})

启动测试:
http://localhost:88/hello?url=baidu

https://qq.com/hello

- Gitee地址:https://gitee.com/Daniel-sys/gulimall.git

- 文章所有源码
相关文章:
三、谷粒商城- Spring Cloud Alibaba(3)
🌻🌻 目录 🌻🌻 一、SpringCloud Alibaba1.1、SpringCloud Alibaba 简介1.2、SpringCloud Alibaba-Nacos[作为注册中心]1.2.1 将微服务注册到 nacos 中1.2.2 服务注册到 nacos,远程调用 1.3、SpringCloud Alibaba-Naco…...
MATLAB和Python激发光谱
激发光谱是一种用于研究物质发光特性的分析方法。当样品吸收特定波长的光时,电子从基态跃迁至激发态。随后,当电子返回基态时,会发射出光子,产生荧光或磷光。激发光谱通过测量不同波长的入射光激发下的发光强度来获取数据。该技术…...
学习笔记024——Ubuntu 安装 Redis遇到相关问题
目录 1、更新APT存储库缓存: 2、apt安装Redis: 3、如何查看检查 Redis版本: 4、配置文件相关设置: 5、重启服务,配置生效: 6、查看服务状态: 1、更新APT存储库缓存: sudo apt…...
UE5 腿部IK 解决方案 footplacement
UE5系列文章目录 文章目录 UE5系列文章目录前言一、FootPlacement 是什么?二、具体实现 前言 在Unreal Engine 5 (UE5) 中,腿部IK(Inverse Kinematics,逆向运动学)是一个重要的动画技术,用于实现角色脚部准…...
北航软件算法C4--图部分
C4上级图部分 TOPO!步骤代码段TOPO排序部分 完整代码 简单的图图题目描述输入输出样例步骤代码段开辟vector容器作为dist二维数组初始化调用Floyd算法查询 完整代码 负环题目描述输入输出样例步骤代码段全局变量定义spfa1函数用于判断是否有负环spfa2用于记录每个点到1号点的距…...
PCL点云开发-解决在Qt中嵌入点云窗口出现的一闪而过的黑窗口
PCL点云开发-解决在Qt中嵌入点云窗口出现的一闪而过的黑窗口 众所周知,在windows下开发PCL点云最快的方式就是到官网下载其预编译好的库,比如: PCL-1.14.0-AllInOne-msvc2022-win64.exe 这时候你到网络上搜索,大概率会有两种方案…...
本地音乐服务器(二)
4. 上传音乐模块设计 4.1 上传音乐的接口设计 请求和响应设计: 新建music实体类: Data public class Music {private int id;private String title;private String singer;private String time;private String url;private int userid; } 4.2 创建Mu…...
第三十六篇——伯努利试验:到底如何理解随机性?
目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么? 四、总结五、升华 一、背景介绍 概率论指导着我们对于直觉不靠谱的事情,以及为我们如何更高效…...
【Android、IOS、Flutter、鸿蒙、ReactNative 】屏幕适配
Android Java 屏幕适配 参考 今日头条适配依赖配置 添加设计屏幕尺寸 设置字体大小 通过切换不同屏幕尺寸查看字体大小 设置文本宽高 通过切换不同屏幕尺寸查看文本宽高 Android Compose 屏幕适配 <...
candence : 如何利用EXCEL 绘制复杂、多管脚元件
如何利用EXCEL 绘制复杂、多管脚元件 前面的步骤直接略过 我们以STM32F407VEXX 系列 100pin 芯片为例讲解: 1、新建好一个空元件 2、使用阵列,放置管脚 点击 “ ok ” 3、选中所有管脚 右键 “edit properites” 出现如下页面 4、点击 左上角&…...
项目配置文件选择(Json,xml,Yaml, INI)
选择使用哪种类型的配置文件(如 JSON、XML 或其他格式)取决于多个因素,包括项目的需求、团队的熟悉程度、数据结构的复杂性以及可读性和可维护性等。以下是对常见配置文件格式的比较,以及在不同情况下的推荐: 1. JSON&…...
Android 使用Retrofit 以纯二进制文件流上传文件
一、背景 一般上传文件都是以表单形式上传文件,最近项目中涉及到非表单形式上传文件流,分为单个文件流上传、大文件分段上传,此种情景资料较少,这里记录下。 二、方案介绍 2.1 需求协议 1. 上传文件 API 端点:/serv…...
Vue3踩坑记录
目录 一、定义常变量 1.1、ref和reactive到底用谁? 二、双向绑定 2.1、直接改变表格该行数据 2.1、在弹窗改变表格该行数据 一、定义常变量 1.1、ref和reactive到底用谁? 已知:使用ref定义基础类型数据;使用reactive定义复…...
大数据-227 离线数仓 - Flume 自定义拦截器(续接上节) 采集启动日志和事件日志
点一下关注吧!!!非常感谢!!持续更新!!! Java篇开始了! 目前开始更新 MyBatis,一起深入浅出! 目前已经更新到了: Hadoop࿰…...
【热门主题】000054 ECMAScript:现代 Web 开发的核心语言
前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 目录 【热…...
【Pytorch】torch.nn.functional模块中的非线性激活函数
在使用torch.nn.functional模块时,需要导入包: from torch.nn import functional 以下是常见激活函数的介绍以及对应的代码示例: tanh (双曲正切) 输出范围:(-1, 1) 特点:中心对称,适合处理归一化后的数据…...
reactflow 中 useNodesState 模块作用
1. 节点状态管理核心功能 useNodesState是一个关键的钩子函数,用于专门管理节点(Nodes)的状态。节点是流程图的核心元素,它们可以代表各种实体,如流程中的任务、系统中的组件或者数据结构中的元素。 useNodesState提…...
Go语言内存分配源码分析学习笔记
大家好,我是V 哥。GO GO GO,今天来说一说Go语言内存分配问题,Go语言内存分配的源码主要集中在runtime包中,它实现了Go语言的内存管理,包括初始化、分配、回收和释放等。下面来对这些过程详细分析一下,先赞后…...
【jvm】方法区常用参数有哪些
目录 1. -XX:PermSize2. -XX:MaxPermSize3. -XX:MetaspaceSize(Java 8及以后)4. -XX:MaxMetaspaceSize(Java 8及以后)5. -Xnoclassgc6. -XX:TraceClassLoading7.-XX:TraceClassUnLoading 1. -XX:PermSize 1.设置JVM初始分配的永久…...
JAVA环境的配置
首先找到JDK环境的官网。 Java Archive Downloads - Java SE 8u211 and laterhttps://www.oracle.com/java/technologies/javase/javase8u211-later-archive-downloads.html 我下载的最后一个x64.exe,下载后,直接双击运行,我这里默认安装到…...
VB.net复制Ntag213卡写入UID
本示例使用的发卡器:https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...
Appium+python自动化(十六)- ADB命令
简介 Android 调试桥(adb)是多种用途的工具,该工具可以帮助你你管理设备或模拟器 的状态。 adb ( Android Debug Bridge)是一个通用命令行工具,其允许您与模拟器实例或连接的 Android 设备进行通信。它可为各种设备操作提供便利,如安装和调试…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...
最新SpringBoot+SpringCloud+Nacos微服务框架分享
文章目录 前言一、服务规划二、架构核心1.cloud的pom2.gateway的异常handler3.gateway的filter4、admin的pom5、admin的登录核心 三、code-helper分享总结 前言 最近有个活蛮赶的,根据Excel列的需求预估的工时直接打骨折,不要问我为什么,主要…...
剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
ESP32 I2S音频总线学习笔记(四): INMP441采集音频并实时播放
简介 前面两期文章我们介绍了I2S的读取和写入,一个是通过INMP441麦克风模块采集音频,一个是通过PCM5102A模块播放音频,那如果我们将两者结合起来,将麦克风采集到的音频通过PCM5102A播放,是不是就可以做一个扩音器了呢…...
Pinocchio 库详解及其在足式机器人上的应用
Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...
JAVA后端开发——多租户
数据隔离是多租户系统中的核心概念,确保一个租户(在这个系统中可能是一个公司或一个独立的客户)的数据对其他租户是不可见的。在 RuoYi 框架(您当前项目所使用的基础框架)中,这通常是通过在数据表中增加一个…...
CSS设置元素的宽度根据其内容自动调整
width: fit-content 是 CSS 中的一个属性值,用于设置元素的宽度根据其内容自动调整,确保宽度刚好容纳内容而不会超出。 效果对比 默认情况(width: auto): 块级元素(如 <div>)会占满父容器…...
嵌入式学习笔记DAY33(网络编程——TCP)
一、网络架构 C/S (client/server 客户端/服务器):由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序,负责提供用户界面和交互逻辑 ,接收用户输入,向服务器发送请求,并展示服务…...
