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

JavaScript系列(61)--边缘计算应用开发详解

JavaScript边缘计算应用开发详解 🌐

今天,让我们深入探讨JavaScript的边缘计算应用开发。边缘计算是一种将计算和数据存储分布到更靠近数据源的位置的架构模式,它能够提供更低的延迟和更好的实时性能。

边缘计算基础架构 🌟

💡 小知识:边缘计算通过将计算任务分散到网络边缘节点来减少延迟和带宽使用,同时提供更好的实时响应能力和离线处理能力。

// 1. 边缘节点管理器
class EdgeNodeManager {constructor() {this.nodes = new Map();this.status = new Map();this.healthChecks = new Map();}// 注册边缘节点registerNode(nodeId, config) {this.nodes.set(nodeId, {id: nodeId,config,status: 'INITIALIZING',lastHeartbeat: Date.now()});this.startHealthCheck(nodeId);}// 启动健康检查startHealthCheck(nodeId) {const interval = setInterval(async () => {try {await this.checkNodeHealth(nodeId);} catch (error) {this.handleNodeFailure(nodeId, error);}}, 30000); // 每30秒检查一次this.healthChecks.set(nodeId, interval);}// 检查节点健康状态async checkNodeHealth(nodeId) {const node = this.nodes.get(nodeId);if (!node) return;try {const response = await fetch(`${node.config.url}/health`);const status = await response.json();this.updateNodeStatus(nodeId, {status: 'HEALTHY',metrics: status.metrics,lastHeartbeat: Date.now()});} catch (error) {throw new Error(`Health check failed: ${error.message}`);}}// 处理节点故障handleNodeFailure(nodeId, error) {const node = this.nodes.get(nodeId);if (!node) return;this.updateNodeStatus(nodeId, {status: 'UNHEALTHY',error: error.message,lastHeartbeat: Date.now()});// 触发故障转移this.triggerFailover(nodeId);}// 更新节点状态updateNodeStatus(nodeId, status) {const node = this.nodes.get(nodeId);if (!node) return;Object.assign(node, status);this.nodes.set(nodeId, node);this.emit('nodeStatusChanged', { nodeId, status });}// 触发故障转移triggerFailover(failedNodeId) {const failedNode = this.nodes.get(failedNodeId);if (!failedNode) return;// 寻找健康的备用节点const healthyNodes = Array.from(this.nodes.values()).filter(node => node.id !== failedNodeId && node.status === 'HEALTHY');if (healthyNodes.length > 0) {this.migrateWorkload(failedNode, healthyNodes[0]);}}
}// 2. 任务调度器
class TaskScheduler {constructor() {this.tasks = new Map();this.workers = new Map();this.queue = [];}// 注册任务registerTask(taskId, config) {this.tasks.set(taskId, {id: taskId,config,status: 'PENDING'});}// 分配任务async scheduleTask(taskId) {const task = this.tasks.get(taskId);if (!task) throw new Error('Task not found');// 找到最合适的workerconst worker = this.findBestWorker(task);if (!worker) {this.queue.push(task);return;}try {await this.executeTask(task, worker);} catch (error) {this.handleTaskFailure(task, error);}}// 查找最佳workerfindBestWorker(task) {return Array.from(this.workers.values()).filter(worker => worker.status === 'AVAILABLE').sort((a, b) => a.load - b.load)[0];}// 执行任务async executeTask(task, worker) {task.status = 'RUNNING';worker.load++;try {const result = await worker.execute(task.config);this.handleTaskSuccess(task, result);} finally {worker.load--;}}
}// 3. 数据同步管理器
class DataSyncManager {constructor() {this.syncQueue = new Map();this.conflicts = new Map();}// 添加同步任务addSyncTask(data, priority = 'normal') {const taskId = this.generateTaskId();this.syncQueue.set(taskId, {data,priority,status: 'PENDING',retries: 0});this.processSyncQueue();}// 处理同步队列async processSyncQueue() {const tasks = Array.from(this.syncQueue.values()).sort((a, b) => this.getPriorityScore(b.priority) - this.getPriorityScore(a.priority));for (const task of tasks) {if (task.status === 'PENDING') {await this.syncData(task);}}}// 同步数据async syncData(task) {try {task.status = 'SYNCING';await this.sendToServer(task.data);task.status = 'COMPLETED';} catch (error) {this.handleSyncError(task, error);}}// 处理同步错误handleSyncError(task, error) {task.retries++;if (task.retries < 3) {task.status = 'PENDING';setTimeout(() => this.syncData(task), Math.pow(2, task.retries) * 1000);} else {task.status = 'FAILED';this.conflicts.set(task.data.id, {task,error,timestamp: Date.now()});}}
}

