【微服务】OpenFeign+Sentinel集中处理远程调用异常

文章目录

    • 1.微服务基本环境调整
        • 1.对10004模块的application.yml调整
        • 2.启动nacos以及一个消费者两个提供者
        • 3.测试
          • 1.输入http://localhost:8848/nacos/index.html 来查看注册情况
          • 2.浏览器访问 http://localhost:81/member/nacos/consumer/get/1
          • 3.结果
    • 2.使用OpenFeign实现微服务模块间的远程调用
        • 1.消费者的pom.xml,引入OpenFeign和Nacos的服务发现
        • 2.消费者的application.yml(配置nacos服务注册)
        • 3.消费者的启动类(开启nacos的服务发现,以及启动OpenFeign)
        • 4.com/sun/springcloud/service/MemberOpenfeignService.java 编写与远程调用的方法匹配的接口
          • 1.将要远程调用的方法整个复制到这个接口,然后去掉方法体
          • 2.在接口上添加@FeignClient注解,指定远程调用的服务在nacos中的名字
        • 5.编写一个controller进行远程调用
          • 1.创建一个MemberOpenFeignController的controller并将要远程调用的controller上面的注解复制过来(不能改)
          • 2.依赖注入刚才编写的远程调用的接口的动态代理对象
          • 3.将要远程调用的接口再复制过来,按Tab,使用copilot来自动补全远程调用的代码
        • 6.测试
          • 1.启动nacos,81模块,10004,10006模块
          • 2.访问nacos查看注册情况
          • 3.浏览器输入 http://localhost:81/member/openfeign/get/1 (必须加上http:// )
        • 7.切换负载均衡算法
          • 1.编写配置类,注入一个负载均衡算法的bean
          • 2.重新启动,报错,bean已经被定义了,说明之前可能定义了同样id的负载均衡算法的bean
          • 3.换一个id即可,然后重新启动
          • 4.测试,浏览器访问几次,有时会出现超时的情况(OpenFeign默认超时时间为1s)
          • 5.设置超时时间 application.yml
            • 1.全局配置
            • 2.单个Feign客户端配置
          • 6.又检查了一下,远程调用的方法,之前设置了休眠时间,删除即可。。。
    • 3.服务消费者整合Sentinel进行服务保护
        • 1.pom.xml引入Sentinel
        • 2.application.yml 配置Sentinel的客户端和服务端
        • 3.测试
          • 1.启动nacos,sentinel
          • 2.启动81,10004,10006模块
          • 3.浏览器输入http://localhost:8080/ 进入Sentinel的服务端
          • 4.浏览器输入http://192.168.137.1:8848/nacos/index.html进入nacos查看注册情况
          • 5.浏览器访问 http://localhost:81/member/openfeign/get/1 然后查看Sentinel控制台
        • 4.需求分析
        • 5.开始配置之前进行测试
          • 当10004和10006都down掉时,不断请求会发生什么?
            • 1.首先关闭10004和10006微服务
            • 2.浏览器发送请求 http://localhost:81/member/openfeign/get/1,发现是超时
            • 3.浏览器发送请求 http://localhost:81/member/openfeign/get/1, 可以发现服务不可用
        • 6. 81模块配置如果远程调用的服务出现异常,则立即返回结果
          • 1.MemberFeignFallbackService.java 实现 MemberOpenfeignService.java 并注入容器
          • 2.在application.yml配置启用openfeign和sentinel的整合
          • 3.MemberOpenfeignService 添加fallback属性,指定出现异常要处理的类
          • 4.重新启动81模块,浏览器输入 http://localhost:81/member/openfeign/get/1测试
          • 5.关闭10004和10006,再次进行测试,成功处理异常!
    • 4.消费者使用OpenFeign整合Sentinel进行服务保护小结
        • 1.服务消费者OpenFeign远程调用流程
          • 1.配置Nacos的服务发现和服务注册功能
          • 2.配置OpenFeign远程调用
            • 1.pom.xml引入OpenFeign依赖
            • 2.编写service接口存放服务发现和资源路径的信息
            • 3.编写controller进行远程调用
        • 2.整合Sentinel进行服务保护流程
          • 1.配置Sentinel监控服务
          • 2.配置OpenFeign整合Sentinel,使得远程调用出现异常集中处理
        • 3.服务消费者OpenFeign远程调用整合Sentinel进行服务保护原理
        • 4.Sentinel仍然可以对这个controller进行流量控制,熔断降级,热点限流
          • 设置QPS为1
    • 5.规则持久化
        • 1.规则持久化方案
        • 2.规则持久化原理
        • 3.需求分析
        • 4.具体配置
          • 1.在Nacos配置中心增加Sentinel的流控规则
          • 2.pom.xml引入nacos和sentinel持久化的依赖
          • 3.application.yml 拉取Nacos的配置信息并同步到Sentinel
          • 4.测试
            • 1.启动Nacos、Sentinel、81、10004、10006
            • 2.查看Nacos注册情况
            • 3.浏览器快速请求 http://localhost:81/member/openfeign/get/1, 流控规则生效!
            • 4.查看同步到Sentinel的流控规则
        • 5.其他规则配置

