性能狂飙:SpringBoot应用优化实战手册

在数字时代,速度就是生命,性能就是王道!《极速启航:SpringBoot性能优化的秘籍》带你深入SpringBoot的内核,探索如何打造一个飞速响应、高效稳定的应用。从基础的代码优化到高级的数据库连接池配置,再到前端资源的压缩与缓存,我们为你揭秘每一个提升性能的秘诀。不仅如此,你还将学会如何使用强大的性能分析工具,监控你的应用就像监控自己的心跳一样。准备好了吗?让我们一起启航,让应用的性能飞跃起来!

文章目录

    • 1. 引言
      • 1.1 优化的重要性与目标
      • 1.2 SpringBoot应用的性能挑战
    • 2. 性能分析工具和指标
      • 2.1 常用性能分析工具
        • 2.1.1 VisualVM
        • 2.1.2 JProfiler
        • 2.1.3 Spring Boot Actuator
      • 2.2 关键性能指标(KPIs)
        • 2.2.1 响应时间
        • 2.2.2 吞吐量
        • 2.2.3 错误率
        • 2.2.4 系统资源利用率
    • 3. 代码层面的性能优化技巧
      • 3.1 减少不必要的计算与查询
      • 3.2 利用缓存机制
      • 3.3 并发编程优化
        • 3.3.1 使用线程池
        • 3.3.2 并发集合的选择
      • 3.4 代码优化实例
        • 3.4.1 循环优化
        • 3.4.2 字符串操作优化
    • 4. 配置和优化数据库连接池
      • 4.1 数据库连接池介绍
      • 4.2 SpringBoot中常用的连接池
        • 4.2.1 HikariCP
        • 4.2.2 c3p0
        • 4.2.3 DBCP2
      • 4.3 连接池参数调优
        • 4.3.1 最小连接数
        • 4.3.2 最大连接数
        • 4.3.3 连接超时时间
      • 4.4 SQL查询优化策略
    • 5. 应用层与网络优化
      • 5.1 前端资源压缩与缓存
      • 5.2 HTTP请求优化
        • 5.2.1 使用HTTP/2
        • 5.2.2 GZIP压缩
      • 5.3 跨域资源共享(CORS)优化
    • 6. 结论
      • 6.1 总结关键优化措施
      • 6.2 持续性能监控与迭代的重要性

在这里插入图片描述

1. 引言

1.1 优化的重要性与目标

在这个快节奏的时代,性能就像是一杯咖啡,能让人迅速提神醒脑,而优化则是那一勺糖,让咖啡变得更加可口。对于SpringBoot应用来说,性能优化就像是给这杯咖啡加上了奶泡,不仅提升了口感,还增加了层次感。优化的重要性不言而喻,它关系到应用的响应速度、稳定性和用户体验。而我们的目标,就是让这杯咖啡,哦不,是应用,变得更加丝滑、高效。

想象一下,如果你的应用像蜗牛一样慢,用户可能会在等待中失去耐心,甚至转投竞争对手的怀抱。这就像是在一场赛跑中,你的对手已经冲过终点,而你还在起跑线上系鞋带。所以,优化不仅是为了提升速度,更是为了赢得用户的青睐和市场的竞争。

1.2 SpringBoot应用的性能挑战

然而,优化之路并非一帆风顺。SpringBoot应用在性能上面临着诸多挑战,比如资源限制、代码效率、数据库访问等。这些问题就像是一块块绊脚石,阻碍着我们前进的步伐。但是,正如那句老话所说,“困难是弹簧,你弱它就强”。面对这些挑战,我们需要采取一系列策略和技巧,一一克服它们。

首先,资源限制是一个普遍存在的问题。在有限的硬件资源下,如何让应用跑得更快,就像是在一个小房间里跳舞,需要巧妙地安排每一个动作。其次,代码效率直接影响到应用的性能。优化代码,就像是给房间打扫卫生,让空间更加宽敞,让舞步更加流畅。最后,数据库访问是性能优化中的一个重要环节。优化数据库访问,就像是给房间安装了一扇大窗户,让更多的阳光照进来,让房间更加明亮。