离线处理能力 💾

// 1. 离线存储管理器
class OfflineStorageManager {constructor() {this.db = null;this.initDatabase();}// 初始化IndexedDBasync initDatabase() {return new Promise((resolve, reject) => {const request = indexedDB.open('EdgeDB', 1);request.onerror = () => reject(request.error);request.onsuccess = () => {this.db = request.result;resolve();};request.onupgradeneeded = (event) => {const db = event.target.result;// 创建存储对象if (!db.objectStoreNames.contains('data')) {db.createObjectStore('data', { keyPath: 'id' });}};});}// 存储数据async store(data) {return new Promise((resolve, reject) => {const transaction = this.db.transaction(['data'], 'readwrite');const store = transaction.objectStore('data');const request = store.put(data);request.onerror = () => reject(request.error);request.onsuccess = () => resolve(request.result);});}// 检索数据async retrieve(id) {return new Promise((resolve, reject) => {const transaction = this.db.transaction(['data'], 'readonly');const store = transaction.objectStore('data');const request = store.get(id);request.onerror = () => reject(request.error);request.onsuccess = () => resolve(request.result);});}
}// 2. 离线操作队列
class OfflineOperationQueue {constructor() {this.queue = [];this.processing = false;}// 添加操作addOperation(operation) {this.queue.push({operation,timestamp: Date.now(),status: 'PENDING'});this.processQueue();}// 处理队列async processQueue() {if (this.processing || this.queue.length === 0) return;this.processing = true;while (this.queue.length > 0) {const item = this.queue[0];try {await this.executeOperation(item.operation);this.queue.shift();} catch (error) {if (!navigator.onLine) {// 如果离线,停止处理break;}// 如果在线但失败,移到队列末尾this.queue.push(this.queue.shift());}}this.processing = false;}// 执行操作async executeOperation(operation) {// 实现具体的操作执行逻辑await operation();}
}// 3. 冲突解决器
class ConflictResolver {constructor() {this.strategies = new Map();}// 注册解决策略registerStrategy(type, strategy) {this.strategies.set(type, strategy);}// 解决冲突async resolveConflict(localData, serverData) {const type = this.getConflictType(localData, serverData);const strategy = this.strategies.get(type);if (!strategy) {throw new Error(`No strategy found for conflict type: ${type}`);}return strategy(localData, serverData);}// 获取冲突类型getConflictType(localData, serverData) {if (!serverData) return 'CREATE';if (localData.version > serverData.version) return 'UPDATE';return 'CONFLICT';}
}

性能优化策略 ⚡

// 1. 资源预加载器
class ResourcePreloader {constructor() {this.cache = new Map();this.priorities = new Map();}// 添加预加载资源addResource(url, priority = 'normal') {this.priorities.set(url, priority);this.preloadResource(url);}// 预加载资源async preloadResource(url) {if (this.cache.has(url)) return;try {const response = await fetch(url);const data = await response.blob();this.cache.set(url, data);} catch (error) {console.error(`Failed to preload ${url}:`, error);}}// 获取资源async getResource(url) {if (!this.cache.has(url)) {await this.preloadResource(url);}return this.cache.get(url);}
}// 2. 计算任务优化器
class ComputeOptimizer {constructor() {this.workers = new Set();this.taskQueue = [];}// 初始化Web WorkersinitializeWorkers(count = navigator.hardwareConcurrency) {for (let i = 0; i < count; i++) {const worker = new Worker('compute-worker.js');this.workers.add(worker);}}// 提交计算任务async submitTask(task) {if (this.workers.size === 0) {this.initializeWorkers();}return new Promise((resolve, reject) => {const worker = this.getAvailableWorker();if (worker) {this.executeTask(worker, task, resolve, reject);} else {this.taskQueue.push({ task, resolve, reject });}});}// 获取可用WorkergetAvailableWorker() {return Array.from(this.workers).find(worker => worker.idle);}
}// 3. 网络优化器
class NetworkOptimizer {constructor() {this.bandwidth = new Map();this.latency = new Map();}// 测量网络性能async measureNetwork(endpoint) {const start = performance.now();const response = await fetch(endpoint);const end = performance.now();const size = response.headers.get('content-length');const duration = end - start;this.latency.set(endpoint, duration);if (size) {this.bandwidth.set(endpoint, size / duration);}}// 选择最佳端点selectBestEndpoint(endpoints) {return endpoints.sort((a, b) => {const scoreA = this.calculateScore(a);const scoreB = this.calculateScore(b);return scoreB - scoreA;})[0];}// 计算端点得分calculateScore(endpoint) {const latency = this.latency.get(endpoint) || Infinity;const bandwidth = this.bandwidth.get(endpoint) || 0;return (1 / latency) * bandwidth;}
}

