当前位置: 首页 > news >正文

数据库操作与数据管理——Rust 与 SQLite 的集成

第六章:数据库操作与数据管理
第一节:Rust 与 SQLite 的集成

在本节中,我们将深入探讨如何在 Rust 中使用 SQLite 数据库,涵盖从基本的 CRUD 操作到事务处理、数据模型的构建、性能优化以及安全性考虑等方面。SQLite 是一个轻量级的关系型数据库,适合嵌入式应用和小型项目。我们将利用 rusqlite 库高效地与 SQLite 进行交互。


1. 使用 rusqlite 进行基本 CRUD 操作
1.1 rusqlite 库的引入

首先,在 Cargo.toml 文件中添加 rusqlite 依赖:

[dependencies]
rusqlite = { version = "0.26", features = ["bundled"] }
1.2 连接到 SQLite 数据库
use rusqlite::{params, Connection, Result};fn connect_to_db() -> Result<Connection> {let conn = Connection::open("my_database.db")?;Ok(conn)
}
1.3 创建表

在执行任何 CRUD 操作之前,我们需要定义数据表。

fn create_table(conn: &Connection) -> Result<()> {conn.execute("CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY,name TEXT NOT NULL,age INTEGER NOT NULL)",[],)?;Ok(())
}
1.4 插入数据(Create)

我们可以通过以下代码插入数据到表中:

fn insert_user(conn: &Connection, name: &str, age: i32) -> Result<()> {conn.execute("INSERT INTO users (name, age) VALUES (?1, ?2)",params![name, age],)?;Ok(())
}
1.5 查询数据(Read)

查询数据可以使用 query_map 方法:

fn fetch_users(conn: &Connection) -> Result<Vec<(i32, String, i32)>> {let mut stmt = conn.prepare("SELECT id, name, age FROM users")?;let user_iter = stmt.query_map([], |row| {Ok((row.get(0)?, row.get(1)?, row.get(2)?))})?;let mut users = Vec::new();for user in user_iter {users.push(user?);}Ok(users)
}
1.6 更新数据(Update)
fn update_user_age(conn: &Connection, id: i32, new_age: i32) -> Result<()> {conn.execute("UPDATE users SET age = ?1 WHERE id = ?2",params![new_age, id],)?;Ok(())
}
1.7 删除数据(Delete)
fn delete_user(conn: &Connection, id: i32) -> Result<()> {conn.execute("DELETE FROM users WHERE id = ?1", params![id])?;Ok(())
}

2. 处理事务与连接池
2.1 事务的基本操作

使用事务可以确保一系列数据库操作的原子性。

fn transaction_example(conn: &Connection) -> Result<()> {conn.execute("BEGIN TRANSACTION", [])?;insert_user(conn, "Alice", 30)?;insert_user(conn, "Bob", 25)?;conn.execute("COMMIT", [])?;Ok(())
}
2.2 处理错误与回滚

在执行事务时,如果出现错误,我们应该回滚事务。

fn safe_transaction(conn: &Connection) -> Result<()> {let transaction = conn.transaction()?;transaction.execute("INSERT INTO users (name, age) VALUES (?1, ?2)", params!["Charlie", 28])?;// 故意造成错误transaction.execute("INSERT INTO users (name, age) VALUES (?1, ?2)", params![None::<String>, 28])?;transaction.commit()?;Ok(())
}
2.3 使用连接池

使用连接池可以提高性能,允许多个线程安全地共享数据库连接。

use r2d2::Pool;
use r2d2_sqlite::SqliteConnectionManager;fn create_pool() -> Pool<SqliteConnectionManager> {let manager = SqliteConnectionManager::new("my_database.db");Pool::builder().build(manager).unwrap()
}

3. 数据模型与查询构建
3.1 定义数据模型

使用 Rust 结构体表示数据模型,使数据操作更加明确。

#[derive(Debug)]
struct User {id: i32,name: String,age: i32,
}
3.2 从数据库映射到模型

编写函数将数据库记录映射到模型:

fn map_row_to_user(row: &rusqlite::Row) -> User {User {id: row.get(0).unwrap(),name: row.get(1).unwrap(),age: row.get(2).unwrap(),}
}
3.3 动态查询构建

使用 rusqliteQuery 来构建动态查询,以支持不同的查询条件。