通过这些比喻,我们可以看到,性能优化是一个全方位、多层次的过程。它需要我们从不同的角度出发,采取不同的策略,才能达到最佳效果。在接下来的章节中,我们将一步步探索SpringBoot应用的性能优化之路,就像是一位探险家,一步步揭开神秘的面纱,发现宝藏。

2. 性能分析工具和指标

2.1 常用性能分析工具

在性能优化的征程中,我们首先需要装备一些得力的助手——性能分析工具。这些工具就像是我们手中的望远镜和显微镜,帮助我们发现问题,分析问题,最终解决问题。

2.1.1 VisualVM

VisualVM 是 Java 性能分析的瑞士军刀,它提供了一个图形界面,让我们可以直观地查看 JVM 的运行情况,包括内存使用、线程状态、CPU 使用率等。使用 VisualVM,就像是在看一场精彩的球赛,我们可以清晰地看到球场上的每一个角落,每一个球员的动态。

2.1.2 JProfiler

JProfiler 是一个更为专业的性能分析工具,它提供了深入的分析功能,包括 CPU 分析、内存分析、线程分析等。使用 JProfiler,就像是在进行一次深入的体检,可以发现隐藏在身体内部的隐患。

2.1.3 Spring Boot Actuator

Spring Boot Actuator 是 Spring Boot 的一个扩展,它提供了一系列的端点,用于监控和管理 Spring Boot 应用。通过 Actuator,我们可以获取应用的运行时信息,包括健康状态、度量数据等。使用 Actuator,就像是拥有了一个智能手表,随时监控我们的身体状况。

2.2 关键性能指标(KPIs)

了解了工具之后,我们需要明确一些关键性能指标,这些指标就像是我们优化路上的里程碑,指引我们前进的方向。

2.2.1 响应时间

响应时间是衡量应用性能的一个重要指标,它反映了用户发出请求到收到响应所经历的时间。优化响应时间,就像是在赛跑中提高起跑速度,让用户更快地得到反馈。

2.2.2 吞吐量

吞吐量是指应用在单位时间内能够处理的请求数量。提高吞吐量,就像是在工厂提高生产效率,让机器运转得更快,产出更多的产品。

2.2.3 错误率

错误率是指应用在处理请求时出现错误的比率。降低错误率,就像是在考试中减少错题,提高得分率,确保应用的稳定性和可靠性。

2.2.4 系统资源利用率

系统资源利用率包括 CPU、内存、磁盘和网络等资源的使用情况。合理利用系统资源,就像是在厨房合理分配食材,让每一道菜都能发挥出最佳的味道。

通过这些性能分析工具和关键性能指标,我们可以对 SpringBoot 应用进行全面的监控和分析,找到性能瓶颈,制定优化策略。在接下来的章节中,我们将深入探讨如何利用这些工具和指标,一步步提升应用的性能。

在这里插入图片描述

3. 代码层面的性能优化技巧

3.1 减少不必要的计算与查询

在代码的世界里,每一次计算和查询都像是在厨房里准备食材。如果准备得太多,不仅浪费资源,还会让厨房变得拥挤不堪。因此,减少不必要的计算和查询,就像是精简菜单,只准备那些真正需要的食材。

举个例子,假设我们有一个方法,需要根据用户ID查询用户信息,如果这个方法在循环中被多次调用,而用户ID并没有变化,那么我们可以将其移出循环,只查询一次,然后复用结果。

// 假设getUserById是一个查询数据库的方法
String userId = "12345";
User user = getUserById(userId); // 只查询一次

for (int i = 0; i < 10; i++) {
    // 循环中使用user变量,而不再重复查询
    processUser(user);
}

3.2 利用缓存机制

缓存就像是我们的大脑,能够快速回忆起之前学习过的知识,而不需要每次都从头开始学习。在应用中使用缓存,可以显著提高数据的读取速度,减少对数据库的访问。