安全性考虑 🔒

// 1. 边缘节点安全管理器
class EdgeSecurityManager {constructor() {this.tokens = new Map();this.permissions = new Map();}// 验证请求async validateRequest(request) {const token = this.extractToken(request);if (!token) {throw new Error('No authentication token');}const isValid = await this.verifyToken(token);if (!isValid) {throw new Error('Invalid token');}return this.checkPermissions(token, request);}// 检查权限async checkPermissions(token, request) {const permissions = this.permissions.get(token);if (!permissions) {throw new Error('No permissions found');}const required = this.getRequiredPermissions(request);return required.every(perm => permissions.includes(perm));}
}// 2. 数据加密管理器
class DataEncryptionManager {constructor() {this.keyPair = null;this.generateKeyPair();}// 生成密钥对async generateKeyPair() {this.keyPair = await window.crypto.subtle.generateKey({name: 'RSA-OAEP',modulusLength: 2048,publicExponent: new Uint8Array([1, 0, 1]),hash: 'SHA-256'},true,['encrypt', 'decrypt']);}// 加密数据async encrypt(data) {const encoded = new TextEncoder().encode(JSON.stringify(data));return window.crypto.subtle.encrypt({name: 'RSA-OAEP'},this.keyPair.publicKey,encoded);}// 解密数据async decrypt(encrypted) {const decrypted = await window.crypto.subtle.decrypt({name: 'RSA-OAEP'},this.keyPair.privateKey,encrypted);return JSON.parse(new TextDecoder().decode(decrypted));}
}

最佳实践建议 💡

  1. 边缘计算设计模式
// 1. 边缘节点模式
class EdgeNode {constructor(config) {this.config = config;this.status = 'INITIALIZING';this.storage = new OfflineStorageManager();this.security = new EdgeSecurityManager();}// 初始化节点async initialize() {await this.storage.initDatabase();await this.security.initialize();this.status = 'READY';}// 处理请求async handleRequest(request) {await this.security.validateRequest(request);if (!navigator.onLine) {return this.handleOfflineRequest(request);}return this.processRequest(request);}
}// 2. 数据同步模式
class DataSyncPattern {constructor() {this.version = 0;this.changes = [];}// 记录变更recordChange(change) {change.version = ++this.version;this.changes.push(change);}// 合并变更mergeChanges(remoteChanges) {const merged = [];let local = 0;let remote = 0;while (local < this.changes.length && remote < remoteChanges.length) {if (this.changes[local].version < remoteChanges[remote].version) {merged.push(this.changes[local++]);} else {merged.push(remoteChanges[remote++]);}}return merged.concat(this.changes.slice(local)).concat(remoteChanges.slice(remote));}
}// 3. 错误处理模式
class EdgeErrorHandler {constructor() {this.handlers = new Map();}// 注册错误处理器register(errorType, handler) {this.handlers.set(errorType, handler);}// 处理错误handle(error) {const handler = this.handlers.get(error.constructor);if (handler) {return handler(error);}// 默认错误处理console.error('Unhandled edge error:', error);throw error;}
}

结语 📝