1.微服务基本环境调整

1.对10004模块的application.yml调整

image-20240330095841583

2.启动nacos以及一个消费者两个提供者

目前的消费者是Ribbon+restTemplate形式进行远程调用的

image-20240330100101156

image-20240330100754503

3.测试
1.输入http://localhost:8848/nacos/index.html 来查看注册情况

image-20240330101232507

2.浏览器访问 http://localhost:81/member/nacos/consumer/get/1
3.结果

image-20240330101116525

2.使用OpenFeign实现微服务模块间的远程调用

1.消费者的pom.xml,引入OpenFeign和Nacos的服务发现
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.example</groupId>
        <artifactId>e-commerce-center</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <artifactId>member-service-nacos-consumer-81</artifactId>
    <name>Archetype - member-service-nacos-consumer-81</name>
    <url>http://maven.apache.org</url>

    <dependencies>
        <!-- 引入openfeign -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <!--引入nacos的服务发现-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!-- springboot web starter 用来监听端口-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <!-- 如果在子工程/模块指定了 version,则以指定为准 -->
        </dependency>
        <!--
        1. starter-actuator 是 springboot 程序的监控系统,可以实现健康检查,info 信息
        等
        2. 访问 http://localhost:10000/actuator 可以看到相关链接, 还可以做相关设置. -->
        <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web
        -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <!-- lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!-- test -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!-- 公共模块的jar包 -->
        <dependency>
            <groupId>org.example</groupId>
            <artifactId>e_commerce_center-common-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

    </dependencies>
</project>

2.消费者的application.yml(配置nacos服务注册)
server:
  port: 81
spring:
  application:
    name: member-service-nacos-consumer-81
# 配置nacos的服务注册
  cloud:
      nacos:
        discovery:
          server-addr: localhost:8848 # 配置要注册到的nacos地址,根据实际情况填写
3.消费者的启动类(开启nacos的服务发现,以及启动OpenFeign)
package com.sun.springcloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

/**
 * @author 孙显圣
 * @version 1.0
 */
@SpringBootApplication // springboot启动类
@EnableDiscoveryClient // 开启nacos服务发现
@EnableFeignClients // 开启feign远程调用
public class MemberNacosCostomerApplication81 {
    public static void main(String[] args) {
        SpringApplication.run(MemberNacosCostomerApplication81.class, args);
    }
}

4.com/sun/springcloud/service/MemberOpenfeignService.java 编写与远程调用的方法匹配的接口
1.将要远程调用的方法整个复制到这个接口,然后去掉方法体
package com.sun.springcloud.service;

import com.sun.springcloud.util.Result;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/3/30 10:39
 * @Version 1.0
 */