想象一下,如果你每次打开网页都需要重新下载所有的图片和脚本,那会是多么痛苦的体验。但是,有了浏览器缓存,这些资源就可以被快速加载,提升用户的访问速度。

在SpringBoot中,我们可以使用各种缓存注解,如@Cacheable@CacheEvict,来轻松实现缓存逻辑。

@Cacheable(value = "userCache", key = "#id")
public User findUserById(String id) {
    // 这里会执行数据库查询,并将结果缓存起来
    return userRepository.findById(id);
}

3.3 并发编程优化

并发编程就像是在厨房里同时进行多个烹饪任务,需要精心安排,以避免混乱和资源冲突。

3.3.1 使用线程池

线程池就像是厨房里的厨师团队,通过合理分配任务,可以提高工作效率,避免资源浪费。在SpringBoot中,我们可以通过配置ThreadPoolTaskExecutor来创建和管理线程池。

@Configuration
public class ThreadPoolConfig {

    @Bean
    public Executor taskExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(2);
        executor.setMaxPoolSize(4);
        executor.setQueueCapacity(100);
        executor.setThreadNamePrefix("TaskExecutor-");
        executor.initialize();
        return executor;
    }
}
3.3.2 并发集合的选择

并发集合就像是厨房里的高效工具,可以帮助我们快速完成烹饪任务。Java提供了多种并发集合,如ConcurrentHashMapCopyOnWriteArrayList等,它们在多线程环境下表现更优。

ConcurrentHashMap<String, User> userMap = new ConcurrentHashMap<>();
userMap.put("12345", newUser); // 线程安全的插入操作

3.4 代码优化实例

3.4.1 循环优化

循环优化就像是在厨房里优化烹饪流程,让每一道工序都更加高效。例如,我们可以减少循环中的复杂操作,或者使用更高效的循环结构。

// 避免在循环中进行复杂的操作
List<User> users = userRepository.findAll();
for (User user : users) {
    processUser(user); // 假设这是一个简单操作
}
3.4.2 字符串操作优化

字符串操作就像是在厨房里处理食材,需要小心翼翼,以避免浪费。在Java中,字符串是不可变的,这意味着每次修改字符串都会创建一个新的字符串对象。因此,我们应该避免在循环中进行大量的字符串拼接。

// 避免在循环中进行字符串拼接
StringBuilder builder = new StringBuilder();
for (int i = 0; i < 100; i++) {
    builder.append(i); // 使用StringBuilder来优化性能
}
String result = builder.toString();

通过这些代码层面的优化技巧,我们的SpringBoot应用就能像厨房里的高效烹饪流程一样,快速、高效地处理任务。在下一章,我们将探讨如何配置和优化数据库连接池,让数据访问更加顺畅。

4. 配置和优化数据库连接池

4.1 数据库连接池介绍

数据库连接池就像是我们的“水桶”,它帮我们预先准备好了“水”(数据库连接),这样我们每次需要用“水”时,就可以直接从“水桶”里取,而不需要每次都去“井”(数据库)里打水。这大大节省了我们的时间,也提高了效率。

4.2 SpringBoot中常用的连接池

SpringBoot中,有几个常用的“水桶”,也就是连接池的实现,它们各有特点,适合不同的场景。

4.2.1 HikariCP

HikariCP 是目前最快的连接池,它就像是一辆高速跑车,启动快、运行快、反应快。它还提供了极佳的并发性能和良好的监控支持。

# application.properties
spring.datasource.hikari.minimumIdle=5
spring.datasource.hikari.maximumPoolSize=15
spring.datasource.hikari.idleTimeout=30000
spring.datasource.hikari.poolName=HikariPool
4.2.2 c3p0

c3p0 是一个成熟的连接池实现,它就像是一辆经典的老爷车,虽然速度可能不如跑车快,但是稳定可靠,经得起时间的考验。