边缘计算是现代Web应用的重要趋势,它能够提供更好的性能和用户体验。通过本文,我们学习了:

  1. 边缘计算的基础架构设计
  2. 离线处理能力的实现
  3. 数据同步机制的构建
  4. 性能优化策略
  5. 安全性考虑和最佳实践

💡 学习建议:在实施边缘计算时,要特别注意数据一致性和安全性。同时,要根据实际需求选择合适的同步策略,平衡性能和可靠性。


如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇

终身学习,共同成长。

咱们下一期见

💻

相关文章:

JavaScript系列(61)--边缘计算应用开发详解

JavaScript边缘计算应用开发详解 &#x1f310; 今天&#xff0c;让我们深入探讨JavaScript的边缘计算应用开发。边缘计算是一种将计算和数据存储分布到更靠近数据源的位置的架构模式&#xff0c;它能够提供更低的延迟和更好的实时性能。 边缘计算基础架构 &#x1f31f; &am…...

【容器技术01】使用 busybox 构建 Mini Linux FS

使用 busybox 构建 Mini Linux FS 构建目标 在 Linux 文件系统下构建一个 Mini 的文件系统&#xff0c;构建目标如下&#xff1a; minilinux ├── bin │ ├── ls │ ├── top │ ├── ps │ ├── sh │ └── … ├── dev ├── etc │ ├── g…...

Effective Python系列(1.3):使用zip函数同时遍历两个迭代器

zip函数是 Python 中的一个内置函数&#xff0c;用于将多个可迭代对象&#xff08;如列表、元组等&#xff09;的元素配对&#xff0c;生成一个迭代器。 使用 zip 函数的好处之一就是能够节省内存空间&#xff0c;因为该函数会创建惰性生成器&#xff0c;每次遍历时只生成一个元…...

gitlab个别服务无法启动可能原因

目录 一、gitlab的puma服务一直重启 1. 查看日志 2. 检查配置文件 3. 重新配置和重启 GitLab 4. 检查系统资源 5. 检查依赖和服务状态 6. 清理和优化 7. 升级 GitLab 8. 查看社区和文档 二、 gitlab个别服务无法启动可能原因 1.服务器内存或磁盘已满 2.puma端口冲突…...

基于Springboot+vue的租车网站系统

基于SpringbootVue的租车网站系统是一个现代化的在线租车平台&#xff0c;它结合了Springboot的后端开发能力和Vue的前端交互优势&#xff0c;为用户和汽车租赁公司提供了一个高效、便捷、易用的租车体验和管理工具。以下是对该系统的详细介绍&#xff1a; 一、系统架构 后…...

Github - 记录一次对“不小心包含了密码的PR”的修复

Github - 记录一次对“不小心包含了密码的PR”的修复 前言 和好朋友一起开发一个字节跳动青训营抖音电商后端(now private)的项目&#xff0c;某大佬不小心把本地一密码commit上去并提了PR。 PR一旦发出则无法被删除&#xff0c;且其包含的commit也能被所有能看到这个仓库的…...

【后端开发】系统设计101——通信协议,数据库与缓存,架构模式,微服务架构,支付系统(36张图详解)

【后端开发】系统设计101——通信协议&#xff0c;数据库与缓存&#xff0c;架构模式&#xff0c;微服务架构&#xff0c;支付系统&#xff08;36张图&#xff09; 文章目录 1、通信协议通信协议REST API 对比 GraphQL&#xff08;前端-web服务&#xff09;grpc如何工作&#x…...

SpringMVC请求

一、RequestMapping注解 RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系 RequestMapping注解可以作用在方法和类上 1. 作用在类上&#xff1a;第一级的访问目录 2. 作用在方法上&#xff1a;第二级的访问目录 3. 细节&#xff1a;路径可以不编写 / 表示应…...

【学术征稿-组织单位 武汉理工大学西安理工大学、西安财经大学】第三届通信网络与机器学习(CNML 2025)

重要信息 官网&#xff1a;www.iccnml.org 大会时间&#xff1a;2025年2月21日-23日 大会地点&#xff1a;中国 南京 通信网络 通信是人与人之间通过某种媒体进行的信息交流与传递。网络是用物理链路将各个孤立的工作站或主机相连在一起&#xff0c;组成的数据链路。通信网…...

