LightRAG实战:轻松构建知识图谱,破解传统RAG多跳推理难题
作者:后端小肥肠
🍊 有疑问可私信或评论区联系我。
🥑 创作不易未经允许严禁转载。
姊妹篇:
2025防失业预警:不会用DeepSeek-RAG建知识库的人正在被淘汰_deepseek-embedding-CSDN博客
从PDF到精准答案:Coze助力RAGFlow框架提升数据召回率_rag 召回率测试-CSDN博客
基于RAGFlow本地部署DeepSeek-R1大模型与知识库:从配置到应用的全流程解析_ragflow 怎么配置自己部署的大模型-CSDN博客
目录
1. 前言
2. LightRAG简介
2.1. 什么是LightRAG
2.2. LightRAG检索和查询流程图
3. LightRAG构建检索增强生成系统(生成知识图谱)
3.1. 本地安装
3.2. LightRAG构建检索增强生成系统(生成知识图谱)实战
3.2.1. 基于ollama构建检索增强生成系统(生成知识图谱)
3.2.2. 调用云端智普大模型构建检索增强生成系统(生成知识图谱)
4. LightRAG查询
5. 资料获取
6. 结语
1. 前言
当前的检索增强生成(RAG)技术在实际应用中面临若干挑战。传统的RAG采用基于向量的扁平化数据表示,难以有效建模实体之间的复杂语义关系,导致在处理复杂领域知识时检索精度不足。此外,传统RAG在多实体关联推理中容易出现逻辑断层,且全量更新机制使得知识库的维护成本随数据规模指数增长。相比之下,LightRAG通过引入图结构和增量更新算法,大幅降低了计算开销,提高了系统在实时数据更新和复杂推理场景中的应用效能。
本文将深入探讨LightRAG的原理,通过实战演示如何基于LightRAG生成知识图谱,同时展示如何进行查询操作,帮助你全方位掌握这一工具。感兴趣的话就继续往下阅读吧~
2. LightRAG简介
2.1. 什么是LightRAG
LightRAG(Lightweight Retrieval-Augmented Generation)是香港大学团队开发的一种轻量级、高效的检索增强生成(RAG)系统。它通过将图结构融入文本索引和检索过程中,采用双层检索机制,增强了对复杂实体依赖关系的理解能力,同时提高了信息检索的效率和响应速度,项目指路:https://github.com/HKUDS/LightRAG
LightRAG的主要优势包括:
- 高效的知识图谱构建:LightRAG通过图结构差异分析实现增量更新算法,显著降低了计算开销,使知识库维护更加高效。
- 双层检索机制:该系统结合了低层次(具体实体和属性)和高层次(广泛主题和概念)的检索策略,满足了不同类型的查询需求,提高了检索的全面性和多样性。
- 快速适应动态数据:LightRAG能够在新数据到来时快速整合,无需重建整个知识库,确保系统在动态环境中保持高效和准确。
通过了解和使用LightRAG,您可以构建高效、灵活且易于维护的知识图谱系统,提升信息检索和生成任务的性能,特别是在处理复杂实体关系和动态数据更新的场景中。
2.2. LightRAG检索和查询流程图
上述流程可以归纳为两大步骤,分别为索引构建流程和查询响应流程:
索引构建流程:
这个阶段的目标是把所有资料整理好,方便后续快速查找,就像把图书馆的书按主题、内容、关系整整齐齐地放好:
1. 把文本切块 + 提取知识
- 系统先把原始文档分成一个个小段落(Chunk),方便处理。
- 然后通过语言模型,从中找出关键的人名、地名、概念等,并发现它们之间的联系(比如:“乔布斯 创办 苹果公司”)。
- 最后去掉重复内容,把图谱结构整理得更紧凑、更清晰。
2. 存进图谱+向量库
- 所有概念和它们之间的关系会被保存成一张“知识图谱”,像思维导图一样储存在图数据库里。
- 同时,每个概念和文本也会被转成“向量”(一串数字),方便用数学方式快速找相似的内容。
3. 动态更新
- 当新数据加入时,LightRAG采用增量更新算法,只更新相关部分,而无需重建整个知识库。
查询响应流程:
这个阶段的任务是:当用户提出一个问题时,系统先理解问题在说什么,然后去“知识库”里找答案,再组织成一段清晰自然的回复。
1. 先分析问题,分出两类关键词
系统会分析用户提问的句子,从中提取出两种关键词:
- 局部关键词:具体的内容,比如“爱因斯坦”、“相对论”这种名词。
- 全局关键词:更偏概念性的词,比如“物理学原理”、“科学贡献”。
2. 两步查找,信息更全面
- 局部检索:先用具体的关键词在“向量库”里找最相关的小段落或知识点。
- 全局检索:再根据概念性关键词,在知识图谱中沿着关系扩展,找更多相关内容。
3. 组织上下文,生成自然语言回答
- 把刚才查到的信息拼成一个“上下文背景”,喂给语言模型(LLM)。
- 系统会按照提前设定的“回答模板”来组织内容,确保回答连贯、有逻辑、信息完整。
3. LightRAG构建检索增强生成系统(生成知识图谱)
3.1. 本地安装
本地安装教程比较简单,首先我们需要把项目克隆到本地,可以用git下载,也可以直接下载安装包:
下载到本地后还是用Pycharm打开,配置一下环境(需要先建立虚拟环境LightRAG,怎么建的就不说了,实在不会的去看我这篇文章的3.1小节解锁DeepSeek-R1大模型微调:从训练到部署,打造定制化AI会话系统_deepseek本地模型训练后怎么讲训练成功移植到生产环境上-CSDN博客)
打开命令行:
运行以下命令安装LightRAG Core:
pip install -e .
之后运行以下命令安装LightRAG Server:
pip install -e ".[api]"
3.2. LightRAG构建检索增强生成系统(生成知识图谱)实战
在程序的examples目录下面提供了很多构建检索增强生成系统(生成知识图谱)的python示例文件:
首先我们需要下载一下用于生成知识图谱的示例文件(狄更斯的圣诞颂歌):
curl https://raw.githubusercontent.com/gusye1234/nano-graphrag/main/tests/mock_data.txt > ./book.txt
下载完成以后记得放到examples目录下面。
3.2.1. 基于ollama构建检索增强生成系统(生成知识图谱)
基于ollama构建检索增强生成系统(生成支持图谱)的python文件为lightrag_ollama_demo.py,官方就有相关视频教我们怎么一步步生成知识图谱和进行查询操作:https://www.youtube.com/watch?v=g21royNJ4fw,如果你本地显存很大,可以试一下,否则我不建议你去浪费时间,我就被卡了一下午,我的chat模型用的是deepseek-r1:1.5b,向量模型用的是nomic-embed-text:latest
报错503,出于程序员的本能,我第一时间就想着用postman测一下这个接口能通吗?测了以后是通的。
于是又去查了资料:
被自己蠢笑了,原本是本地电脑8G的显存根本不够.......
3.2.2. 调用云端智普大模型构建检索增强生成系统(生成知识图谱)
基于云端智普大模型生成知识图谱的python文件为lightrag_zhipu_demo.py,加一行代码配置一下智普大模型的apiKey就行:
os.environ["ZHIPUAI_API_KEY"] = ""
你实在不知道加哪里(纯小白),就直接粘贴我这个代码替换lightrag_zhipu_demo.py:
# 导入必要的标准库
import os
import logging
import asyncio# 从lightrag库中导入LightRAG类和QueryParam类
from lightrag import LightRAG, QueryParam
# 从lightrag.llm.zhipu模块中导入智普大模型的文本生成和嵌入函数
from lightrag.llm.zhipu import zhipu_complete, zhipu_embedding
# 从lightrag.utils模块中导入EmbeddingFunc类,用于定义嵌入函数
from lightrag.utils import EmbeddingFunc
# 从lightrag.kg.shared_storage模块中导入初始化管道状态的函数
from lightrag.kg.shared_storage import initialize_pipeline_status# 设置工作目录
WORKING_DIR = "./dickens"# 配置日志记录,设置日志格式和日志级别为INFO
logging.basicConfig(format="%(levelname)s:%(message)s", level=logging.INFO)# 如果工作目录不存在,则创建该目录
if not os.path.exists(WORKING_DIR):os.mkdir(WORKING_DIR)# 设置智普大模型的API密钥
os.environ["ZHIPUAI_API_KEY"] = ""# 获取环境变量中的API密钥
api_key = os.environ.get("ZHIPUAI_API_KEY")
# 如果API密钥未设置,则抛出异常提示用户设置API密钥
if api_key is None:raise Exception("Please set ZHIPU_API_KEY in your environment")# 定义一个异步函数,用于初始化LightRAG实例
async def initialize_rag():# 创建LightRAG实例rag = LightRAG(working_dir=WORKING_DIR, # 设置工作目录llm_model_func=zhipu_complete, # 设置使用的语言模型函数llm_model_name="glm-4-flashx", # 设置使用的语言模型名称llm_model_max_async=4, # 设置最大异步请求数llm_model_max_token_size=32768, # 设置模型处理的最大token数量# 设置嵌入函数embedding_func=EmbeddingFunc(embedding_dim=2048, # 设置嵌入向量的维度max_token_size=8192, # 设置模型处理的最大token数量func=lambda texts: zhipu_embedding(texts), # 使用智普的嵌入函数),)# 初始化存储系统await rag.initialize_storages()# 初始化管道状态await initialize_pipeline_status()# 返回初始化好的LightRAG实例return rag# 定义主函数
def main():# 使用异步事件循环初始化LightRAG实例rag = asyncio.run(initialize_rag())# 读取本地文本文件并将其内容插入到LightRAG中with open("./book.txt", "r", encoding="utf-8") as f:rag.insert(f.read())# 使用不同的查询模式进行检索并打印结果# 朴素检索:基础查询模式print(rag.query("What are the top themes in this story?", param=QueryParam(mode="naive")))# 局部检索:局部检索模式,仅查找与输入相关的区域print(rag.query("What are the top themes in this story?", param=QueryParam(mode="local")))# 全局检索:全局检索模式,扩展到整个知识图谱的关系print(rag.query("What are the top themes in this story?", param=QueryParam(mode="global")))# 混合检索:混合模式,结合局部与全局信息print(rag.query("What are the top themes in this story?", param=QueryParam(mode="hybrid")))# 如果当前模块是主模块,则调用主函数
if __name__ == "__main__":main()
上述代码展示了如何使用LightRAG框架构建一个基于智普大模型的检索增强生成系统。首先,设置工作目录并配置智普API密钥。然后,定义了一个异步函数initialize_rag
,用于初始化LightRAG实例,包括设置语言模型、嵌入函数和其他参数。在main
函数中,读取本地文本文件,将其内容插入到LightRAG中,并执行多种查询模式(如naive、local、global、hybrid),以获取不同层次的检索结果。整个流程实现了从文本处理、嵌入生成到多模式检索的功能。
不知道智普大模型的apiKey怎么申请的可以点击这个网址:智谱AI开放平台
填入apiKey后运行代码,代码运行完毕后会在工作目录生成结果文件:
以下是对各文件功能的解释(细节图我就不截了,可以生成出来自己去看文件细节):
1. graph_chunk_entity_relation.graphml:
该文件以GraphML格式存储知识图谱的图形结构,包括实体节点及其相互关系。这种格式便于使用图形处理工具进行可视化和分析。
2. kv_store_doc_status.json:
此JSON文件记录文档处理的状态信息,例如文档是否已成功处理或是否存在错误。这有助于跟踪文档的处理进度和状态。
3. kv_store_full_docs.json:
存储原始文档的完整内容。该文件包含了所有输入文档的文本数据,便于后续的检索和处理。
4. kv_store_llm_response_cache.json:
用于缓存大型语言模型(LLM)的响应结果,以提高系统的响应速度和效率,避免对相同请求进行重复计算。
5. kv_store_text_chunks.json:
存储将文档拆分成的小块(chunks)后的文本数据。将长文档拆分为较小的块有助于提高处理效率和检索精度。
6. vdb_chunks.json:
包含文本块的向量化表示。通过将文本块转换为向量,可以在向量数据库中进行高效的相似度搜索和检索。
7. vdb_entities.json:
存储知识图谱中实体的向量表示。将实体转换为向量形式,有助于在检索和推理过程中快速匹配和识别相关实体。
8. vdb_relationships.json:
记录知识图谱中实体之间关系的向量表示。通过将关系表示为向量,可以在图谱中进行高效的关系检索和推理。
这些文件共同构成了LightRAG系统的数据存储和管理架构,支持知识图谱的构建、更新和查询等功能。
运行graph_visual_with_html.py,就可以生成可视化的知识图谱html页面:
# 导入pipmaster库,用于简化Python包的安装和管理
import pipmaster as pm# 检查并安装pyvis库,如果尚未安装
if not pm.is_installed("pyvis"):pm.install("pyvis")
# 检查并安装networkx库,如果尚未安装
if not pm.is_installed("networkx"):pm.install("networkx")# 导入networkx库,用于创建和操作复杂的网络图
import networkx as nx
# 从pyvis.network模块导入Network类,用于在浏览器中展示网络图
from pyvis.network import Network
# 导入random模块,用于生成随机数
import random# 读取GraphML格式的图文件,创建一个NetworkX图对象G
G = nx.read_graphml("./dickens/graph_chunk_entity_relation.graphml")# 创建一个Pyvis的Network对象,用于在浏览器中展示网络图
net = Network(height="100vh", notebook=True)# 将NetworkX图对象G转换为Pyvis网络
net.from_nx(G)# 遍历网络中的所有节点,为每个节点添加随机颜色和提示信息
for node in net.nodes:# 为节点分配一个随机颜色node["color"] = "#{:06x}".format(random.randint(0, 0xFFFFFF))# 如果节点有"description"属性,将其设置为鼠标悬停时显示的提示信息if "description" in node:node["title"] = node["description"]# 遍历网络中的所有边,为每条边添加提示信息
for edge in net.edges:# 如果边有"description"属性,将其设置为鼠标悬停时显示的提示信息if "description" in edge:edge["title"] = edge["description"]# 将网络图保存为HTML文件,并在浏览器中展示
net.show("knowledge_graph.html")
上述代码使用 networkx
创建图结构,利用 pyvis
将其转换为交互式网络图,并在浏览器中显示。代码首先检查并安装所需的 pyvis
和 networkx
库,随后读取存储在 ./dickens/graph_chunk_entity_relation.graphml
的图数据文件。通过 pyvis
的 Network
类,将 networkx
图对象转换为可视化网络,随机为每个节点分配颜色,并设置节点和边的提示信息。最终,生成的交互式网络图被保存为 knowledge_graph.html
文件,用户可在浏览器中打开并与之交互。
把鼠标移动到节点上还能查看详情:
4. LightRAG查询
在lightrag_zhipu_demo.py中选择你想要的查询模式(注释其他模式),输入问题即可进行查询(我选的是global模式):
我的问题是:
这个故事的主题是什么?
LightRAG的回答:
这个故事的主题是道德救赎和人物转变。通过讲述吝啬鬼斯克鲁奇在圣诞节的经历,以及他与三位圣诞灵的相遇,故事展现了斯克鲁奇从自私、冷酷到慷慨、仁慈的转变。圣诞节作为一个象征性的节日,强调了慷慨、善良和对他人的关怀。故事传达了深刻的道德教训,即人们可以通过反思和改变自己的行为来获得救赎。以下是几个重要的主题:
1. 道德救赎:斯克鲁奇在故事中经历了深刻的道德转变,他从最初的冷漠和吝啬,最终转变为一个慷慨和仁慈的人。
2. 人物转变:斯克鲁奇的转变是故事的核心,它展示了一个人在经历启示后如何改变自己的性格和行为。
3. 圣诞节的象征意义:圣诞节作为一个节日,象征着慷慨、善良和社区的团结,对斯克鲁奇的性格转变起到了重要的推动作用。
4. 社会批判:故事通过描绘斯克鲁奇对穷人和慈善事业的冷漠态度,对社会的不平等和贫富差距进行了批判。
5. 人性的复杂性:斯克鲁奇的形象展示了人性的复杂性,即使是一个冷酷的人也有机会改变自己,成为更好的人。
以上主题共同构成了《圣诞颂歌》的核心内容,使其成为一部经典的文学作品。
5. 资料获取
如果你对DeepSeek的相关知识还不熟悉,可以关注gzh后端小肥肠,点击底部【资源】菜单获取DeepSeek相关教程资料。
6. 结语
通过对LightRAG技术的探索与应用,我们不仅成功地构建了一个高效的知识图谱系统,还进一步理解了RAG(检索增强生成)技术在实际应用中的潜力与挑战。LightRAG通过引入图结构和增量更新机制,大大提升了知识图谱的构建效率与查询精度,特别是在处理复杂领域知识时,展现了其独特的优势。此外,LightRAG通过结合检索与生成的双层机制,能够在保持语义连贯性的同时,实现对多实体、多层次关系的深入理解。无论是在文本生成、信息检索还是知识图谱的可视化等方面,LightRAG都为我们提供了新的思路和工具,推动了智能系统在处理复杂问题时的表现。
如果本文对你有帮助,请动动小手点点关注哦~小肥肠将持续更新AI相关干货知识和好用工具。
相关文章:
LightRAG实战:轻松构建知识图谱,破解传统RAG多跳推理难题
作者:后端小肥肠 🍊 有疑问可私信或评论区联系我。 🥑 创作不易未经允许严禁转载。 姊妹篇: 2025防失业预警:不会用DeepSeek-RAG建知识库的人正在被淘汰_deepseek-embedding-CSDN博客 从PDF到精准答案:Coze…...
Hyperlane框架全面详解与应用指南 [特殊字符][特殊字符][特殊字符]
Hyperlane框架全面详解与应用指南 🚀🚀🚀 📚 前言 欢迎来到Hyperlane框架的全面详解与应用指南!🎉🎉🎉 本文档旨在为开发者提供一个全面、详尽的Hyperlane框架使用指南,…...
使用LVS的 NAT 模式实现 3 台RS的轮询访问
题目 使用LVS的 NAT 模式实现 3 台RS的轮询访问。IP地址和主机自己规划。 -i— turn,-g——DR模式,-m——NAT模式 节点规划 仅主机网段:192.168.216.0/24 NAT网段:192.168.88.0/24 主机角色系统网络ipclientclientredhat9.5仅…...
BGP路由协议之属性4
MED 多出口鉴别器 可选非过渡属性 EBGP 的邻居 Cost 开销值,控制如何进入 AS。越小越优。继承 IGP 的开销值,默认 0 MED(Multi-Exit Discriminator,多出口鉴别器)是可选非过属性,是一种度量值用于向外部对等体指出进入本 AS 的首…...
数据库的操作
1.创建数据库 CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification] ...]create_specification: [DEFAULT] CHARACTER SET charset_name [DEFAULT] COLLATE collation_name 大写的表示关键字。[]是可选项。CHARACTER SET:指定…...
【愚公系列】《高效使用DeepSeek》055-可靠性评估与提升
🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...
记录clickhouse记录一次性能优化,从60s到1s
文章目录 问题表结构类似如下分析第一步调整第一步观察多磁盘读继续观察sql 问题 一个查询接口,涉及多个clickhouse 查询,查询用时一下变成要60s 表结构类似如下 CREATE TABLE demo.test_local (id UUID,date DateTime,type String ) ENGINE Replic…...
二叉树的层序遍历
102. Binary Tree Level Order Traversal 广度优先搜索 将每个结点的层号记录下。 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* …...
嵌入式硬件篇---TOF陀螺仪SPI液晶屏
文章目录 前言1. TOF传感器(Time of Flight)原理STM32使用方法硬件连接SDASCLVCC\GND 软件配置初始化I2C外设库函数驱动:读取数据 2. 陀螺仪(如MPU6050)原理STM32使用方法硬件连接SDA/SCLINTVCC/GND 软件配置初始化I2C…...
OpenCV 在树莓派上进行实时人脸检测
这段 Python 代码借助 OpenCV 库实现了在树莓派上进行实时人脸检测的功能。它会开启摄像头捕获视频帧,在每一帧里检测人脸并以矩形框标记出来,同时在画面上显示帧率(FPS)。 依赖库 cv2:OpenCV 库,用于计算…...
55.跳跃游戏
题目来源: leetcode题目,网址:55. 跳跃游戏 - 力扣(LeetCode) 解题思路: 遍历数组,若当前节点可达,更新可到达的最远距离,否则返回false。若可遍历整个数组…...
awk 实现listagg ,count 功能
awk命令实现分组统计 测试数据 ABC a1 ABC a2 ABC a3 ABD c1 ABD c2 分组统计 abc a1,a2,a3 3 abd c1,c2 awk 命令 awk {arr[$1]arr[$1] ? arr[$1] "," $2 : $2; count[$1]} END{for (i in arr) print tolower(i), arr[i], count[i]} group_…...
瑞萨RA4M2使用心得-GPIO输出
目录 一、新建项目 二、图形化开发 1.初始化IO 2.界面介绍 3.代码编写 4.所有内部函数的封装位置 5.LED闪烁函数编写 三.debug运行 总结 环境: 开发板:RA-Eco-RA4M2-100PIN-V1.0 IDE:e2 studio 一、新建项目 正常操作,下…...
uniapp微信小程序引入vant组件库
1、首先要有uniapp项目,根据vant官方文档使用yarn或npm安装依赖: 1、 yarn init 或 npm init2、 # 通过 npm 安装npm i vant/weapp -S --production# 通过 yarn 安装yarn add vant/weapp --production# 安装 0.x 版本npm i vant-weapp -S --production …...
COZE通关指南:工作流与插件开发
前言 本文隶属于专栏《AI Agent 通关指南》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见《AI Agent 通关指南》 正文 1. 平台基础介绍 🌟 1.1 COZE平台概述 COZE平台(coze.cn)是一个强大的AI应用开发平台…...
在Unity中,如果物体上的脚本丢失,可以通过编写一个自定义编辑器脚本来查找并删除这些丢失的组件
在Unity中,如果物体上的脚本丢失,可以通过编写一个自定义编辑器脚本来查找并删除这些丢失的组件。以下是一个示例脚本,它可以帮助你一键检索场景中所有丢失脚本的物体,并删除这些丢失的组件。 步骤: 创建编辑器脚本&a…...
青少年编程与数学 02-016 Python数据结构与算法 04课题、栈与队列
青少年编程与数学 02-016 Python数据结构与算法 04课题、栈与队列 一、栈1. 栈的定义2. 栈的特点3. 栈的基本操作示例 4. 栈的实现(1)数组实现(2)链表实现 5. 栈的应用(1)函数调用(2)…...
Lucene.Net全文搜索引擎:架构解析与全流程实战指南
文章目录 引言:为什么选择Lucene.Net?一、Lucene.Net核心架构剖析1.1 模块化设计 二、Lucene.Net索引原理揭秘2.1 倒排索引:搜索的基石2.2 段(Segment)机制 三、全流程实战:从0到1构建搜索引擎3.1 环境准备…...
OpenSceneGraph 中的 LOD详解
LOD (Level of Detail,细节层次) 是3D图形中一种重要的优化技术,OpenSceneGraph 通过 osg::LOD 类提供了完整的LOD支持。 一、LOD 基本概念 1. 什么是LOD 核心思想:根据物体与相机的距离显示不同细节程度的模型 目的:减少远处物…...
程序化广告行业(64/89):AdX/SSP系统广告位设置全解析
程序化广告行业(64/89):AdX/SSP系统广告位设置全解析 大家好!我一直觉得在技术和营销不断融合的当下,程序化广告领域充满了机遇与挑战。之前和大家分享了程序化广告PDB模式的相关知识,今天想接着和大家一起…...
Pytorch中的计算图(Computational Graph)是什么
🧩 一、什么是计算图? 计算图是一种“有向无环图(DAG)”,表示变量(张量)之间的运算关系。 节点:张量或操作(如加法、乘法)边:数据流(即…...
Java 大视界 -- Java 大数据在航天遥测数据分析中的技术突破与应用(177)
💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…...
【Linux操作系统——学习笔记三】Linux环境下多级目录构建与管理的命令行实践报告
1.在用户主目录下,使用以下方法新建目录,并显示详细执行过程: (1)使用绝对路径在当前目录下创建 new_dir目录 (2)使用相对路径、在当前目录创建dir1、dir2、dir3目录 (3)…...
java.util.Collections中常用api
在Java中,java.util.Collections 是一个工具类,提供了大量静态方法用于操作或返回集合(如List、Set、Map等)。以下是常用的API分类整理: 1. 排序与顺序操作 sort(List<T> list) 对List进行自然顺序排序ÿ…...
批量将图片统一色调
from PIL import Image, ImageEnhance # 确保导入 ImageEnhance 模块 import osdef adjust_image_tone(image_path, output_path, r_weight1.0, g_weight1.0, b_weight1.0, brightness1.0):"""调整图片的色调、明暗,并进行去图处理。参数:image_pat…...
OCC Shape 操作
#pragma once #include <iostream> #include <string> #include <filesystem> #include <TopoDS_Shape.hxx> #include <string>class GeometryIO { public:// 加载几何模型:支持 .brep, .step/.stp, .iges/.igsstatic TopoDS_Shape L…...
docker的run命令 笔记250406
docker的run命令 笔记250406 Docker 的 run 命令用于创建并启动一个新的容器。它是 Docker 中最常用的命令之一,基本语法为: docker run [OPTIONS] IMAGE [COMMAND] [ARG...]常用选项(OPTIONS) 参数说明-d 或 --detach后台运行…...
批量将 HTML 转换为 Word/Txt/PDF 等其它格式
HTML是一种超文本标记语言,在进行网页编辑的时候非常常见,我们浏览的网站内容,都可以保存为 html 格式,如果想要将 html 格式的文档转为其它格式,比如 Word、PDF 或者 Txt,我们应该怎么做呢?今天…...
TPS入门DAY02 服务器篇
1.创建空白插件 2.导入在线子系统以及在线steam子系统库 MultiplayerSessions.uplugin MultiplayerSessions.Build.cs 3.创建游戏实例以及初始化会话创建流程 创建会话需要的函数,委托,委托绑定的回调,在线子系统接口绑定某一个委托的控制其…...
C高级,终端操作
核心要点整理 刷题作业 一、基础操作 命令行提示符结构 ubuntuubuntu:~$ 当前用户 | 连接符 | 计算机名 | 当前路径 | 用户权限 用户切换 su 用户名:切换用户sudo passwd 用户名:修改用户密码 常用指令 cd -:返回上一次路径ls:显…...
Lua语言的边缘计算
Lua语言的边缘计算探索 引言 随着物联网(IoT)、人工智能(AI)和大数据技术迅速发展,边缘计算作为一种分布式计算架构日益受到重视。其核心理念是将计算和数据存储资源更靠近数据源,以降低延迟、减轻网络负…...
RabbitMQ运维
RabbitMQ运维 一.集群1.简单介绍2.集群的作用 二.搭建集群1.多机多节点搭建步骤 2.单机单节点搭建步骤 3.宕机演示 三.仲裁队列1.简单介绍2.Raft协议Raft基本概念主节点选举选举过程 3.仲裁队列的使用 四.HAProxy负载均衡1.安装HAProxy2.HAProxy的使用 一.集群 1.简单介绍 Ra…...
【ESP32】ESP32物联网应用:MQTT控制与状态监测
ESP32物联网应用:MQTT控制与状态监测 引言 在物联网时代,远程监测和控制设备已经成为现实生活中常见的需求。本文将介绍如何使用ESP32微控制器配合MQTT协议,实现一个简单而强大的物联网应用:远程状态监测和设备控制。我们将以巴…...
如何保证RabbitMQ消息的可靠传输?
在这个图中,消息可能丢失的场景是1,2,3 1.在生产者将消息发送给RabbitMQ的时候,消息到底有没有正确的到达服务器呢,RabbitMQ提供了两种解决方案: a. 通过事务机制实现(比较消耗性能࿰…...
Redis高可用
主从复制 为什么要主从复制? 由于数据都是存储在一台服务器上,如果出事就完犊子了,比如: 如果服务器发生了宕机,由于数据恢复是需要点时间,那么这个期间是无法服务新的请求的;如果这台服务器…...
[项目总结] 在线OJ刷题系统项目技术应用(下)
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…...
链表算法中常用操作和技巧
目 1.常用技巧 1.1.画图 1.2.添加虚拟头节点 1.3.大胆引入中间变量 1.4.快慢双指针 1.4.1判断链表是否有环 1.4.2找链表中环的入口 2.常用操作 2.1. 创建一个新节点 2.2.尾插 2.3.头插 1.常用技巧 1.1.画图 画图可以让一些抽象的文字语言更加形象生动 画图&#…...
MySQL基础 [二] - 数据库基础
目录 库的增删查改 查看数据库 创建数据库 删除数据库 修改数据库 认识系统编码(字符集和校验规则) 查看系统默认字符集以及校验规则 查看数据库支持的字符集和字符集校验规则 验证不同校验码编码的影响 校验规则对数据库的影响 数据库的备份…...
【Linux篇】基础IO - 文件描述符的引入
📌 个人主页: 孙同学_ 🔧 文章专栏:Liunx 💡 关注我,分享经验,助你少走弯路! 文章目录 一. 理解文件1.1 侠义理解1.2 广义理解1.3 文件操作的归类认知1.4 系统角度 二. 回顾C语言文件…...
13.【.NET 8 实战--孢子记账--从单体到微服务--转向微服务】--微服务基础工具与技术--Refit
在微服务架构中,不同服务之间经常需要相互调用以完成复杂业务流程,而 Refit 能让这种“跨服务调用”变得简洁又可靠。开发者只需将对外暴露的 REST 接口抽象成 C# 接口,并通过共享库或内部 NuGet 包在各服务中引用,这种契约优先的…...
C++ 并发性能优化实战:提升多线程应用的效率与稳定性
🧑 博主简介:CSDN博客专家、CSDN平台优质创作者,获得2024年博客之星荣誉证书,高级开发工程师,数学专业,拥有高级工程师证书;擅长C/C、C#等开发语言,熟悉Java常用开发技术,…...
前端性能优化的全方位方案【待进一步结合项目】
以下是前端性能优化的全方位方案,结合代码配置和最佳实践,涵盖从代码编写到部署的全流程优化: 一、代码层面优化 1. HTML结构优化 <!-- 语义化标签减少嵌套 --> <header><nav>...</nav> </header> <main&…...
(undone) 并行计算 CS149 Lecture3 (现代多核处理器2 + ISPC编程抽象)
url: https://www.bilibili.com/video/BV1du17YfE5G?spm_id_from333.788.videopod.sections&vd_source7a1a0bc74158c6993c7355c5490fc600&p3 如上堂课,超线程技术通过储存不同线程的 execution context,能够在一个线程等待 IO 的时候低成本切换…...
DiffAD:自动驾驶的统一扩散建模方法
25年3月来自新加坡公司 Carion 和北航的论文“DiffAD: A Unified Diffusion Modeling Approach for Autonomous Driving”。 端到端自动驾驶 (E2E-AD) 已迅速成为实现完全自动驾驶的一种有前途的方法。然而,现有的 E2E-AD 系统通常采用传统的多任务框架,…...
QScrollArea 内部滚动条 QSS 样式失效问题及解决方案
在使用 Qt 进行 UI 开发时,我们经常希望通过 QSS(Qt Style Sheets)自定义控件的外观,比如为 QScrollArea 的内部滚动条设置特定的样式。然而,有开发者遇到了这样的问题:在 UI 设计器中预览 QSS 显示效果正常,但程序运行时却显示为系统默认样式。经过反复测试和调试,最终…...
换脸视频FaceFusion3.1.0-附整合包
2025版最强换脸软件FaceFusion来了(附整合包)超变态的AI换脸教程 2025版最强换脸软件FaceFusion来了(附整合包)超变态的AI换脸教程 整合包地址: 「Facefusion_V3.1.0」 链接:https://pan.quark.cn/s/f71601…...
Qt 入门 1 之第一个程序 Hello World
Qt 入门1之第一个程序 Hello World 直接上操作步骤从头开始认识,打开Qt Creator,创建一个新项目,并依次执行以下操作 在Qt Creator中,一个Kits 表示一个完整的构建环境,包括编译器、Qt版本、调试器等。在上图中可以直…...
无锁队列简介与实现示例
1. 简介 无锁队列是一种数据结构,旨在在多线程环境中实现高效的并发访问,而无需使用传统的锁机制(如互斥锁)。无锁队列通过使用原子操作(如CAS,Compare-And-Swap)来确保线程安全,从…...
SpringMVC与SpringCloud的区别
SpringMVC与SpringCloud的核心区别 功能定位 • SpringMVC: 基于Spring框架的Web层开发模块,采用MVC(Model-View-Controller)模式,专注于处理HTTP请求、路由分发(如DispatcherServlet)和视图…...
STM32F103C8T6单片机开发:简单说说单片机的外部GPIO中断(标准库)
目录 前言 如何使用STM32F1系列的标准库完成外部中断的抽象 初始化我们的GPIO为输入的一个模式 初识GPIO复用,开启GPIO的复用功能时钟 GPIO_EXTILineConfig和EXTI_Init配置外部中断参数 插入一个小知识——如何正确的配置结构体? 初始化中断&#…...