# application.properties
spring.datasource.c3p0.minPoolSize=5
spring.datasource.c3p0.maxPoolSize=15
spring.datasource.c3p0.timeout=30000
spring.datasource.c3p0.idleConnectionTestPeriod=30
4.2.3 DBCP2

DBCP2 是 Apache 的一个项目,它就像是一辆经济型轿车,性价比高,适合预算有限的情况。

# application.properties
spring.datasource.dbcp2.minEvictableIdleTimeMillis=30000
spring.datasource.dbcp2.maxTotal=15
spring.datasource.dbcp2.numTestsPerEvictionRun=10

4.3 连接池参数调优

连接池的参数调优就像是调整“水桶”的大小和“水”的流动速度,以适应不同的需求。

4.3.1 最小连接数

最小连接数决定了“水桶”里始终保持的“水”量,太少了可能不够用,太多了又会造成浪费。

4.3.2 最大连接数

最大连接数则是“水桶”能装的“水”的最大量,超过这个量,就需要等待或者拒绝服务了。

4.3.3 连接超时时间

连接超时时间则是规定了“水”在“水桶”里可以存放的最长时间,时间太长“水”可能会变质,太短则可能导致频繁地更换“水”。

4.4 SQL查询优化策略

SQL查询优化就像是挑选“水桶”里的“水”,我们要挑选最新鲜、最清澈的“水”,避免取到杂质或者浑水。

  • 使用索引:给数据库表加上索引,就像是给“水桶”装上过滤器,可以快速找到我们需要的“水”。
  • 避免全表扫描:尽量减少全表扫描,就像是避免把“水桶”里的“水”全部倒出来再找我们需要的“水”。
  • 优化查询语句:优化查询语句,就像是优化取“水”的流程,让取“水”更加高效。
-- 一个简单的SQL查询优化示例
SELECT * FROM users WHERE active = true AND last_login > '2024-01-01';
-- 可以改为
SELECT * FROM users WHERE active = true AND last_login > '2024-01-01' LIMIT 100;
-- 限制结果集大小,提高查询效率

通过这些策略,我们的数据库连接池就能像一个高效的“水桶”一样,为我们的应用提供稳定、快速的数据访问服务。下一章,我们将探讨应用层与网络优化,让应用的运行更加顺畅,用户体验更加舒适。

在这里插入图片描述

5. 应用层与网络优化

5.1 前端资源压缩与缓存

前端资源的压缩与缓存就像是给网站穿上了一件保暖的大衣,不仅让网站在寒冷的网络世界中保持温暖,还能让访问者感受到快速和便捷。

  • 资源压缩:通过压缩CSS、JavaScript文件和图片,我们可以减少文件的大小,加快加载速度。这就像是把一件厚重的大衣换成一件轻薄的羽绒服,既保暖又轻便。
<!-- 在HTML中引用压缩后的CSS和JavaScript文件 -->
<link rel="stylesheet" href="styles.min.css">
<script src="scripts.min.js"></script>
  • 资源缓存:利用浏览器缓存可以减少重复加载资源的次数。这就像是给大衣加上了一个智能温控系统,只在需要的时候提供温暖。
<!-- HTTP缓存相关的头部示例 -->
<META HTTP-EQUIV="Cache-Control" CONTENT="max-age=86400">

5.2 HTTP请求优化

HTTP请求的优化就像是给网站配备了一辆高速列车,让数据传输更加迅速。

5.2.1 使用HTTP/2

HTTP/2 是HTTP协议的一个升级版本,它提供了更高效的数据传输机制。使用HTTP/2,就像是给网站换上了一辆高速列车,让数据传输更加迅速。

# 在SpringBoot应用的配置文件中启用HTTP/2
server:
  http2:
    enabled: true
5.2.2 GZIP压缩

GZIP压缩可以进一步减少传输的数据量。这就像是给高速列车的车厢加上了压缩装置,让车厢能够装载更多的货物,同时还能保持高速运行。