代码随想录算法训练营打卡第55天:并查集相关问题;

Java并查集的模板 //并查集模板 class DisJoint{private int[] father;public DisJoint(int N) {father new int[N];for (int i 0; i < N; i){father[i] i;}}public int find(int n) {return n father[n] ? n : (father[n] find(father[n]));}public void join (int …...

设计模式学习

1.设计模式分类 1.创建型模式 用于描述“怎样创建对象”&#xff0c;主要特点是“将对象的创建与使用分离”。 单例&#xff0c;原型&#xff0c;工厂方法&#xff0c;抽象工厂&#xff0c;建造者 2.结构型模式 用于描述如何将类或对象按某种布局组成更大的结构 代理&…...

js-对象-JSON

JavaScript自定义对象 JSON 概念: JavaScript Object Notation&#xff0c;JavaScript对象标记法. JSON 是通过JavaScript 对象标记法书写的文本。 由于其语法简单&#xff0c;层次结构鲜明&#xff0c;现多用于作为数据载体&#xff0c;在网络中进行数据传输. json中属性名(k…...

C/C++编译器

C/C 代码是不可跨平台的&#xff0c;Windows 和 Unix-like 有着不同的 API&#xff0c;C/C 在不同平台有着不同编译器。 MSVC Windows 平台&#xff0c;MSVC 是 Visual Studio 中自带的 C/C 编译器。 GCC Unix-like 平台&#xff0c;GCC 原名 GNU C Compiler&#xff0c;后…...

【R语言】数据操作

一、查看和编辑数据 1、查看数据 直接打印到控制台 x <- data.frame(a1:20, b21:30) x View()函数 此函数可以将数据以电子表格的形式进行展示。 用reshape2包中的tips进行举例&#xff1a; library("reshape2") View(tips) head()函数 查看前几行数据&…...

Linux 安装 RabbitMQ

Linux下安装RabbitMQ 1 、获取安装包 # 地址 https://github.com/rabbitmq/erlang-rpm/releases/download/v21.3.8.9/erlang-21.3.8.9-1.el7.x86_64.rpm erlang-21.3.8.9-1.el7.x86_64.rpmsocat-1.7.3.2-1.el6.lux.x86_64.rpm# 地址 https://github.com/rabbitmq/rabbitmq-se…...

“AI智能分析综合管理系统:企业管理的智慧中枢

在如今这个快节奏的商业世界里&#xff0c;企业面临的挑战越来越多&#xff0c;数据像潮水一样涌来&#xff0c;管理工作变得愈发复杂。为了应对这些难题&#xff0c;AI智能分析综合管理系统闪亮登场&#xff0c;它就像是企业的智慧中枢&#xff0c;让管理变得轻松又高效。 过去…...

2024最新版Java面试题及答案,【来自于各大厂】

发现网上很多Java面试题都没有答案&#xff0c;所以花了很长时间搜集整理出来了这套Java面试题大全~ 篇幅限制就只能给大家展示小册部分内容了&#xff0c;需要完整版的及Java面试宝典小伙伴点赞转发&#xff0c;关注我后在【翻到最下方&#xff0c;文尾点击名片】即可免费获取…...

调用腾讯云批量文本翻译API翻译srt字幕

上一篇文章介绍了调用百度翻译API翻译日文srt字幕的方法。百度翻译API是get方式调用&#xff0c;参数都放在ur中&#xff0c;每次调用翻译文本长度除了接口限制外&#xff0c;还有url长度限制&#xff0c;而日文字符通过ur转码后会占9个字符长度&#xff0c;其实从这个角度来讲…...

【分块解决大文件上传的最佳实践】

前言 前几天看了一篇关于大文件上传分块实现的博客&#xff0c;代码实现过于复杂且冗长&#xff0c;而且没有进行外网上传的测试。因此&#xff0c;我决定自己动手实现一个大文件上传&#xff0c;并进行优化。 实现思路 在许多应用中&#xff0c;大文件上传是常见的需求&…...

机器学习中的关键概念:通过SKlearn的MNIST实验深入理解