public interface MemberOpenfeignService {
    /**
     * 根据id来获取某个会员的信息
     *
     * @param id 使用路径参数的形式传入参数
     * @return 返回json格式的数据
     */
    @GetMapping("/memberget/{id}") // 这里使用的路径参数
    public Result getMemberById(@PathVariable("id") Long id);
}

2.在接口上添加@FeignClient注解,指定远程调用的服务在nacos中的名字
  • 这样这个接口中就具备了所有远程调用微服务的信息
  • 后面在注入的时候就会注入针对这个接口的代理对象,远程调用方法的时候通过@FeignClient注解中的信息进行服务发现ip + 端口 + 上下文路径,并在前面加上http://,最后再拼接上这个@GetMapping注解中的资源路径,完成远程调用
  • 简单来说,这个接口需要包含要远程调用的服务发现和资源路径的信息,这样才能够进行远程调用
package com.sun.springcloud.service;

import com.sun.springcloud.util.Result;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/3/30 10:39
 * @Version 1.0
 */
@FeignClient("member-service-nacos-provider") // 会进行服务的发现,发现服务的ip+端口+上下文路径
public interface MemberOpenfeignService {
    /**
     * 根据id来获取某个会员的信息
     *
     * @param id 使用路径参数的形式传入参数
     * @return 返回json格式的数据
     */
    @GetMapping("/member/get/{id}") // 这里使用的路径参数
    public Result getMemberById(@PathVariable("id") Long id);
}

5.编写一个controller进行远程调用
1.创建一个MemberOpenFeignController的controller并将要远程调用的controller上面的注解复制过来(不能改)
package com.sun.springcloud.controller;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RestController;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/3/30 10:53
 * @Version 1.0
 */
// 这两个注解是要远程调用的controller的注解
@RestController
@Slf4j
public class MemberOpenFeignController {
}

2.依赖注入刚才编写的远程调用的接口的动态代理对象
package com.sun.springcloud.controller;

import com.sun.springcloud.service.MemberOpenfeignService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/3/30 10:53
 * @Version 1.0
 */
// 这两个注解是要远程调用的controller的注解
@RestController
@Slf4j
public class MemberOpenFeignController {
    @Resource
    private MemberOpenfeignService memberOpenFeignService; // 注入远程调用的接口
}

3.将要远程调用的接口再复制过来,按Tab,使用copilot来自动补全远程调用的代码
  • 这里的url,方法名,参数,都是可以修改的
  • 传入getMemberById的参数必须符合这个controller的要求
  • getMemberById的返回类型也要匹配,比如这里就必须使用@RestController
  • 牢记接口三要素 url 参数 返回值
  • 建议:如果只是想要远程调用一下的话,就没必要修改了,直接粘贴过来远程调用即可
package com.sun.springcloud.controller;

import com.sun.springcloud.service.MemberOpenfeignService;
import com.sun.springcloud.util.Result;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/3/30 10:53
 * @Version 1.0
 */
// 这两个注解是要远程调用的controller的注解
@RestController
@Slf4j
public class MemberOpenFeignController {
    @Resource
    private MemberOpenfeignService memberOpenFeignService; // 注入远程调用的接口

    /**
     * 根据id来获取某个会员的信息
     *
     * @param id 使用路径参数的形式传入参数
     * @return 返回json格式的数据
     */
    @GetMapping("/member/openfeign/get/{id}") // 1.这里的url是可以改的
    public Result getMemberById(@PathVariable("id") Long id) { // 2.这里的参数和方法名是可以改的
        // 远程调用member-service-nacos-provider的getMemberById方法
        return memberOpenFeignService.getMemberById(id); // 这里的参数和返回值是要远程调用的接口的参数和返回值
    }
}

6.测试
1.启动nacos,81模块,10004,10006模块

image-20240330112344035

image-20240330112330720

2.访问nacos查看注册情况