fn fetch_users_with_conditions(conn: &Connection, min_age: Option<i32>) -> Result<Vec<User>> {let mut query = String::from("SELECT id, name, age FROM users");let mut params: Vec<&(dyn rusqlite::ToSql + 'static)> = Vec::new();if let Some(age) = min_age {query.push_str(" WHERE age >= ?");params.push(&age);}let mut stmt = conn.prepare(&query)?;let user_iter = stmt.query_map(params, |row| map_row_to_user(row))?;let mut users = Vec::new();for user in user_iter {users.push(user?);}Ok(users)
}
3.4 连接模型与业务逻辑

通过将数据库操作封装在服务层,将数据模型与业务逻辑分离,确保代码的可维护性。

struct UserService {conn: Connection,
}impl UserService {fn new(conn: Connection) -> Self {UserService { conn }}fn add_user(&self, name: &str, age: i32) -> Result<()> {insert_user(&self.conn, name, age)}fn get_all_users(&self) -> Result<Vec<User>> {fetch_users(&self.conn)}
}

4. 性能优化
4.1 使用索引

在处理大量数据时,使用索引可以显著提高查询速度。

fn create_index(conn: &Connection) -> Result<()> {conn.execute("CREATE INDEX idx_user_name ON users (name)", [])?;Ok(())
}
4.2 批量插入

在插入大量数据时,可以使用批量插入来提高性能。

fn batch_insert(conn: &Connection, users: Vec<(String, i32)>) -> Result<()> {let tx = conn.transaction()?;for (name, age) in users {tx.execute("INSERT INTO users (name, age) VALUES (?1, ?2)", params![name, age])?;}tx.commit()?;Ok(())
}
4.3 减少数据库往返

尽量减少与数据库的交互次数,可以通过使用预处理语句或批量操作实现。


5. 安全性考虑

在进行数据库操作时,确保数据的安全性和完整性是至关重要的。以下是一些重要的安全性考虑因素,帮助开发者在使用 Rust 与 SQLite 进行数据库操作时,最大程度地保护应用程序和用户数据。

5.1 防止 SQL 注入

SQL 注入是数据库安全中最常见的攻击方式之一。攻击者通过在 SQL 查询中插入恶意代码,从而获取、修改或删除数据。为了防止 SQL 注入,采用参数化查询是最有效的方法。

fn safe_insert_user(conn: &Connection, name: &str, age: i32) -> Result<()> {conn.execute("INSERT INTO users (name, age) VALUES (?1, ?2)",params![name, age],)?;Ok(())
}

关键点:

  • 参数化查询:总是使用参数化查询而不是将用户输入直接拼接到 SQL 字符串中。
  • 使用库功能:利用 rusqlite 提供的安全 API,避免手动构建 SQL 字符串。
5.2 数据加密

对于敏感数据,尤其是用户的个人信息、信用卡号码等,应该使用加密技术进行存储。Rust 提供了多个加密库,比如 aesrust-crypto 等,可以轻松实现数据的加密和解密。

use aes::{Aes128, NewBlockCipher, BlockEncrypt, BlockDecrypt};
use aes::block_cipher_trait::generic_array::GenericArray;fn encrypt_data(data: &[u8], key: &[u8; 16]) -> Vec<u8> {let cipher = Aes128::new(GenericArray::from_slice(key));let mut block = GenericArray::clone_from_slice(data);cipher.encrypt_block(&mut block);block.to_vec()
}fn decrypt_data(encrypted_data: &[u8], key: &[u8; 16]) -> Vec<u8> {let cipher = Aes128::new(GenericArray::from_slice(key));let mut block = GenericArray::clone_from_slice(encrypted_data);cipher.decrypt_block(&mut block);block.to_vec()
}

关键点:

  • 选择合适的加密算法:选择适合您应用程序需求的加密算法,AES 是一个普遍推荐的选择。
  • 密钥管理:确保密钥的安全存储与管理,避免将密钥硬编码到代码中。
5.3 用户输入验证

确保所有用户输入都经过严格验证,避免不合法或恶意数据进入数据库。这包括检查数据类型、长度、格式等。

fn validate_user_input(name: &str, age: i32) -> Result<()> {if name.len() > 50 {return Err(rusqlite::Error::UserFunctionError("Name too long".into()));}if age < 0 {return Err(rusqlite::Error::UserFunctionError("Invalid age".into()));}Ok(())
}

关键点:

  • 使用正则表达式:对复杂输入(如电子邮件、电话号码)使用正则表达式进行验证。
  • 长度和类型检查:确保输入的数据类型和长度符合预期,防止意外错误和数据损坏。
5.4 身份验证与授权

确保只有经过身份验证的用户才能访问敏感数据或执行重要操作。可以使用 JWT(JSON Web Tokens)或 OAuth 2.0 等现代身份验证方法。

fn verify_user(token: &str) -> Result<bool> {// 此处可使用 JWT 解码和验证逻辑Ok(true) // 简化示例
}

关键点:

  • 确保安全的认证流程:实现安全的登录流程,使用 HTTPS 保护数据传输。
  • 最小权限原则:每个用户和角色应仅能访问其工作所需的数据,避免不必要的权限。
5.5 日志记录与监控

有效的日志记录和监控可以帮助识别和响应安全事件。记录所有的数据库操作、异常和潜在的安全威胁。

fn log_operation(action: &str) {// 记录数据库操作println!("Operation logged: {}", action);
}

关键点:

  • 详细的日志记录:记录操作的时间、执行者和操作内容,便于后续审计。
  • 监控与警报:设置监控系统,及时警报异常活动,例如频繁的失败登录尝试。

小结

在数据库操作中,安全性是一个不容忽视的重要方面。通过防止 SQL 注入、加密敏感数据、验证用户输入、实施身份验证和授权机制以及有效的日志记录和监控,可以显著提高应用程序的安全性。务必在开发过程中将这些安全性考虑融入设计中,以保护用户数据和应用程序的完整性。

进一步学习
  • 深入研究 Rust 的安全特性:了解 Rust 语言如何在编译时避免许多常见的安全漏洞。
  • 数据库安全最佳实践:研究数据库安全的行业标准和最佳实践。
  • 加密算法的选择与实现:探索不同加密算法的优缺点,并尝试在 Rust 中实现更多的加密技术。

相关文章:

数据库操作与数据管理——Rust 与 SQLite 的集成

第六章&#xff1a;数据库操作与数据管理 第一节&#xff1a;Rust 与 SQLite 的集成 在本节中&#xff0c;我们将深入探讨如何在 Rust 中使用 SQLite 数据库&#xff0c;涵盖从基本的 CRUD 操作到事务处理、数据模型的构建、性能优化以及安全性考虑等方面。SQLite 是一个轻量…...

Linux文件目录基本操作

目录 目录概述相关操作函数相关数据结构体说明 目录概述 什么是目录&#xff1f; 在linux操作系统中其实目录也是一种文件&#xff0c;相对于普通文件&#xff0c;它的存储内容不同&#xff0c;它的存储内容主要是当前目录下的文件以及子目录文件信息。目录就像是一颗大树&a…...

TaskBuilder项目实战:创建项目

用TaskBuilder开发应用系统的第一步就是创建项目&#xff0c;项目可以是一个简单的功能模块&#xff0c;也可以是很多功能模块的集合&#xff0c;具体怎么划分看各位的实际需要&#xff0c;我们一般会将相互关联比较紧密的一组功能模块放到一个独立的项目内&#xff0c;以便打包…...

使用DeepSeek的技巧笔记

来源&#xff1a;新年逼自己一把&#xff0c;学会使用DeepSeek R1_哔哩哔哩_bilibili 前言 对于DeepSeek而言&#xff0c;我们不再需要那么多的提示词技巧&#xff0c;但还是要有两个注意点&#xff1a;你需要理解大语言模型的工作原理与局限,这能帮助你更好的知道AI可完成任务…...

使用Python实现PDF与SVG相互转换

目录 使用工具 使用Python将SVG转换为PDF 使用Python将SVG添加到现有PDF中 使用Python将PDF转换为SVG 使用Python将PDF的特定页面转换为SVG SVG&#xff08;可缩放矢量图形&#xff09;和PDF&#xff08;便携式文档格式&#xff09;是两种常见且广泛使用的文件格式。SVG是…...

idea整合deepseek实现AI辅助编程

1.File->Settings 2.安装插件codegpt 3.注册deepseek开发者账号&#xff0c;DeepSeek开放平台 4.按下图指示创建API KEY 5.回到idea配置api信息&#xff0c;File->Settings->Tools->CodeGPT->Providers->Custom OpenAI API key填写deepseek的api key Chat…...

java文件上传粗糙版

粗糙版图片上传 1.导入依赖 <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.5.2</version> </dependency> 2.配置minio地址跟对应的桶 业务层实现类 import io.minio.MinioClient; /…...

一种基于Leaflet.Legend的图例动态更新方法

目录 前言 一、场景再现 1、需求描述 2、核心方法介绍 3、存在的问题 二、问题解决 1、重复解决办法 2、图例不展示解决办法 3、成果展示 三、总结 前言 在当今数字化时代&#xff0c;地理信息系统&#xff08;GIS&#xff09;技术已经广泛应用于各个领域&#xff0c;…...

Vue Dom截图插件,截图转Base64 html2canvas

安装插件 npm install html2canvas --save插件使用 <template><div style"padding: 10px;"><div ref"imageTofile" class"box">发生什么事了</div><button click"toImage" style"margin: 10px;&quo…...

安宝特方案 | AR眼镜:远程医疗的“时空折叠者”,如何为生命争夺每一分钟?

行业痛点&#xff1a;当“千里求医”遇上“资源鸿沟” 20世纪50年代&#xff0c;远程会诊的诞生曾让医疗界为之一振——患者不必跨越山河&#xff0c;专家无需舟车劳顿&#xff0c;一根电话线、一张传真纸便能架起问诊的桥梁。然而&#xff0c;传统远程医疗的局限也日益凸显&a…...

【人工智能】Python中的序列到序列(Seq2Seq)模型:实现机器翻译

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 序列到序列(Seq2Seq)模型是自然语言处理(NLP)中一项核心技术,广泛应用于机器翻译、语音识别、文本摘要等任务。本文深入探讨Seq2Seq模…...

【批量获取图片信息】批量获取图片尺寸、海拔、分辨率、GPS经纬度、面积、位深度、等图片属性里的详细信息,提取出来后导出表格,基于WPF的详细解决方案

摄影工作室通常会有大量的图片素材&#xff0c;在进行图片整理和分类时&#xff0c;需要知道每张图片的尺寸、分辨率、GPS 经纬度&#xff08;如果拍摄时记录了&#xff09;等信息&#xff0c;以便更好地管理图片资源&#xff0c;比如根据图片尺寸和分辨率决定哪些图片适合用于…...

关于32位和64位程序的传参方法及虚拟机调试工具总结

一、传参方法对比 1. 32位程序 系统调用 (Linux) 使用int 0x80指令触发系统调用 寄存器传参顺序&#xff1a; eax 系统调用号 ebx 第1个参数 ecx 第2个参数 edx 第3个参数 esi 第4个参数 edi 第5个参数 普通函数调用 (C语言) 栈传递参数&#xff1a;参数从右向左压栈…...

【Windows】PowerShell 缓存区大小调节

PowerShell 缓存区大小调节 方式1 打开powershell 窗口属性调节方式2&#xff0c;修改 PowerShell 配置文件 方式1 打开powershell 窗口属性调节 打开 CMD&#xff08;按 Win R&#xff0c;输入 cmd&#xff09;。右键标题栏 → 选择 属性&#xff08;Properties&#xff09;…...

查看云机器的一些常用配置

云原生学习路线导航页&#xff08;持续更新中&#xff09; kubernetes学习系列快捷链接 Kubernetes架构原则和对象设计&#xff08;一&#xff09;Kubernetes架构原则和对象设计&#xff08;二&#xff09;Kubernetes架构原则和对象设计&#xff08;三&#xff09;Kubernetes常…...

约克VRF|冬日舒适新标杆,温暖每一寸空间

冬天来了&#xff0c;谁不想窝在家里&#xff0c;一边温暖舒适&#xff0c;一边畅享清新空气&#xff1f;      约克VRF中央空调——用科技为你打造全方位的冬季理想生活&#xff01;      地暖空调二合一&#xff0c;暖从足起&#xff0c;养生更健康~      普通取…...

【AI学习】关于 DeepSeek-R1的几个流程图

遇见关于DeepSeek-R1的几个流程图&#xff0c;清晰易懂形象直观&#xff0c;记录于此。 流程图一 来自文章《Understanding Reasoning LLMs》&#xff0c; 文章链接&#xff1a;https://magazine.sebastianraschka.com/p/understanding-reasoning-llms?continueFlagaf07b1a0…...

CNN卷积神经网络多变量多步预测,光伏功率预测(Matlab完整源码和数据)

代码地址&#xff1a;CNN卷积神经网络多变量多步预测&#xff0c;光伏功率预测&#xff08;Matlab完整源码和数据) 标题&#xff1a;CNN卷积神经网络多变量多步预测&#xff0c;光伏功率预测 一、引言 1.1 研究背景及意义 随着全球能源危机的加剧和环保意识的提升&#xff…...

mapbox进阶,添加绘图扩展插件,绘制圆形

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️MapboxDraw 绘图控件二、🍀添加绘图扩…...

学习TCL脚本基础语法的几个步骤?

文章目录 前言1. 命令和参数1.1 Tcl 命令的基本结构1.2 示例1.2.1 puts 命令1.2.2 set 命令1.2.3 if 命令1.2.4 foreach 命令 1.3 参数的类型1.3.1 字符串1.3.2 变量1.3.3 表达式1.3.4 列表1.3.5 字典 1.4 命令的嵌套 二、变量1. 声明变量2. 使用变量3. 变量类型3.1 字符串3.2 …...

move_base全局路径规划震荡之参数调优

在使用 move_base 进行导航时&#xff0c;如果全局路径规划在遇到障碍物时频繁在障碍物左右两侧跳变&#xff0c;导致机器人绕障失败&#xff0c;通常可以通过调整参数优化来解决。以下是具体原因分析和解决方案&#xff1a; 问题原因分析&#xff1a; 全局路径规划的震荡&…...

Could not create task ‘:mainActivity:minifyReleaseWithR8‘.

最近接收了一个老项目&#xff0c;把项目clone下来后&#xff0c;总是报错&#xff0c;无法运行 Build-tool 33.0.1 is missing DX at D:\Android\Sdk\build-tools\33.0.1\dx.batFAILURE: Build failed with an exception.* What went wrong: Could not determine the depende…...

保姆级教程Docker部署Zookeeper官方镜像

目录 1、安装Docker及可视化工具 2、创建挂载目录 3、运行Zookeeper容器 4、Compose运行Zookeeper容器 5、查看Zookeeper运行状态 6、验证Zookeeper是否正常运行 1、安装Docker及可视化工具 Docker及可视化工具的安装可参考&#xff1a;Ubuntu上安装 Docker及可视化管理…...

人工智能-A* 算法与机器学习算法结合

以下将为你展示如何将 A* 算法与机器学习算法&#xff08;这里以简单的神经网络为例&#xff09;结合实现路径规划。我们会先使用 A* 算法生成一些路径规划数据&#xff0c;然后用这些数据训练一个简单的神经网络&#xff0c;让神经网络学习如何预测路径。最后&#xff0c;将训…...

如何在Python中使用Requests库?

在Python中&#xff0c;网络请求处理是很多应用开发中的常见需求。Requests库作为Python中最常用的第三方库之一&#xff0c;它能够简化HTTP请求的发送和响应的处理。无论是获取网页内容、与API接口交互&#xff0c;还是提交表单数据&#xff0c;Requests都可以帮助开发者轻松实…...

通过命令行运行py文件与通过ide运行py文件,对文件中模块的引用方式的影响

通过命令行运行 Python 文件和通过 IDE 运行 Python 文件时&#xff0c;模块的引用方式 会受到一些影响&#xff0c;主要体现在 工作目录 和 模块导入路径&#xff08;sys.path&#xff09;的设置上。下面详细介绍这两种方式的区别和它们如何影响模块引用。 1. 通过命令行运行…...

如何避免大语言模型中涉及丢番图方程的问题

希尔伯特第十问题是一个著名的数学问题,涉及不定方程(又称为丢番图方程)的可解答性。然而在大模型中,我们希望问题都是确定的可解的,或者说要尽可能的想办法避免不确定的不可解问题。由于丢番图方程问题是不可判定问题(即不存在一个有效的算法能够解决该类问题的所有实例…...

重新刷题求职2-DAY7

1.454. 四数相加 II 给你四个整数数组 nums1、nums2、nums3 和 nums4 &#xff0c;数组长度都是 n &#xff0c;请你计算有多少个元组 (i, j, k, l) 能满足&#xff1a; 0 < i, j, k, l < nnums1[i] nums2[j] nums3[k] nums4[l] 0 示例 1&#xff1a; 输入&#…...

Day 32 卡玛笔记

这是基于代码随想录的每日打卡 455. 分发饼干 假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[i]&#xff0c;这是能让孩子们满足胃口的饼干的最小尺寸&#xff…...

android studio无痛入门

在Android Studio中创建和管理项目主要涉及以下几个步骤&#xff1a; 1. 创建新项目 打开Android Studio&#xff0c;点击“Start a new Android Studio project”或者“File” > “New” > “New Project”。 选择一个模板&#xff0c;例如“Empty Activity”&#xff0…...

flutter安卓打包签名

flutter安卓打包签名 1.创建签名文件 keytool -genkeypair -v -keystore my-release-key.jks -keyalg RSA -keysize 2048 -validity 10000 -alias my-key-aliaskeytool 是一个用于管理密钥和证书的命令行工具&#xff0c;通常与 Java 开发工具包 (JDK) 一起使用。my-release-…...

Windows编程:下载与安装 Visual Studio 2019

本节前言 在写作本节的时候&#xff0c;本来呢&#xff0c;我正在写的专栏&#xff0c;是 MFC 专栏。而 VS2010 和 VS2019&#xff0c;正是 MFC 学习与开发中&#xff0c;可以使用的两款软件。然而呢&#xff0c;如果你去学习 Windows API 知识的话&#xff0c;那么&#xff0…...

ElementUI的<el-image>组件引用网络图片加载失败

1. 验证图片 URL 是否有效 直接访问图片链接&#xff0c;确保 URL 正确且可公开访问 如果浏览器无法加载图片&#xff0c;可能是图片服务器限制了外链或已失效。 解决方法&#xff1a;更换为可用的图片 URL。 2. 检查浏览器开发者工具 打开浏览器开发者工具&#xff08;F12…...

GitHub Pages + Jekyll 博客搭建指南(静态网站)

目录 &#x1f680; 静态网站及其生成工具指南&#x1f30d; 什么是静态网站&#xff1f;&#x1f4cc; 静态网站的优势⚖️ 静态网站 VS 动态网站 &#x1f680; 常见的静态网站生成器对比&#x1f6e0;️ 使用 GitHub Pages Jekyll 搭建个人博客&#x1f4cc; 1. 创建 GitHu…...

idea项目列表不出现,展示loading

2025年02月08 11:23:36 星期六 发生在webstorm中&#xff0c;跟其他idea类似 原因是将 ignore 插件升级到 4.5.5 版本 https://github.com/JetBrains/idea-gitignore/pull/933 解决方案&#xff1a;将ignore版本将为 4.5.4 我是将 4.5.5 降低为 4.5.4 正常显示文件夹了。...

多智能体协作架构模式:驱动传统公司向AI智能公司转型

前言 在数字化浪潮的席卷下&#xff0c;传统公司的运营模式正面临着前所未有的挑战。随着市场竞争的日益激烈&#xff0c;客户需求的快速变化以及业务复杂度的不断攀升&#xff0c;传统公司在缺乏 AI 技术支撑的情况下&#xff0c;暴露出诸多痛点。在决策层面&#xff0c;由于…...

新增md、html压缩文档上传,开放接口访问密钥改为多个,zyplayer-doc 2.4.7 发布啦!

zyplayer-doc是一款适合企业和个人使用的WIKI知识库管理工具&#xff0c;支持在线编辑富文本、Markdown、表格、Office文档、API接口、思维导图、Drawio以及任意的文本文件&#xff0c;专为私有化部署而设计&#xff0c;最大程度上保证企业或个人的数据安全&#xff0c;支持以内…...

w~Transformer~合集5

我自己的原文哦~ https://blog.51cto.com/whaosoft/12406495 #transformer~x1 太可怕了都到6了 太强~~ DeepMind 表示&#xff0c;他们提出的算法蒸馏&#xff08;AD&#xff09;是首个通过对具有模仿损失的离线数据进行顺序建模以展示上下文强化学习的方法。同时基于观察…...

Dubbo 3.x源码(29)—Dubbo Consumer服务调用源码(1)服务调用入口

基于Dubbo 3.1&#xff0c;详细介绍了Dubbo Consumer服务调用源码。 此前我们学习了Dubbo服务的导出和引入的源码&#xff0c;现在我们来学习Dubbo服务调用的源码。 此前的文章中我们讲过了最上层代理的调用逻辑(服务引用bean的获取以及懒加载原理)&#xff1a;业务引入的接口…...

Linux内核同步机制:确保系统稳定与高效

在复杂而庞大的 Linux 系统世界中&#xff0c;内核就如同一位有条不紊的指挥官&#xff0c;协调着各种任务和资源的分配。而其中&#xff0c;内核同步机制则是确保整个系统稳定与高效运行的关键要素。想象一下&#xff0c;众多的进程和线程在 Linux 内核的舞台上同时登场&#…...

firebase简介

Firebase 是一个由 Google 提供的移动应用开发平台&#xff0c;旨在帮助开发者快速构建和管理应用程序。它提供了一系列强大的工具和服务&#xff0c;特别适合用于开发和管理 Web 和移动应用。以下是 Firebase 的一些核心功能&#xff1a; 实时数据库&#xff1a;Firebase 提供…...

利用Termux在安卓手机中安装 PostgreSQL

利用Termux在安卓手机中安装 PostgreSQL ⬇️Termux下载 点击下载 在 Termux 中安装 PostgreSQL 可以按照以下步骤进行&#xff1a; 1. 更新 Termux 包管理器 先更新软件包列表和已安装的软件包&#xff1a; pkg update && pkg upgrade -y2. 安装 PostgreSQL 使…...

windows安装WSL完整指南

本文首先介绍WSL&#xff0c;然后一步一步安装WSL及Ubuntu系统&#xff0c;最后讲解如何在两个系统之间访问和共享文件信息。通过学习该完整指南&#xff0c;能帮助你快速安装WSL&#xff0c;解决安装和使用过程中的常见问题。 理解WSL&#xff08;Windows Subsystem for Linux…...

Windows Docker笔记-安装docker

安装环境 操作系统&#xff1a;Windows 11 家庭中文版 docker版本&#xff1a;Docker Desktop version: 4.36.0 (175267) 注意&#xff1a; Docker Desktop 支持以下Windows操作系统&#xff1a; 支持的版本&#xff1a;Windows 10&#xff08;家庭版、专业版、企业版、教育…...

ReactNative进阶(五十九):存量 react-native 项目适配 HarmonyOS NEXT

文章目录 一、前言二、ohos_react_native2.1 Fabric2.2 TurboModule2.2.1 ArkTSTurboModule2.2.2 cxxTurboModule&#xff1a; 三、拓展阅读 一、前言 2024年10月22日19:00&#xff0c;华为在深圳举办“原生鸿蒙之夜暨华为全场景新品发布会”&#xff0c;主题为“星河璀璨&…...

[x86 ubuntu22.04]进入S4失败

目录 1 问题描述 2 解决过程 2.1 查看内核日志 2.2 新建一个交换分区 2.3 指定交换分区的位置 1 问题描述 CPU&#xff1a;G6900E OS&#xff1a;ubuntu22.04 Kernel&#xff1a;6.8.0-49-generic 使用“echo disk > /sys/power/state”命令进入 S4&#xff0c;但是无法…...

Java面试题-MySQL数据库

文章目录 1.事务1.事务的特性 ACID2.并发事务问题3.undo log 和redo log的区别&#xff1f;4.事务的隔离性是如何保证的呢&#xff1f;解释一下MVCC&#xff1f; 2.索引1.如何定位慢查询&#xff1f;2.explain3.了解过索引吗&#xff1f;索引的底层数据结构B树和B树对比4.什么是…...

为什么Vue的data属性是函数而不是对象

Vue中data属性设计为函数而非对象的原因是解决组件复用时的数据隔离问题。确保每个实例维护独立的数据副本&#xff0c;避免数据共享导致的状态污染。 而根实例因为只会被创建一次(不会被复用)&#xff0c;所以可以直接用对象&#xff0c;不会有这个问题。 组件一般都会被多个实…...

网络工程师 (26)TCP/IP体系结构

一、层次 四层&#xff1a; 网络接口层&#xff1a;TCP/IP协议的最底层&#xff0c;负责网络层与硬件设备间的联系。该层协议非常多&#xff0c;包括逻辑链路和媒体访问控制&#xff0c;负责与物理传输的连接媒介打交道&#xff0c;主要功能是接收数据报&#xff0c;并把接收到…...

MySQL部署基于二进制日志文件位置的主从复制集群

MySQL主从复制介绍 MySQL 主从复制&#xff08;Master-Slave Replication&#xff09; 作为一种经典的数据库复制方案&#xff0c;被广泛应用于企业生产环境&#xff0c;尤其是在提升数据库性能、实现数据备份和分布式扩展方面具有重要作用。 官方文档&#xff1a;https://de…...