欢迎来到我的主页&#xff1a;【Echo-Nie】 本篇文章收录于专栏【机器学习】 1 sklearn相关介绍 Scikit-learn 是一个广泛使用的开源机器学习库&#xff0c;提供了简单而高效的数据挖掘和数据分析工具。它建立在 NumPy、SciPy 和 matplotlib 等科学计算库之上&#xff0c;支持…...

【Elasticsearch】post_filter

post_filter是 Elasticsearch 中的一种后置过滤机制&#xff0c;用于在查询执行完成后对结果进行过滤。以下是关于post_filter的详细介绍&#xff1a; 工作原理 • 查询后过滤&#xff1a;post_filter在查询执行完毕后对返回的文档集进行过滤。这意味着所有与查询匹配的文档都…...

Git基础

目录 一、Git介绍二、Git下载与配置1、下载安装Git2、Git配置2.1 注册码云账号2.2 Git配置 三、Git开发流程1、相关代码2、上述代码执行截图示例 四、Git提交&撤销五、Git资料 一、Git介绍 Git是一种分布式版本控制系统&#xff0c;广泛用于软件开发项目的版本管理。它由L…...

深度学习系列--02.损失函数

一.定义 损失函数&#xff08;Loss Function&#xff09;是机器学习和深度学习中用于衡量模型预测结果与真实标签之间差异的函数&#xff0c;它在模型训练和评估过程中起着至关重要的作用 二.作用 1.指导模型训练 提供优化方向&#xff1a;在训练模型时&#xff0c;我们的目…...

如何在自己mac电脑上私有化部署deep seek

在 Mac 电脑上私有化部署 DeepSeek 的步骤如下&#xff1a; 1. 环境准备 安装 Homebrew&#xff08;如果尚未安装&#xff09;&#xff1a; Homebrew 是 macOS 上的包管理工具&#xff0c;用于安装依赖。 /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com…...

攻防世界 fileclude

代码审计 WRONG WAY! <?php include("flag.php"); highlight_file(__FILE__);//高亮显示文件的源代码 if(isset($_GET["file1"]) && isset($_GET["file2"]))//检查file1和file2参数是否存在 {$file1 $_GET["file1"];$fi…...

Ubuntu24登录PostgreSql数据库的一般方法

命令格式如 psql -U user -d db 或者 sudo psql -U user -d db 修改配置 /etc/postgresql/16/main/postgresql.conf 改成md5&#xff0c;然后重新启动pgsql sudo systemctl restart postgresql...

3.5 Go(特殊函数)

目录 一、匿名函数 1、匿名函数的特点&#xff1a; 2、匿名函数代码示例 2、匿名函数的类型 二、递归函数 1. 递推公式版本 2. 循环改递归 三、嵌套函数 1、嵌套函数用途 2、代码示例 3、作用域 & 变量生存周期 四、闭包 1、闭包使用场景 2、代码示例 五、De…...

设计模式学习(三)

行为模式 职责链模式&#xff08;Chain of Responsibility Pattern&#xff09; 定义 它允许多个对象有机会处理请求&#xff0c;从而避免请求的发送者与接收者之间的耦合。职责链模式将这些对象连成一条链&#xff0c;并沿着这条链传递请求&#xff0c;直到有对象处理它为止…...

挑战项目 --- 微服务编程测评系统(在线OJ系统)

一、前言 1.为什么要做项目 面试官要问项目&#xff0c;考察你到底是理论派还是实战派&#xff1f; 1.希望从你的项目中看到你的真实能力和对知识的灵活运用。 2.展示你在面对问题和需求时的思考方式及解决问题的能力。 3.面试官会就你项目提出一些问题&#xff0c;或扩展需求…...

堆(Heap)的原理与C++实现

1. 什么是堆&#xff1f; 堆&#xff08;Heap&#xff09;是一种特殊的树形数据结构&#xff0c;通常用于实现优先队列。堆可以分为两种类型&#xff1a; 最大堆&#xff08;Max Heap&#xff09;&#xff1a;每个节点的值都大于或等于其子节点的值。最小堆&#xff08;Min H…...

(10) 如何获取 linux 系统上的 TCP 、 UDP 套接字的收发缓存的默认大小,以及代码范例