image-20240330112448718

3.浏览器输入 http://localhost:81/member/openfeign/get/1 (必须加上http:// )

image-20240330112747460

7.切换负载均衡算法
1.编写配置类,注入一个负载均衡算法的bean
package com.sun.springcloud.config;

import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RandomRule;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/** 配置类,用于配置Ribbon的负载均衡策略
 * @author 孙显圣
 * @version 1.0
 */
@Configuration
public class RibbonRule {
    @Bean
    public IRule ribbonRule() {
        // 随机策略
        return new RandomRule();
    }
}

2.重新启动,报错,bean已经被定义了,说明之前可能定义了同样id的负载均衡算法的bean

image-20240330131715496

3.换一个id即可,然后重新启动

image-20240330131826535

image-20240330131949790

4.测试,浏览器访问几次,有时会出现超时的情况(OpenFeign默认超时时间为1s)

image-20240330132533574

5.设置超时时间 application.yml
1.全局配置
feign:
  client:
    config:
      default:
        connectTimeout: 5000
        readTimeout: 10000

2.单个Feign客户端配置
feign:
  client:
    config:
      客户端的application-name:
        connectTimeout: 5000
        readTimeout: 10000

6.又检查了一下,远程调用的方法,之前设置了休眠时间,删除即可。。。

image-20240330132831360

3.服务消费者整合Sentinel进行服务保护

1.pom.xml引入Sentinel
        <!-- 引入Sentinel -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>
2.application.yml 配置Sentinel的客户端和服务端

image-20240330133818630

      sentinel:
        transport:
          dashboard: localhost:8080 # 配置sentinel服务端的地址,根据实际情况填写  
          port: 8719 # 配置sentinel客户端的端口,根据实际情况填写,如果冲突,会自动+1,直到找到可用的端口
3.测试
1.启动nacos,sentinel

image-20240330134115568

image-20240330134103411

2.启动81,10004,10006模块

image-20240330134142463

3.浏览器输入http://localhost:8080/ 进入Sentinel的服务端

image-20240330134321907

4.浏览器输入http://192.168.137.1:8848/nacos/index.html进入nacos查看注册情况

image-20240330134523803

5.浏览器访问 http://localhost:81/member/openfeign/get/1 然后查看Sentinel控制台

image-20240330135602866

4.需求分析

image-20240330140249918

5.开始配置之前进行测试
当10004和10006都down掉时,不断请求会发生什么?
1.首先关闭10004和10006微服务

image-20240330141042709

2.浏览器发送请求 http://localhost:81/member/openfeign/get/1,发现是超时
  • 原因是OpenFeign会根据接口的信息来通过服务发现和资源路径,找到要远程调用的接口,并缓存在本地,所以只要缓存还在,就不会是服务不可用

image-20240330132533574

3.浏览器发送请求 http://localhost:81/member/openfeign/get/1, 可以发现服务不可用
  • 此时的缓存已经不在,OpenFeign重新从nacos获取服务信息,但是获取不到所以会出现服务不可用的错误

image-20240330141137054

6. 81模块配置如果远程调用的服务出现异常,则立即返回结果

image-20240330144105150

1.MemberFeignFallbackService.java 实现 MemberOpenfeignService.java 并注入容器
package com.sun.springcloud.service;

import com.sun.springcloud.util.Result;
import org.springframework.stereotype.Component;

/**
 * Description: 会员服务的降级处理, 当服务不可用时,立即返回一个默认的结果
 *
 * @Author sun
 * @Create 2024/3/30 14:32
 * @Version 1.0
 */
@Component // 注入到spring容器中
public class MemberFeignFallbackService implements MemberOpenfeignService{
    @Override
    public Result getMemberById(Long id) {
        return Result.error("503", "服务降级返回, 服务不可用");
    }
}

2.在application.yml配置启用openfeign和sentinel的整合

image-20240330144151786