# application.properties
server.compression.enabled=true
server.compression.mime-types=text/html,text/xml,text/plain,text/css,application/javascript,application/json

5.3 跨域资源共享(CORS)优化

跨域资源共享(CORS)优化就像是给网站打开了一扇大门,让来自不同地方的访客都能够进入。

  • CORS策略配置:合理配置CORS策略,允许特定的域名访问我们的资源。这就像是在大门上安装了一个智能门禁系统,只有得到授权的人才能进入。
@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**").allowedOrigins("http://example.com");
    }
}

通过这些应用层与网络优化措施,我们的网站就像是穿上了一件保暖的大衣,配备了一辆高速列车,并且打开了一扇大门,让访问者能够快速、便捷、安全地访问我们的资源。在下一章,我们将总结关键的优化措施,并强调持续性能监控与迭代的重要性。

6. 结论

6.1 总结关键优化措施

经过了前面章节的探索,我们就像是完成了一场精彩的寻宝之旅,找到了优化SpringBoot应用的宝藏。现在,让我们来回顾一下这场旅程中发现的关键优化措施。

  • 性能分析工具:我们学会了使用VisualVM、JProfiler和Spring Boot Actuator这些工具来监控和分析应用的性能。
  • 代码层面优化:我们学会了减少不必要的计算和查询,利用缓存机制,优化并发编程,以及对循环和字符串操作进行优化。
  • 数据库连接池优化:我们了解了如何配置和优化HikariCP、c3p0和DBCP2等连接池,以及如何调整连接池参数。
  • 应用层与网络优化:我们学会了对前端资源进行压缩和缓存,使用HTTP/2和GZIP压缩来优化HTTP请求,以及配置CORS策略。

这些优化措施就像是我们寻宝过程中收集到的宝贝,每一件都有其独特的价值和作用。

6.2 持续性能监控与迭代的重要性

然而,寻宝之旅并没有结束。性能优化是一个持续的过程,就像是种下一棵树,需要我们不断地浇水、施肥,它才能茁壮成长。

  • 持续监控:我们需要持续监控应用的性能,以便及时发现问题并进行优化。这就像是给树定期检查,确保它的健康成长。
  • 性能迭代:随着业务的发展和用户需求的变化,我们需要不断地迭代和优化应用的性能。这就像是根据季节的变化调整浇水和施肥的策略。
// 一个简单的健康检查端点示例
@GetMapping("/actuator/health")
public Map<String, Object> healthCheck() {
    // 实现健康检查逻辑
}

通过持续的性能监控和迭代,我们的SpringBoot应用就能保持最佳状态,为用户提供最佳的服务。这就像是一棵茁壮成长的树,不仅能为我们提供阴凉,还能结出丰硕的果实。

最后,让我们记住,性能优化是一场永无止境的旅程。我们需要不断地学习、探索和实践,才能在这个快速变化的技术世界中保持领先。所以,拿起你的工具,继续前进吧,更多的宝藏还在等待着我们去发现!

通过这一系列的优化措施,我们的SpringBoot应用将能够以更高的效率和更好的性能服务于用户,就像一杯精心调制的咖啡,让人回味无穷。记住,优化是一场旅程,而不是终点。让我们一起享受这场旅程,不断探索,不断进步!

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

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

相关文章

恭喜!Z医生喜提世界顶级梅奥诊所访问学者邀请函

➡️【院校简介】 梅奥诊所&#xff08;Mayo clinic&#xff09;&#xff0c;于1863年在美国明尼苏达州罗彻斯特创立&#xff0c;是全球规模最大的综合性非营利医生执业组织。它是以不断创新的医学教育和世界领先的医学研究为基础&#xff0c;建立起来的全美规模最大、设备最先…

YashanDB携手宏杉科技助力国产软件生态发展

近日&#xff0c;深圳计算科学研究院崖山数据库系统YashanDB与宏杉科技系列存储、系列服务器与数据库一体机等多款产品顺利完成兼容性互认证。经严格测试&#xff0c;双方产品完全兼容&#xff0c;稳定运行&#xff0c;共同提供高效、稳定、安全的国产软硬件一体化解决方案&…

