Next.js 系统性教学:深入理解缓存与数据优化策略
更多有关Next.js教程,请查阅:
【目录】Next.js 独立开发系列教程-CSDN博客
目录
前言
1. 缓存的基本概念
1.1 缓存的作用
1.2 Next.js 中的缓存策略
2. Next.js 的缓存机制
2.1 请求记忆化(Request Memoization)
2.1.1 什么是请求记忆化?
2.1.2 Next.js 中的请求记忆化
2.1.3 缓存失效与更新
2.2 数据缓存(Data Caching)
2.2.1 什么是数据缓存?
2.2.2 Next.js 中的数据缓存
客户端数据缓存 - 使用 SWR
服务器端数据缓存 - 使用 getServerSideProps
2.3 缓存优化策略
2.3.1 静态资源缓存
2.3.2 使用 CDN 加速缓存
2.3.3 API 响应缓存
3. 总结与最佳实践
前言
在现代 Web 开发中,性能优化已成为提高用户体验和系统稳定性的核心任务。对于开发人员来说,如何有效地管理应用的缓存,减少不必要的请求,并提升响应速度,尤其在处理大量动态数据时,显得尤为重要。Next.js,作为 React 的强大框架,提供了多种缓存机制,不仅能够提高页面加载速度,还能通过高效的缓存管理减少服务器负载。
本文将围绕 Next.js 中的缓存技术,特别是 请求记忆化(Request Memoization)与 数据缓存(Data Caching),深入分析其工作原理、配置方式以及如何在实际开发中利用这些缓存策略优化应用性能。
1. 缓存的基本概念
1.1 缓存的作用
缓存是计算机系统中常用的性能优化技术,指将频繁使用的数据或计算结果存储在访问速度较快的存储介质中,从而减少重复计算或请求。Web 应用中,缓存能够显著减少服务器和数据库的压力,提高响应速度,特别是在高并发访问的情况下。
常见的缓存机制包括:
- 浏览器缓存:将静态资源如图片、JS、CSS 缓存到客户端,避免重复加载。
- 服务器端缓存:在服务器端存储已生成的页面或计算结果,减少重复请求。
- API 缓存:通过缓存 API 请求的响应数据,减少频繁的后端请求。
- CDN 缓存:通过分布式的 CDN 网络将静态资源缓存到全球多个节点,加速资源加载速度。
对于使用 Next.js 开发应用的开发者来说,理解并正确配置缓存机制,将对提升性能有着至关重要的作用。
1.2 Next.js 中的缓存策略
Next.js 提供了灵活且高效的缓存机制,能够在构建时、运行时以及数据获取阶段进行优化。主要的缓存机制包括:
- 静态资源缓存:针对静态文件(如图片、JS、CSS)的缓存。
- 页面缓存:静态页面通过增量静态生成(ISR)进行缓存,动态页面则利用缓存控制 HTTP 响应。
- API 缓存:通过设置 HTTP 头部的缓存策略来控制 API 请求的缓存时间。
- 数据缓存:用于缓存从 API 或数据库获取的数据,减少重复请求。
2. Next.js 的缓存机制
2.1 请求记忆化(Request Memoization)
2.1.1 什么是请求记忆化?
请求记忆化是一种通过缓存先前的请求结果来避免重复计算的技术。具体到 Web 应用中,它通常用于缓存 API 请求的响应或某些计算结果。通过这种方式,Next.js 能够在服务器端或客户端避免对相同请求的重复计算,显著提升性能。
例如,在数据库查询操作中,如果多个用户或同一用户在短时间内多次请求相同的数据,使用请求记忆化可以避免每次都进行数据库查询,而是直接返回缓存的数据。
2.1.2 Next.js 中的请求记忆化
在 Next.js 中,可以通过自定义缓存策略来实现请求记忆化。对于 API 路由,可以利用 Cache-Control
头部来设置缓存策略。例如,可以在 API 路由中设置 max-age
或 stale-while-revalidate
来实现请求的缓存。
// pages/api/posts.js
export default async function handler(req, res) {const posts = await fetchPostsFromDatabase();// 设置缓存头res.setHeader('Cache-Control', 'public, max-age=3600'); // 缓存 1 小时res.status(200).json(posts);
}
在上面的示例中,Cache-Control
头部指示缓存策略为 max-age=3600
,意味着服务器返回的数据会缓存 1 小时,期间用户的请求会直接返回缓存的数据。
2.1.3 缓存失效与更新
虽然请求记忆化可以显著提高性能,但也需要在合适的时机更新缓存数据。例如,对于频繁变化的数据,过长的缓存时间可能导致用户看到过时的信息。在这种情况下,可以利用 增量静态生成(ISR) 和 定时更新 策略。
// pages/products/[id].js
export async function getStaticProps({ params }) {const product = await fetchProductById(params.id);return {props: { product },revalidate: 10, // 页面每 10 秒重新生成};
}
通过设置 revalidate
参数,可以控制页面缓存的生命周期。在每次请求时,Next.js 会自动检查是否需要重新生成页面。
2.2 数据缓存(Data Caching)
2.2.1 什么是数据缓存?
数据缓存是指将从外部数据源(如数据库、API)获取的数据保存在一个临时存储区域,以便后续请求直接获取缓存的数据,而无需重新查询数据库或发送 API 请求。这是 Web 应用中最常见的缓存形式,尤其对于大规模应用和高并发场景,数据缓存能够显著提高应用性能。
2.2.2 Next.js 中的数据缓存
Next.js 提供了多种方式来进行数据缓存。在客户端,开发者可以通过 SWR(Stale While Revalidate)库来实现数据缓存和自动更新。在服务器端,开发者可以通过设置缓存头、使用 Incremental Static Regeneration(ISR)或 getServerSideProps 来管理缓存。
客户端数据缓存 - 使用 SWR
SWR 是一个 React Hook 库,用于数据获取和缓存。它通过缓存机制减少 API 请求,提升应用的响应速度,并在后台自动更新数据。
import useSWR from 'swr';function Posts() {const { data, error } = useSWR('/api/posts', fetch);if (error) return <div>Failed to load</div>;if (!data) return <div>Loading...</div>;return (<div>{data.map(post => (<div key={post.id}>{post.title}</div>))}</div>);
}
在这个例子中,useSWR
将自动缓存请求的数据,并在后台进行重新验证。当数据过期时,SWR 会发起新的请求,并将最新的数据返回给组件。
服务器端数据缓存 - 使用 getServerSideProps
对于需要每次都从服务器获取数据的页面,可以使用 getServerSideProps
来执行服务端渲染,同时结合 HTTP 缓存头来控制数据缓存。
// pages/dashboard.js
export async function getServerSideProps(context) {const response = await fetch('https://api.example.com/user-data');const data = await response.json();context.res.setHeader('Cache-Control', 'public, max-age=3600'); // 缓存 1 小时return { props: { data } };
}
这里,我们设置了缓存头 Cache-Control
,让 API 响应的数据可以在客户端或 CDN 上缓存 1 小时,减少了对后端服务器的压力。
2.3 缓存优化策略
2.3.1 静态资源缓存
Next.js 提供了强大的静态资源管理功能,开发者可以通过 next.config.js
配置缓存策略,使得静态文件在客户端和 CDN 上得到合理缓存。
// next.config.js
module.exports = {async headers() {return [{source: '/(.*)',headers: [{key: 'Cache-Control',value: 'public, max-age=31536000, immutable', // 缓存 1 年},],},];},
};
上述配置会将所有的静态资源缓存 1 年,并设置为 immutable
,意味着浏览器不会重新请求已缓存的资源,直到资源发生变化。
2.3.2 使用 CDN 加速缓存
Next.js 和 Vercel 默认配合使用 CDN,所有静态资源都可以通过 CDN 加速访问。在生产环境中,Vercel 会自动将你的应用静态资源缓存到 CDN,并为用户提供快速加载体验。
2.3.3 API 响应缓存
对于 API 路由,Next.js 提供了灵活的缓存控制方法。你可以通过设置不同的 Cache-Control
策略来优化数据获取的效率。常见的缓存策略包括:
max-age
: 控制缓存的最大时长。- `s-maxage
`: 控制共享缓存(如 CDN)的缓存时长。
stale-while-revalidate
: 表示缓存过期后,继续使用缓存直到新数据获取到。
// pages/api/data.js
export default async function handler(req, res) {const data = await fetchDataFromDatabase();res.setHeader('Cache-Control', 'public, max-age=600, stale-while-revalidate=300'); // 缓存 10 分钟,过期后 5 分钟内仍使用缓存res.status(200).json(data);
}
3. 总结与最佳实践
在 Web 开发中,合理的缓存策略对于提升性能至关重要。Next.js 提供了多种缓存方式,包括静态页面缓存、动态页面缓存、API 缓存等,可以根据不同的需求灵活配置。在实际开发过程中,合理选择缓存策略,并结合增量静态生成(ISR)、客户端数据缓存(SWR)、缓存头等技术,可以有效提高应用的响应速度和用户体验。
通过本文的学习,开发者应当能掌握以下要点:
- 理解 请求记忆化 和 数据缓存 的概念与实现方式。
- 在 Next.js 中合理配置缓存策略,提高页面加载速度。
- 在实际开发中,结合 SWR 和 增量静态生成 等技术优化数据加载与缓存更新。
正确的缓存策略不仅能优化性能,还能提升用户体验,是每个开发者在构建高效 Web 应用时必备的技能。
更多有关Next.js教程,请查阅:
【目录】Next.js 独立开发系列教程-CSDN博客
有关Next.js的缓存知识,请查阅:
Next.js 系统性教学:深入理解缓存机制(续)-CSDN博客
Next.js系统性教学:深入理解缓存交互与API缓存管理-CSDN博客
相关文章:
Next.js 系统性教学:深入理解缓存与数据优化策略
更多有关Next.js教程,请查阅: 【目录】Next.js 独立开发系列教程-CSDN博客 目录 前言 1. 缓存的基本概念 1.1 缓存的作用 1.2 Next.js 中的缓存策略 2. Next.js 的缓存机制 2.1 请求记忆化(Request Memoization) 2.1.1 什…...
JAVA数据结构
1.数组 (Array): 固定大小的容器,用于存储相同类型的元素,数组在内存中是连续存储的,支持通过索引快 速访问元素。 int[] numbers = new int[10]; numbers[0] = 1;2.Java Collections Framework (JCF) JCF提供了一组接口和类用于管理和操作集合(如列表,集合,…...
力扣第96题 不同的二叉搜索树
力扣第96题 - 不同的二叉搜索树 题目描述 给定一个整数 n,求以 1 到 n 为节点组成的所有 不同的二叉搜索树(BST) 的个数。 题目分析 二叉搜索树的性质 对于一个二叉搜索树,以 i 为根节点: 左子树的节点值来自 [1, i…...
在Ubuntu上使用IntelliJ IDEA:开启你的Java开发之旅!
你好,年轻的学徒!🧑💻 是时候踏上进入Java开发世界的史诗之旅了,我们的得力助手将是强大的IntelliJ IDEA。准备好了吗?出发吧! 在我们开始之前,我们需要下载这个工具。但是&#…...
【C语言】18. 自定义类型:结构体类型
文章目录 前言:一、结构体类型的声明1、结构体回顾1)结构的声明2)结构体变量的创建和初始化 2、结构的特殊声明3、结构的⾃引⽤ 二、结构体变量的创建和初始化1、对⻬规则2、为什么存在内存对⻬?3、修改默认对⻬数 三、结构成员访问操作符1、…...
智能租赁管理系统助力规范化住房租赁市场提升用户体验
内容概要 在当今的住房租赁市场中,智能租赁管理系统应运而生,为房东和租客带来了前所未有的便利。这套系统就像一位全能助手,将租赁信息、监管机制以及在线签约功能集成在一起,让整个过程变得流畅而高效。换句话说,您…...
ERROR: KeeperErrorCode = NoNode for /hbase/master
原因分析 通过上面的情景模拟,我们可以看到报错的原因在于zookeeper中出现问题,可能是zookeeper中的/hbase/master被删除,或者是在hbase集群启动之后重新安装了zookeeper,导致zookeeper中的/hbase/master节点数据异常。 1. 停止…...
springboot第84集:Java进阶之路, Netty
# kafka-map文件夹 cd /usr/local/kafka-map # 根据需求自行修改配置 vi application.yml # 启动 java -jar kafka-map.jar byte minByte -128; byte maxByte 127; 用于表示一个 8 位(1 字节)有符号整数。它的值范围是 -128(-2^7࿰…...
DevOps持续集成
DevOps流程 第一步安装git 关闭防火墙 systemctl stop firewalld cd /usr/loacl vim docker-compose.yml docker search gitlab 拉取gitlab镜像 2.33GB docker pull gitlab/gitlab-ce:latestvim docker-compose.yml修改docker-compose.yml version: 3.1 services:gitlab:i…...
sql server log文件
确定 SQL Server 实例中具有大量 VDF 的数据库 SELECT [name], COUNT(l.database_id) AS vlf_count FROM sys.databases AS s CROSS APPLY sys.dm_db_log_info(s.database_id) AS l GROUP BY [name] HAVING COUNT(l.database_id) > 100; 在收缩日志文件之前确定事务日志中…...
pip install报错 Missing dependencies for SOCKS support的正确解决办法:离线安装pysocks
今天准备开发python项目的时候,发现在pip install 的时候报错了,提示:Missing dependencies for SOCKS support,查遍csdn所有的回答都统一是只需要执行: unset all_proxy unset ALL_PROXY 然后再执行 pip install p…...
嵌入式学习(15)-stm32通用GPIO模拟串口发送数据
一、概述 在项目开发中可能会遇到串口不够用的情况这时候可以用通过GPIO来模拟串口的通信方式。 二、协议格式 按照1位起始位8位数据位1位停止位的方式去编写发送端的程序。起始位拉低一个波特率的时间;发送8位数据;拉高一个波特率的时间。 三、代码 …...
AKE 安全模型:CK, CK+, eCK
参考文献: [BCK98] Mihir Bellare, Ran Canetti, Hugo Krawczyk. A Modular Approach to the Design and Analysis of Authentication and Key Exchange Protocols (Extended Abstract). STOC 1998: 419-428.[CK01] Ran Canetti, Hugo Krawczyk. Analysis of Key-E…...
【Linux】通过crond服务设置定时执行shell脚本,实际执行时间却延迟了8小时
一、问题描述 通过使用crond服务设置定时任务,在每天凌晨的2:00执行脚本,但检查结果时发现,实际执行时间却在上午10点。 检查shell脚本执行结果发现,实际执行脚本时间在上午10:00,延迟了8小时。 检查系统时间…...
什么是云原生数据库 PolarDB?
云原生数据库 PolarDB 是阿里云推出的一款高性能、兼容性强、弹性灵活的关系型数据库产品。它基于云原生架构设计,结合分布式存储和计算分离的技术优势,为用户提供强大的计算能力、卓越的可靠性以及高性价比的数据库解决方案。PolarDB 适合各种业务场景&…...
(6)JS-Clipper2之ClipperOffset
1. 描述 ClipperOffset类封装了对打开路径和关闭路径进行偏移(膨胀/收缩)的过程。 这个类取代了现在已弃用的OffsetPaths函数,该函数不太灵活。可以使用不同的偏移量(增量)多次调用Execute方法,而不必重新分配路径。现在可以在一次操作中对开放和封闭路…...
基于51单片机64位病床呼叫系统设计( proteus仿真+程序+设计报告+原理图+讲解视频)
基于51单片机病床呼叫系统设计( proteus仿真程序设计报告原理图讲解视频) 仿真图proteus7.8及以上 程序编译器:keil 4/keil 5 编程语言:C语言 设计编号:S0095 1. 主要功能: 基于51单片机的病床呼叫系统proteus仿…...
工业智能网关如何为企业实现智能制造赋能?
在数字化转型的浪潮中,工业智能网关作为连接物理世界与数字世界的桥梁,正逐步成为智能制造领域的核心组件。本文将通过一个实际使用案例,深入剖析工业智能网关如何助力企业实现生产流程的优化、数据的高效采集与分析,以及智能化决…...
【Spring项目】表白墙,留言板项目的实现
阿华代码,不是逆风,就是我疯 你们的点赞收藏是我前进最大的动力!! 希望本文内容能够帮助到你!! 目录 一:项目实现准备 1:需求 2:准备工作 (1)…...
Java-WebSocket
文章目录 WebSocket概念SpringBoot实现一个WebSocket示例STOMP消息订阅和发布后端主动发送消息 跨域 WebSocket概念 应用层协议,底层采用TCP,特点:持续连接,有状态,双向通信 当客户端想要与服务器建立WebSocket连接时…...
C#请求https提示未能为 SSL/TLS 安全通道建立信任关系
System.Net.WebException: 基础连接已经关闭: 未能为 SSL/TLS 安全通道建立信任关系 ,这个错误通常表明你的应用程序在尝试建立一个安全的 SSL/TLS 连接时遇到了问题。这通常是由于证书验证失败引起的。证书验证失败可能有几个原因: 证书不受信任&#…...
pdf转word/markdown等格式——MinerU的部署:2024最新的智能数据提取工具
一、简介 MinerU是开源、高质量的数据提取工具,支持多源数据、深度挖掘、自定义规则、快速提取等。含数据采集、处理、存储模块及用户界面,适用于学术、商业、金融、法律等多领域,提高数据获取效率。一站式、开源、高质量的数据提取工具&…...
人工智能与机器学习:真实案例分析及其在各行业的应用前景
目录 引言 人工智能与机器学习的基础概念 人工智能的历史与演变 机器学习的算法分类 深度学习与传统机器学习的区别 行业应用案例分析 医疗健康 疾病预测与诊断 影像识别的运用 案例:IBM Watson在肿瘤治疗中的应用 金融服务 风险评估与欺诈检测 投资预测…...
再谈多重签名与 MPC
目录 什么是 MPC 钱包以及它们是如何出现的 多重签名和智能合约钱包已经成熟 超越 MPC 钱包 关于小队 多重签名已经成为加密货币领域的一部分,但近年来,随着 MPC(多方计算)钱包的出现,多重签名似乎被掩盖了。MPC 钱包之…...
(长期更新)《零基础入门 ArcGIS(ArcMap) 》实验二----网络分析(超超超详细!!!)
相信实验一大家已经完成了,对Arcgis已进一步熟悉了,现在开启第二个实验 ArcMap实验--网络分析 目录 ArcMap实验--网络分析 1.1 网络分析介绍 1.2 实验内容及目的 1.2.1 实验内容 1.2.2 实验目的 2.2 实验方案 2.3 实验流程 2.3.1 实验准备 2.3.2 空间校正…...
Python、R循环神经网络RNN、指数平滑ETS、ARIMA模型预测网络流量、ATM机取款、旅游需求时间序列数据...
全文链接:https://tecdat.cn/?p38496 分析师:Pengyuan Wen 在当今经济研究与商业决策领域,精准的时间序列预测具有极为关键的意义。社会消费品零售总额作为反映人民消费水平以及国民经济状况的核心指标,其发展趋势的精准把握对中…...
通过PS和Unity制作2D动画之二:IK的使用
一、IK的概念 IK:Inverse Kinematics,反向动力学。 (1)正向动力学 在骨骼动画中,构建骨骼的方法被称为正向动力学。它的表现形式是:子骨骼(关节)的位置根据父骨骼(关节…...
如何防御ARP欺骗 保护IP安全
在数字化浪潮席卷全球的今天,网络安全威胁如同暗流涌动,时刻考验着我们的防范能力。其中,ARP欺骗攻击作为一种隐蔽性强、成本低廉且危害严重的网络攻击手段,成为众多网络安全事件中的一颗“毒瘤”。那么我们究竟是如何防御ARP欺骗…...
浏览器插件上架流程
上回说到,用 AI 开发上架了个浏览器插件。有朋友想知道上架扩展有需要哪些步骤。这里做个整理,这篇文章结构和步骤都是 AI 整理的。里面的文案细节、推荐的工具是我自己总结,以前发布扩展时直接用的。有需要的话下面的文案可以直接拷贝使用。…...
Android13 USB 串口默认授权
一)场景需求 项目中使用到了can协议控制车机功能,can 直接转串口,用USB转串口工具 cn.wch.uartlib 来实现. can 板子通过usb 插入到机器上面,那就是usb 协议了。 遇到问题: 插入can 板的usb 到机器上后,直…...
word实践:正文/标题/表图等的共用模板样式设置
说在前面 最近使用word新建文件很多,发现要给大毛病,每次新建一个word文件,标题/正文的字体、大小和间距都要重新设置一遍,而且每次设置这些样式都忘记了参数,今天记录一下,以便后续方便查看使用。现在就以…...
docker安装kettle(PDI)并实现web访问
我是MAC电脑M1版本,希望把软件交给docker进行管理,最近公司同事都通过kettle来实现外部数据对接,所以我本地也有安装kettle需求,在网上找到了这个解决方案操作很简单,但出现了无法访问的情况。我的排查方式是ÿ…...
vue自定义弹窗点击除了自己区域外关闭弹窗
这里使用到vue的自定义指令 <div class"item" v-clickoutside"clickoutside1"><div click"opencity" class"text":style"{ color: popup.iscitypop || okcitylist.length ! 0 ? #FF9500 : #000000 }">选择地区…...
【vue2】封装自定义的日历组件(三)之基础添加月份的加减定位到最新月份的第一天
我们在切换月份的时候,希望高亮显示在每个月的第一天上面,这样的效果我们要怎么来实现,其实也很简单,我们先看下实现的效果 实现效果 代码实现 原理就是获取到每月的第一天日期,然后再跟整个的数据进行对比ÿ…...
21天掌握javaweb-->第12天:Spring Boot项目优化与安全性
Spring Boot项目优化与安全性 1. Spring Boot性能优化 1.1 减少依赖项 评估项目的依赖项,并确保只引入必要的依赖。较多的依赖项可能会增加启动时间,因为它们需要被扫描和初始化。通过删除不需要的依赖项或仅引入必要的模块,可以减少类路径…...
Android —— 四大组件之Activity(一)
Android四大组件即Activity(前台)Service(后台),Broadcast(通信),ContentProvider(数据存储) 一、Activity Activity 充当了应用与用户互动的入口点Activity …...
Ubuntu手持司岚S2激光雷达进行建图
目前通过ros包将激光雷达数据读取之后: roslaunch rplidar_ros view_rplidar_s2.launch 再通过运行 cartographer_ros结点将代码运行起来 roslaunch cartographer_ros demo_revo_lds.launch 这里要注意, 在demo_revo_lds.launch 文件中引入的revo_lds.lua文件中要使用仿真时…...
快速了解 Aurora DSQL
上周在 AWS re:Invent大会(类似于阿里云的云栖大会)上推出了新的产品 Aurora DSQL[1] ,在数据库层面提供了多区域、多点一致性写入的能力,兼容 PostgreSQL。并声称,在多语句跨区域的场景下,延迟只有Google …...
【Android Studio】学习——网络连接
实验:Android网络连接 文章目录 实验:Android网络连接[toc]实验目标和实验内容:1、掌握Android联网的基本概念;2、能够使用URL connection实现网络连接;3、掌握第三方库的基本概念4、需实现的具体功能 实验结果功能说明…...
c语言复制字符串memcpy和strncpy函数区别
memcpy 和 strncpy 的耗时区别 这两个函数在功能上有明显差异,导致性能和耗时也不同。以下是它们的详细对比: 1. 功能差异 函数功能memcpy按字节复制数据,不处理字符串终止符 \0,适用于任意数据类型的内存复制。strncpy复制字符…...
Java设计模式 —— 【创建型模式】建造者模式详解
文章目录 一、建造者模式二、案例实现三、优缺点四、模式拓展五、对比1、工厂方法模式VS建造者模式2、抽象工厂模式VS建造者模式 一、建造者模式 建造者模式(Builder Pattern) 又叫生成器模式,是一种对象构建模式。它可以将复杂对象的建造过…...
python爬虫--某房源网站验证码破解
文章目录 使用模块爬取目标验证码技术细节实现成果代码实现使用模块 requests请求模块 lxml数据解析模块 ddddocr光学识别 爬取目标 网站验证码破解思路是统一的,本文以城市列表为例 目标获取城市名以及城市连接,之后获取城市房源信息技术直接替换地址即可 验证码 技术…...
Android 项目依赖库无法找到的解决方案
目录 错误信息解析 解决方案 1. 检查依赖版本 2. 检查 Maven 仓库配置 3. 强制刷新 Gradle 缓存 4. 检查网络连接 5. 手动下载依赖 总结 相关推荐 最近,我在编译一个 Android 老项目时遇到了一个问题,错误信息显示无法找到 com.gyf.immersionba…...
SpringBoot3整合SpringMVC
一、实现过程: (1).创建程序 (2).引入依赖: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"…...
内网穿透 natapp安装与使用
前言 NATAPP是一款基于ngrok的内网穿透工具。以下是对NATAPP的详细概述: 基本概念 定义:内网穿透(NAT穿透)是一种技术,它允许具有特定源IP地址和端口号的数据包能够绕过NAT设备,从而被正确地路由到内网主机…...
docker镜像构建企业级示例
华子目录 示例(在centos容器中源码编译nginx(单介构建))包准备为centos容器提供网络源添加企业7的ISO文件 提交为新的centos镜像编写dockerfile文件构建镜像如何优化自己构建的镜像大小多介构建 ldd命令基本用法示例 镜像优化方案…...
【论文阅读】龙芯2号处理器设计和性能分析
作者:胡伟武老师 胡伟武老师是计算机体系结构方向的大牛,推动了龙芯处理器的发展 学习体会: 学习追踪龙芯系列“工程流”论文,看看如何做工程,完成→完美 龙芯2号处理器几乎是工程向的论文,主要看一下实现…...
二一(GIT4)、echarts(地图)、黑马就业数据平台(学生页-增 删 改)
1. echarts 地图 echarts社区:makeapie echarts社区图表可视化案例 社区模板代码地址:自定义 tooltip-轮播 - category-work,series-map地图,tooltip提示框,visualMap视觉映射 - makeapie echarts社区图表可视化案例 // todo: 籍贯分布 地图 function…...
数据结构排序算法详解
数据结构排序算法详解 1、冒泡排序(Bubble Sort)2、选择排序(Selection Sort)2、插入排序(Insertion Sort)4、快速排序(Quick Sort) 1、冒泡排序(Bubble Sort)…...
使用kubeadm命令安装k8s
版本信息 kubernetesVersion: 1.28.01. 前期环境准备 先配置软件源可以安装kubeadm、kubelet、kubectl三个软件,不同的系统不同的安装方式,这里不列举了,自己找。然后要安装cri-dockerd,因为kubernetes从1.24版本不再支持docker的api,支持原生的containerd的api,可以使用…...