# 配置openfeign和sentinel的整合          
feign:
  sentinel:
    enabled: true
3.MemberOpenfeignService 添加fallback属性,指定出现异常要处理的类

image-20240330145014987

4.重新启动81模块,浏览器输入 http://localhost:81/member/openfeign/get/1测试

image-20240330144529901

5.关闭10004和10006,再次进行测试,成功处理异常!

image-20240330145207537

4.消费者使用OpenFeign整合Sentinel进行服务保护小结

1.服务消费者OpenFeign远程调用流程
1.配置Nacos的服务发现和服务注册功能
  • 服务发现:配置pom.xml,和启动类开启服务发现的注解
  • 服务注册:配置application.yml
2.配置OpenFeign远程调用
1.pom.xml引入OpenFeign依赖
2.编写service接口存放服务发现和资源路径的信息
  • 将要远程调用的方法整个复制到这个接口,然后去掉方法体
  • 在接口上添加@FeignClient注解,指定远程调用的服务在nacos中的名字
3.编写controller进行远程调用
  • 将要远程调用的controller上面的注解复制过来(不能改)
  • 依赖注入刚才编写的远程调用的接口的动态代理对象
  • 将要远程调用的接口再复制过来去掉方法体,按Tab,使用copilot来自动补全远程调用的代码
2.整合Sentinel进行服务保护流程
1.配置Sentinel监控服务
  • pom.xml引入Sentinel依赖
  • application.yml 配置Sentinel的客户端和服务端
2.配置OpenFeign整合Sentinel,使得远程调用出现异常集中处理
  • 编写一个类实现存放服务发现和资源路径的信息的service,并实现其方法,然后注入容器
  • 在application.yml配置启用openfeign和sentinel的整合
  • 在service中的@FeignClient注解,添加fallback属性,指定出现处理异常的类
3.服务消费者OpenFeign远程调用整合Sentinel进行服务保护原理

image-20240330153347387

4.Sentinel仍然可以对这个controller进行流量控制,熔断降级,热点限流
设置QPS为1

image-20240330150307503

5.规则持久化

1.规则持久化方案

image-20240330160104138

2.规则持久化原理
  • 简单来说就是在Nacos配置Sentinel的规则
  • 然后在通过Sentinel监控的微服务通过底层通信,同步到Sentinel上

image-20240330160929985

3.需求分析

image-20240330161414714

4.具体配置
1.在Nacos配置中心增加Sentinel的流控规则

image-20240330164518209

2.pom.xml引入nacos和sentinel持久化的依赖
        <!-- 引入nacos和sentinel持久化的依赖 -->
        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-datasource-nacos</artifactId>
        </dependency>
3.application.yml 拉取Nacos的配置信息并同步到Sentinel

image-20240330165648937

        datasource:
          ds1: # 从Nacos中读取sentinel的规则配置
            nacos:
              server-addr: localhost:8848 # 配置要注册到的nacos地址,根据实际情况填写
              dataId: member-service-nacos-consumer-81 # 配置要读取的配置的dataId
              groupId: DEFAULT_GROUP # 配置要读取的配置的groupId
              data-type: json # 配置要读取的配置的类型
              rule-type: flow # 配置要读取的配置的规则类型为流控规则
4.测试
1.启动Nacos、Sentinel、81、10004、10006
2.查看Nacos注册情况

image-20240330165957732

3.浏览器快速请求 http://localhost:81/member/openfeign/get/1, 流控规则生效!

image-20240330170121418

4.查看同步到Sentinel的流控规则

image-20240330170241130

5.其他规则配置

官方文档

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/503434.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【echart】数据可视化

什么是数据可视化&#xff1f; 数据可视化主要目的:借助于图形化手段&#xff0c;清晰有效地传达与沟通信息。 数据可视化可以把数据从冰冷的数字转换成图形&#xff0c;揭示蕴含在数据中的规律和道理。 如何绘制&#xff1f; echarts 图表的绘制&#xff0c;大体分为三步:…