&#xff08;1&#xff09; 先介绍下后面的代码里要用到的基础函数&#xff1a; 以及&#xff1a; &#xff08;2&#xff09; 接着给出现代版的 读写 socket 参数的系统函数 &#xff1a; 以及&#xff1a; &#xff08;3&#xff09; 给出 一言的 范例代码&#xff0c;获取…...

linux 进程补充

环境变量 基本概念 环境变量(environment variables)一般是指在操作系统中用来指定操作系统运行环境的一些参数 如&#xff1a;我们在编写C/C代码的时候&#xff0c;在链接的时候&#xff0c;从来不知道我们的所链接的动态静态库在哪 里&#xff0c;但是照样可以链接成功&#…...

通过docker安装部署deepseek以及python实现

前提条件 Docker 安装:确保你的系统已经安装并正确配置了 Docker。可以通过运行 docker --version 来验证 Docker 是否安装成功。 网络环境:保证设备有稳定的网络连接,以便拉取 Docker 镜像和模型文件。 步骤一:拉取 Ollama Docker 镜像 Ollama 可以帮助我们更方便地管理…...

vim-plug的自动安装与基本使用介绍

vim-plug介绍 Vim-plug 是一个轻量级的 Vim 插件管理器&#xff0c;它允许你轻松地管理 Vim 插件的安装、更新和卸载。相较于其他插件管理器&#xff0c;vim-plug 的优点是简单易用&#xff0c;速度较快&#xff0c;而且支持懒加载插件&#xff08;即按需加载&#xff09; 自动…...

Python 自学秘籍:开启编程之旅,人生苦短,我用python。

从2009年&#xff0c;用了几次python后就放弃了&#xff0c;一直用的php&#xff0c;现在人工智能时代&#xff0c;完全没php什么事情。必须搞python了&#xff0c;虽然已经40多岁了。死磕python了。让滔滔陪着你一起学python 吧。 开启新世界 在当今人工智能化的时代&#xff…...

DRGDIP 2.0时代下基于PostgreSQL的成本管理实践与探索(上)

一、引言 1.1 研究背景与意义 在医疗领域的改革进程中&#xff0c; DRG/DIP 2.0 时代&#xff0c;医院成本管理的重要性愈发凸显。新的医保支付方式下&#xff0c;医院的收入不再单纯取决于医疗服务项目的数量&#xff0c;而是与病种的分组、费用标准以及成本控制紧密相关。这…...

swift 专题三 swift 规范一

一、Swift编码命名规范 对类、结构体、枚举和协议等类型的命名应该采用大驼峰法&#xff0c;如 SplitViewController。 文件名采用大驼峰法&#xff0c;如BlockOperation.swift。 对于扩展文件&#xff0c;有时扩展定义在一个独立的文件中&#xff0c;用“原始类型名 扩展名…...

Vue的状态管理:用响应式 API 做简单状态管理、状态管理库(Pinia )

文章目录 引言单向数据流多个组件共享一个共同的状态I 用响应式 API 做简单状态管理使用 reactive()创建一个在多个组件实例间共享的响应式对象使用ref()返回一个全局状态II 状态管理库Pinia枚举状态管理引言 单向数据流 每一个 Vue 组件实例都在“管理”它自己的响应式状态了…...

排序算法--希尔排序

希尔排序是插入排序的改进版本&#xff0c;适合中等规模数据排序&#xff0c;性能优于简单插入排序。 // 希尔排序函数 void shellSort(int arr[], int n) {// 初始间隔&#xff08;gap&#xff09;为数组长度的一半&#xff0c;逐步缩小for (int gap n / 2; gap > 0; gap …...

HAL库 Systick定时器 基于STM32F103EZT6 野火霸道,可做参考

目录 1.时钟选择(这里选择高速外部时钟) ​编辑 2.调试模式和时基源选择: 3.LED的GPIO配置 这里用板子的红灯PB5 4.工程配置 5.1ms的systick中断实现led闪烁 源码: 6.修改systick的中断频率 7.systick定时原理 SysTick 定时器的工作原理 中断触发机制 HAL_SYSTICK_Co…...

ESXI虚拟机中部署docker会降低服务器性能