Spring异步任务@Async的默认线程池执行器是如何初始化的

Spring异步任务Async的默认线程池执行器&#xff0c;是从哪里来&#xff1f;是如何初始化的&#xff1f; 结论先行 异步任务Async的默认线程池执行器是通过TaskExecutionAutoConfiguration#applicationTaskExecutor自动注入的。 异步任务的线程池执行器是如何初始化的&#…

查看Linux端口占用和开启端口命令

查看端口的使用的情况 lsof 命令 比如查看80端口的使用的情况 lsof -i tcp:80列出所有的端口 netstat -ntlp查看端口的状态 /etc/init.d/iptables status开启端口以开启端口80为例。 1 用命令开启端口 iptables -I INPUT -p tcp --dport 80 -j accpet --写入要开放的端口/…

【Vue】scoped解决样式冲突

默认情况下写在组件中的样式会 全局生效 → 因此很容易造成多个组件之间的样式冲突问题。 全局样式: 默认组件中的样式会作用到全局&#xff0c;任何一个组件中都会受到此样式的影响 局部样式: 可以给组件加上scoped 属性,可以让样式只作用于当前组件 一、代码示例 BaseOne…

龙迅#LT8711H支持TYPE-C/DP/EDP转HDMI功能应用,分辨率支持 1080p@60Hz,芯片内置固件!

1. 概述 LT8711H是一款高性能 Type-C/DP1.2/EDP 转 HD-DVI1.3 转换器&#xff0c;设计用于将 USB Type-C 源或 DP1.2 源连接到 HD-DVI1.3 接收器。 该LT8711H集成了符合 DP1.2 标准的接收器和符合 HD-DVI1.3 标准的发射器。此外&#xff0c;还包括两个用于 CC 通信的 CC 控制器…

Linux服务器扩容及磁盘分区(LVM和非LVM)

Linux扩容及磁盘分区&#xff08;LVM和非LVM&#xff09; 本文主要介绍了阿里云服务器centos的扩容方法&#xff1a;非LVM分区扩容方法&#xff08;系统盘&#xff09;&#xff0c;以及磁盘改LVM并分区&#xff08;数据盘&#xff09;。主要是ext4文件系统及xfs磁盘scsi MBR分…

springcloud Feign调用拦截器(统一处理拷贝请求头实现透传信息、内部调用鉴权、打印feign调用)

springcloud Feign调用拦截器&#xff08;统一处理拷贝请求头实现透传信息、内部调用鉴权、打印feign调用日志&#xff09; 实现接口Feign.RequestInterceptor 实现接口 feign.RequestInterceptor 并注入到IOC容器即可生效 示范代码如下 拷贝请求头&#xff0c;将原请求信…

Redis:Redis的数据类型介绍

Redis 支持多种数据类型&#xff0c;每种数据类型都有其特定的用途和优势。以下是 Redis 中主要数据类型的介绍&#xff1a; 1. String&#xff08;字符串&#xff09; 介绍&#xff1a;最基本的 Redis 数据类型&#xff0c;通常用于缓存和存储经常需要读取的数据。 示例&am…

病理级Polymer酶标二抗IHC试剂盒上线!

免疫组织化学 Immunohistochemistry,lHC 是利用抗体与抗原特异性识别原理&#xff0c;对组织样本中的抗原进行定位/定性分析的实验技术。组织切片保留了样品的解剖学结构特征&#xff0c;从而可以高分辨率地显现蛋白在细胞&#xff0c;甚至细胞器中的定位。基于以上特性&…

开源Mamba-2性能狂飙8倍!多个Mamba超强进化体拿下顶会

MambaOut的热度刚过去没多久&#xff0c;Mamba-2就带着它狂飙8倍的性能炸场了。 Mamba-2的核心层是对Mamba的选择性SSM的改进&#xff0c;同等性能下&#xff0c;模型更小&#xff0c;消耗更低&#xff0c;速度更快。与Mamba不同&#xff0c;新一代的Mamba-2再战顶会&#xff…