使用1panel部署Ollama WebUI(dcoekr版)浅谈

文章目录 说明配置镜像加速Ollama WebUI容器部署Ollama WebUI使用问题解决&#xff1a;访问页面空白 说明 1Panel简化了docker的部署&#xff0c;提供了可视化的操作&#xff0c;但是我在尝试创建Ollama WebUI容器时&#xff0c;遇到了从github拉取镜像网速很慢的问题&#xf…

pytest--python的一种测试框架--pytest初阶

前言 使用pytest去做测试时我们对文件名的命名其实是有规范的&#xff0c;要用test_开头&#xff01;&#xff01;&#xff01; 一、pytest初阶 def test_one():expect1actual1assert expectactual#测试专用语句&#xff1a;assert&#xff0c;识别期望与实际值是否相等这个…

后疫情时代CS保研沉思录暨2023年个人保研经验贴

个人情况 正如古话所说&#xff0c;最适合你的才是最好的。因此这里先贴上个人基本情况&#xff0c;用作参考。 如果你的个人情况与我相近&#xff0c;则有更强的参考作用。如果情况相差较大&#xff0c;也可以姑且引为例子来研究。 学校层次&#xff1a;中流至末流211 专业…

Linux 学习之路 -- 工具篇 -- gcc / g++

在 Linux 系统中&#xff0c;gcc 和 g 是两个常用的编译工具&#xff0c;分别用于编译 C 和 C 代码。下面我将介绍gcc、g的一些基本用法 目录 一、简单的认识 二、简单了解一下编译的过程 <1> 预处理阶段 <2>编译 <3>汇编 <4>链接…

Redis慢日志

SLOWLOG 是用来读取和重置 Redis 慢查询日志的命令&#xff0c;Redis 2.2.12 版本开始支持 1.Redis 慢查询日志概述 客户端从发送命令到获取返回结果经过了以下几个步骤&#xff1a; 1. 客户端发送命令 2. 该命令进入 Redis 队列排队等待执行 3. Redis 开始执行命令 - Red…

飞天使-k8s知识点28-kubernetes散装知识点5-helm安装ingress

文章目录 安装helm添加仓库下载包配置创建命名空间安装 安装helm https://get.helm.sh/helm-v3.2.3-linux-amd64.tar.gztar -xf helm-v3.2.3-linux-amd64.tar.gzcd linux-amd64mv helm /usr/local/bin修改/etc/profile 文件&#xff0c;修改里面内容,然后重新启用export PATH$P…

嵌入式数据库-Sqlite3

阅读引言&#xff1a; 本文将会从环境sqlite3的安装、数据库的基础知识、sqlite3命令、以及sqlite的sql语句最后还有一个完整的代码实例&#xff0c; 相信仔细学习完这篇内容之后大家一定能有所收获。 目录 一、数据库的基础知识 1.数据库的基本概念 2.常用数据库 3.嵌入式…

在A中删除既在B表中出现又在C表中出现的元素

方法一&#xff08;感觉有点取巧&#xff0c;不太推荐&#xff0c;但是实现简单&#xff09;&#xff1a; 算法思想:保留La的头节点&#xff0c;并用pcur指针指向La链中的第一个结点&#xff0c;通过pcur指针遍历La中的每一个元素&#xff0c;并判断该元素是否在Lb和Lc链中出现…

优化选址问题 | 基于帝国企鹅算法求解工厂-中心-需求点三级选址问题含Matlab源码

目录 问题代码问题 "帝国企鹅算法"并不是一个广为人知的优化算法,可能是一个特定领域或者特定情境下提出的方法。不过,对于工厂-中心-需求点三级选址问题,它可能是一种启发式优化方法,用于在多个候选位置中选择最优的工厂、中心和需求点位置。 这类问题通常涉及…

HAL STM32 硬件I2C方式读取AS5600磁编码器获取角度例程