在 8 核 16GB 的 ESXi 虚拟机中部署 Docker 的性能影响分析 在 ESXi 虚拟机中运行 Docker 容器时&#xff0c;性能影响主要来自以下几个方面&#xff1a; 虚拟化开销&#xff1a;ESXi 虚拟化层和 Docker 容器化层的叠加。资源竞争&#xff1a;虚拟机与容器之间对 CPU、内存、…...

前端 | JavaScript中的reduce方法

1. 什么是reduce reduce 方法是 JavaScript 中数组的重要方法之一&#xff0c;用于对数组中的元素进行累积计算。它接收一个回调函数作为参数&#xff0c;并返回一个最终计算结果。reduce 在许多场景下都非常有用&#xff0c;比如求和、数组扁平化、对象计数、数据转换等。 2…...

基于联合概率密度与深度优化的反潜航空深弹命中概率模型研究摘要

前言:项目题材来自数学建模2024年的D题,文章内容为笔者和队友原创,提供一个思路。 摘要 随着现代军事技术的发展,深水炸弹在特定场景下的反潜作战效能日益凸显,如何最大化的发挥深弹威力也成为重要研究课题。本文针对评估深弹投掷落点对命中潜艇概率的影响进行分析,综合利…...

将OneDrive上的文件定期备份到移动硬盘

背景&#xff1a; 我在oneDrive上存了很多文件&#xff0c;分布在多个文件夹中&#xff0c;也有套了好几层文件夹的情况。我希望每隔一段时间&#xff0c;将oneDrive上的所有文件向移动硬盘上拷贝一份&#xff0c;但是我只想将距离上一次向移动硬盘拷贝的文件相比&#xff0c;发…...

01vue3实战-----前言

01vue3实战-----前言 1.大前端时代2.技术栈3.项目大致展示4.创建Vue项目4.1Vue CLI4.2create-vue 5.参考资料 1.大前端时代 前端移动端iOS/android开发桌面端 window/mac 常用的electron框架来开发其它平台:穿戴设备、车载系统(智能汽车)、VR、AR…web3方向 2.技术栈 开发工…...

SQL 秒变三线表 sql导出三线表

&#x1f3af;SQL 秒变三线表&#xff0c;校园小助手超神啦 宝子们&#xff0c;搞数据分析、写论文的时候&#xff0c;从 SQL 里导出数据做成三线表是不是特别让人头疼&#x1f629; 手动调整格式&#xff0c;不仅繁琐&#xff0c;还容易出错&#xff0c;分分钟把人逼疯&#…...

C_位运算符及其在单片机寄存器的操作

C语言的位运算符用于直接操作二进制位&#xff0c;本篇简单结束各个位运算符的作业及其在操作寄存器的应用场景。 一、位运算符的简单说明 1、按位与运算符&#xff08;&&#xff09; 功能&#xff1a;按位与运算符对两个操作数的每一位执行与操作。如果两个对应的二进制…...

Rust错误处理:从灭火器到核按钮的生存指南

开篇&#xff1a;错误处理的生存哲学 在Rust的平行宇宙里&#xff0c;错误分为两种人格&#xff1a; panic! → 核按钮&#x1f4a3;&#xff08;不可恢复&#xff0c;全系统警报&#xff09;Result → 灭火器&#x1f9ef;&#xff08;可控制&#xff0c;局部处理&#xff0…...

YK人工智能(六)——万字长文学会基于Torch模型网络可视化

1. 可视化网络结构 随着深度神经网络做的的发展&#xff0c;网络的结构越来越复杂&#xff0c;我们也很难确定每一层的输入结构&#xff0c;输出结构以及参数等信息&#xff0c;这样导致我们很难在短时间内完成debug。因此掌握一个可以用来可视化网络结构的工具是十分有必要的…...

对象的实例化、内存布局与访问定位

一、创建对象的方式 二、创建对象的步骤: 一、判断对象对应的类是否加载、链接、初始化: 虚拟机遇到一条new指令&#xff0c;首先去检查这个指令的参数能否在Metaspace的常量池中定位到一个类的符号引用&#xff0c;并且检查这个符号引用代表的类是否已经被加载、解析和初始化…...