JVM垃圾收集器和性能调优

目标&#xff1a; 1.JVM垃圾收集器有哪几种&#xff1f; 2.CMS垃圾收集器回收步骤。 一、JVM常见的垃圾回收器 为什么垃圾回收的时候需要STW? 标记垃圾的时候&#xff0c;如果不STW&#xff0c;可能用户线程就会不停的产生垃圾。 1.1 单线程收集 Serial和SerialOld使用单…

windows架设NTP时间服务器进行时间同步

一、windows架设NTP时间服务器 1.win11更改注册表 winR输入regedit 2.HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\Config&#xff0c;找到Config目录&#xff0c;双击Config目录下的AnnounceFlags&#xff0c;设为5。 3.HKEY_LOCAL_MACHINE\SYSTEM\Current…

鸿蒙全栈开发-一文读懂鸿蒙同模块不同模块下的UIAbility跳转详解

前言 根据第三方机构Counterpoint数据&#xff0c;截至2023年三季度末&#xff0c;HarmonyOS在中国智能手机操作系统的市场份额已经提升至13%。短短四年的时间&#xff0c;HarmonyOS就成长为仅次于安卓、苹果iOS的全球第三大操作系统。 因此&#xff0c;对于鸿蒙生态建设而言&a…

前端--导出

这边记录我们公司后端做的导出接口和前端是如何对接的 这边的技术栈是&#xff1a; 1&#xff1a; react 2&#xff1a; fetch 第一步&#xff1a;简单封装--导出界面 import { DrawerForm } from ant-design/pro-components; import { CloseOutlined } f…

不会制作企业版电子书?学会这几个步骤就好啦!

公司安排你制作一本专业的电子书&#xff0c;不知道如何下手&#xff1f;别担心&#xff0c;今天LookLook同学就来给大家分享一下如何轻松制作企业版电子书。参考这几个步骤&#xff0c;相信你一定能轻松搞定&#xff01; 第一步&#xff1a;明确电子书的目标和受众 在开始制作…

【ai】DeepStream 简介

NVIDIA Metropolis 平台。 NVIDIA 大都会 利用视觉 AI 将来自数万亿物联网设备的数据转化为有价值的见解。 NVIDIA Metropolis 是一个应用程序框架、一套开发工具和合作伙伴生态系统,它将视觉数据和 AI 结合在一起,以提高各行各业的运营效率和安全性。它有助于理解数万亿个…

漏洞挖掘 | 验证码绕过

还是老规矩&#xff0c;开局一个登录框&#xff0c;中途漏洞全靠舔&#xff0c;先来研究一下这个登录窗口 很好&#xff0c;发现有验证码登录&#xff0c;先测试测试能不能并发 看来没有&#xff0c;只成功发送了两条&#xff0c;再看看验证码是不是4位 很好&#xff0c;是4位。…

山东大学软件学院项目实训-创新实训-基于大模型的旅游平台(二十八)- 微服务(8)

目录 11.4 SpringAMQP 11.4.2 Work Queue工作队列 11.4.3 发布订阅模型 11.4.4 FanoutExchange(广播交换机) 11.4.5 DirectExchange(路由模式交换机) 11.4.6 TopicExchange 11.5 消息转换器 11.4 SpringAMQP 父工程引入AMQP依赖 <!--AMQP依赖&#xff0c;包含RabbitMQ…

什么无线领夹麦克风音质最好?领夹麦克风品牌排行榜前十名推荐

​在当今的数字化浪潮中&#xff0c;个人声音的传播和记录变得尤为重要。无论是会议中心、教室讲台还是户外探险&#xff0c;无线领夹麦克风以其卓越的便携性和连接稳定性&#xff0c;成为了人们沟通和表达的首选工具。面对市场上琳琅满目的无线麦克风选择&#xff0c;为了帮助…