HAL STM32 硬件I2C方式读取AS5600磁编码器获取角度例程 &#x1f4cd;相关篇《STM32 软件I2C方式读取AS5600磁编码器获取角度例程》 ✨stm32使用硬件I2C去读取角度数据&#xff0c;通过STM32CubeMX工具配置工程&#xff0c;读取角度数据&#xff0c;只需要调用一个函数&#xf…

css3之动画animation

动画animation 一.优点二.定义和使用三.动画序列和解释四.常见属性及解释五.简写&#xff08;名字和时间不能省略&#xff09;&#xff08;持续时间在何时开始的时间前&#xff09;&#xff08;简写中无animation-play-state)六.例子1.大数据热点图2.奔跑的熊大&#xff08;一个…

大模型与数据分析:探索Text-to-SQL

当今大模型如此火热&#xff0c;作为一名数据同学&#xff0c;持续在关注LLM是如何应用在数据分析中的&#xff0c;也关注到很多公司推出了AI数智助手的产品&#xff0c;比如火山引擎数智平台VeDI—AI助手、 Kyligence Copilot AI数智助理、ThoughtSpot等&#xff0c;通过接入人…

同一个主机配置多个SSH key

使用git时&#xff0c;我们可能一个git客户端使用多个git服务器&#xff0c;比如github&#xff0c;自建gitlab&#xff0c;gitee&#xff0c;为了防止提交混乱&#xff0c;所以需要一一对应生成公私钥。 第一步&#xff1a; 使用ssh-keygen生成多对密钥对&#xff0c;比如&…

深入理解SQLite:存储引擎、索引、事务与锁

文章目录 一、存储引擎二、索引的数据结构和类型2.1 B-Tree2.2 其他类型的索引2.3 小结 三、事务处理中的一致性问题3.1 脏读&#xff08;Dirty Read&#xff09;3.2 不可重复读&#xff08;Non-repeatable Read&#xff09;3.3 幻读&#xff08;Phantom Read&#xff09;3.4 小…

python实战之进阶篇(二)

一. python中的继承 二. 多继承 如果一个类继承了多个类, 多个父类中有相同的方法, 相同的方法则按照继承的顺序,继承第一个父类的 如果子类重写父类中继承的方法, 则子类中重写的方法生效 三. 继承与多态

数据结构03:栈、队列和数组 栈习题01[C++]

考研笔记整理~&#x1f95d;&#x1f95d; 之前的博文链接在此&#xff1a;数据结构03&#xff1a;栈、队列和数组_-CSDN博客~&#x1f95d;&#x1f95d; 本篇作为链表的代码补充&#xff0c;供小伙伴们参考~&#x1f95d;&#x1f95d; 第1版&#xff1a;王道书的课后习题…

ubuntu22.04@Jetson Orin Nano安装配置VNC服务端

ubuntu22.04Jetson Orin Nano安装&配置VNC服务端 1. 源由2. 环境3. VNC安装Step 1: update and install xserver-xorg-video-dummyStep 2: Create config for dummy virtual displayStep3: Add the following contents in xorg.conf.dummyStep 4: Update /etc/X11/xorg.con…

使用Flink实现MySQL到Kafka的数据流转换

使用Flink实现MySQL到Kafka的数据流转换 本篇博客将介绍如何使用Flink将数据从MySQL数据库实时传输到Kafka&#xff0c;这是一个常见的用例&#xff0c;适用于需要实时数据connector的场景。 环境准备 在开始之前&#xff0c;确保你的环境中已经安装了以下软件&#xff1a;…

再次加深理解Java中的并发编程

目录 一、线程、进程、程序 二、线程状态 三、线程的七大参数 四、lock与synchronized锁机制 一&#xff09;、lock与synchronized锁区别 二&#xff09;、synchronized锁原理 三&#xff09;、Lock锁原理 五、synchronized锁升级原理 一&#xff09;、锁升级基础知识 …