工程化与框架系列(36)--前端监控告警实践
前端监控告警实践 🔔
引言
前端监控是保障应用质量和用户体验的重要手段。本文将深入探讨前端监控的实现方案,包括性能监控、错误监控、用户行为监控等方面,以及相应的告警机制。
监控系统概述
前端监控系统主要包括以下方面:
- 性能监控:页面加载、资源加载、接口性能等
- 错误监控:JS错误、接口错误、资源加载错误等
- 用户行为:PV/UV、点击行为、路由变化等
- 业务监控:转化率、留存率、业务指标等
- 告警系统:规则配置、通知分发、告警处理等
监控系统实现
监控管理器
// 监控管理器类
class MonitoringManager {private static instance: MonitoringManager;private config: MonitorConfig;private collectors: Map<string, Collector>;private processors: Map<string, Processor>;private reporters: Map<string, Reporter>;private alerter: Alerter;private constructor() {this.collectors = new Map();this.processors = new Map();this.reporters = new Map();this.config = {appId: '',userId: '',sessionId: '',environment: 'production',version: '1.0.0',sampling: 100};}// 获取单例实例static getInstance(): MonitoringManager {if (!MonitoringManager.instance) {MonitoringManager.instance = new MonitoringManager();}return MonitoringManager.instance;}// 初始化监控系统init(config: MonitorConfig): void {this.config = { ...this.config, ...config };// 初始化收集器this.initCollectors();// 初始化处理器this.initProcessors();// 初始化上报器this.initReporters();// 初始化告警器this.initAlerter();// 启动监控this.start();}// 初始化收集器private initCollectors(): void {// 性能收集器this.collectors.set('performance',new PerformanceCollector());// 错误收集器this.collectors.set('error',new ErrorCollector());// 行为收集器this.collectors.set('behavior',new BehaviorCollector());// 业务收集器this.collectors.set('business',new BusinessCollector());}// 初始化处理器private initProcessors(): void {// 性能处理器this.processors.set('performance',new PerformanceProcessor());// 错误处理器this.processors.set('error',new ErrorProcessor());// 行为处理器this.processors.set('behavior',new BehaviorProcessor());// 业务处理器this.processors.set('business',new BusinessProcessor());}// 初始化上报器private initReporters(): void {// HTTP上报器this.reporters.set('http',new HttpReporter(this.config.reportUrl));// 信标上报器this.reporters.set('beacon',new BeaconReporter());// 日志上报器this.reporters.set('log',new LogReporter());}// 初始化告警器private initAlerter(): void {this.alerter = new Alerter({rules: this.config.alertRules,channels: this.config.alertChannels});}// 启动监控private start(): void {// 启动收集器this.collectors.forEach(collector => {collector.start();});// 启动处理器this.processors.forEach(processor => {processor.start();});// 启动上报器this.reporters.forEach(reporter => {reporter.start();});// 启动告警器this.alerter.start();}// 停止监控stop(): void {// 停止收集器this.collectors.forEach(collector => {collector.stop();});// 停止处理器this.processors.forEach(processor => {processor.stop();});// 停止上报器this.reporters.forEach(reporter => {reporter.stop();});// 停止告警器this.alerter.stop();}// 手动上报report(data: MonitorData): void {// 采样判断if (!this.shouldSample()) {return;}// 数据处理const processor = this.processors.get(data.type);if (processor) {data = processor.process(data);}// 数据上报const reporter = this.reporters.get(this.config.reportType);if (reporter) {reporter.report(data);}// 告警检查this.alerter.check(data);}// 采样判断private shouldSample(): boolean {return Math.random() * 100 < this.config.sampling;}
}// 收集器基类
abstract class Collector {protected config: CollectorConfig;protected callback: (data: MonitorData) => void;constructor(config: CollectorConfig) {this.config = config;}setCallback(callback: (data: MonitorData) => void): void {this.callback = callback;}abstract start(): void;abstract stop(): void;
}// 性能收集器
class PerformanceCollector extends Collector {private observer: PerformanceObserver | null = null;start(): void {// 收集性能指标this.collectMetrics();// 观察性能事件this.observePerformance();}stop(): void {this.observer?.disconnect();this.observer = null;}private collectMetrics(): void {// 收集导航计时const navigation = performance.getEntriesByType('navigation')[0];this.callback?.({type: 'performance',subType: 'navigation',data: navigation});// 收集资源计时const resources = performance.getEntriesByType('resource');resources.forEach(resource => {this.callback?.({type: 'performance',subType: 'resource',data: resource});});// 收集First Paintconst paint = performance.getEntriesByType('paint');paint.forEach(entry => {this.callback?.({type: 'performance',subType: 'paint',data: entry});});}private observePerformance(): void {this.observer = new PerformanceObserver(list => {list.getEntries().forEach(entry => {this.callback?.({type: 'performance',subType: entry.entryType,data: entry});});});// 观察的性能指标类型this.observer.observe({entryTypes: ['navigation','resource','paint','largest-contentful-paint','first-input','layout-shift']});}
}// 错误收集器
class ErrorCollector extends Collector {private errorHandler: (event: ErrorEvent) => void;private unhandledRejectionHandler: (event: PromiseRejectionEvent) => void;start(): void {// 监听JS错误this.errorHandler = (event: ErrorEvent) => {this.callback?.({type: 'error',subType: 'javascript',data: {message: event.message,filename: event.filename,lineno: event.lineno,colno: event.colno,error: event.error}});};window.addEventListener('error', this.errorHandler);// 监听Promise错误this.unhandledRejectionHandler = (event: PromiseRejectionEvent) => {this.callback?.({type: 'error',subType: 'promise',data: {reason: event.reason}});};window.addEventListener('unhandledrejection',this.unhandledRejectionHandler);}stop(): void {window.removeEventListener('error', this.errorHandler);window.removeEventListener('unhandledrejection',this.unhandledRejectionHandler);}
}// 行为收集器
class BehaviorCollector extends Collector {private clickHandler: (event: MouseEvent) => void;private routeHandler: () => void;start(): void {// 监听点击事件this.clickHandler = (event: MouseEvent) => {const target = event.target as HTMLElement;this.callback?.({type: 'behavior',subType: 'click',data: {path: this.getElementPath(target),timestamp: Date.now()}});};document.addEventListener('click', this.clickHandler);// 监听路由变化this.routeHandler = () => {this.callback?.({type: 'behavior',subType: 'route',data: {path: location.pathname,timestamp: Date.now()}});};window.addEventListener('popstate', this.routeHandler);}stop(): void {document.removeEventListener('click', this.clickHandler);window.removeEventListener('popstate', this.routeHandler);}private getElementPath(element: HTMLElement): string {const path: string[] = [];let current: HTMLElement | null = element;while (current && current !== document.body) {let selector = current.tagName.toLowerCase();if (current.id) {selector += `#${current.id}`;} else if (current.className) {selector += `.${current.className.split(' ').join('.')}`;}path.unshift(selector);current = current.parentElement;}return path.join(' > ');}
}// 业务收集器
class BusinessCollector extends Collector {private metrics: Map<string, number> = new Map();start(): void {// 定时上报业务指标setInterval(() => {this.reportMetrics();}, this.config.reportInterval);}stop(): void {this.metrics.clear();}// 记录业务指标record(name: string, value: number): void {this.metrics.set(name, value);}private reportMetrics(): void {this.metrics.forEach((value, name) => {this.callback?.({type: 'business',subType: 'metric',data: {name,value,timestamp: Date.now()}});});}
}// 处理器基类
abstract class Processor {protected config: ProcessorConfig;constructor(config: ProcessorConfig) {this.config = config;}abstract start(): void;abstract stop(): void;abstract process(data: MonitorData): MonitorData;
}// 性能处理器
class PerformanceProcessor extends Processor {start(): void {}stop(): void {}process(data: MonitorData): MonitorData {if (data.type !== 'performance') {return data;}// 处理性能数据switch (data.subType) {case 'navigation':return this.processNavigation(data);case 'resource':return this.processResource(data);case 'paint':return this.processPaint(data);default:return data;}}private processNavigation(data: MonitorData): MonitorData {const entry = data.data as PerformanceNavigationTiming;return {...data,data: {dns: entry.domainLookupEnd - entry.domainLookupStart,tcp: entry.connectEnd - entry.connectStart,ttfb: entry.responseStart - entry.requestStart,download: entry.responseEnd - entry.responseStart,domReady: entry.domContentLoadedEventEnd - entry.navigationStart,load: entry.loadEventEnd - entry.navigationStart}};}private processResource(data: MonitorData): MonitorData {const entry = data.data as PerformanceResourceTiming;return {...data,data: {name: entry.name,type: entry.initiatorType,duration: entry.duration,size: entry.transferSize}};}private processPaint(data: MonitorData): MonitorData {const entry = data.data as PerformancePaintTiming;return {...data,data: {name: entry.name,time: entry.startTime}};}
}// 错误处理器
class ErrorProcessor extends Processor {start(): void {}stop(): void {}process(data: MonitorData): MonitorData {if (data.type !== 'error') {return data;}// 处理错误数据return {...data,data: {...data.data,timestamp: Date.now(),url: location.href,userAgent: navigator.userAgent}};}
}// 行为处理器
class BehaviorProcessor extends Processor {start(): void {}stop(): void {}process(data: MonitorData): MonitorData {if (data.type !== 'behavior') {return data;}// 处理行为数据return {...data,data: {...data.data,url: location.href,title: document.title}};}
}// 业务处理器
class BusinessProcessor extends Processor {start(): void {}stop(): void {}process(data: MonitorData): MonitorData {if (data.type !== 'business') {return data;}// 处理业务数据return {...data,data: {...data.data,env: this.config.environment}};}
}// 上报器基类
abstract class Reporter {protected config: ReporterConfig;protected queue: MonitorData[] = [];protected timer: number | null = null;constructor(config: ReporterConfig) {this.config = config;}start(): void {// 定时上报this.timer = window.setInterval(() => {this.flush();}, this.config.flushInterval);}stop(): void {if (this.timer) {clearInterval(this.timer);this.timer = null;}}report(data: MonitorData): void {this.queue.push(data);// 队列满时立即上报if (this.queue.length >= this.config.maxBatchSize) {this.flush();}}protected abstract flush(): void;
}// HTTP上报器
class HttpReporter extends Reporter {protected async flush(): void {if (this.queue.length === 0) {return;}try {const data = this.queue.slice();this.queue = [];await fetch(this.config.url, {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify(data)});} catch (error) {console.error('Failed to report data:', error);// 失败重试this.queue.push(...data);}}
}// 信标上报器
class BeaconReporter extends Reporter {protected flush(): void {if (this.queue.length === 0) {return;}const data = this.queue.slice();this.queue = [];const blob = new Blob([JSON.stringify(data)],{ type: 'application/json' });navigator.sendBeacon(this.config.url, blob);}
}// 日志上报器
class LogReporter extends Reporter {protected flush(): void {if (this.queue.length === 0) {return;}const data = this.queue.slice();this.queue = [];console.log('Monitor Data:', data);}
}// 告警器
class Alerter {private config: AlertConfig;private rules: Map<string, AlertRule> = new Map();private state: Map<string, AlertState> = new Map();constructor(config: AlertConfig) {this.config = config;}start(): void {// 初始化告警规则this.config.rules.forEach(rule => {this.rules.set(rule.id, rule);});}stop(): void {this.rules.clear();this.state.clear();}// 检查告警check(data: MonitorData): void {this.rules.forEach(rule => {if (this.matchRule(rule, data)) {this.processAlert(rule, data);}});}// 匹配规则private matchRule(rule: AlertRule, data: MonitorData): boolean {// 类型匹配if (rule.type !== data.type) {return false;}// 子类型匹配if (rule.subType && rule.subType !== data.subType) {return false;}// 条件匹配return this.evaluateCondition(rule.condition, data.data);}// 评估条件private evaluateCondition(condition: AlertCondition,data: any): boolean {const value = data[condition.field];switch (condition.operator) {case '>':return value > condition.value;case '<':return value < condition.value;case '>=':return value >= condition.value;case '<=':return value <= condition.value;case '==':return value == condition.value;case '!=':return value != condition.value;default:return false;}}// 处理告警private processAlert(rule: AlertRule, data: MonitorData): void {const state = this.state.get(rule.id) || {count: 0,firstTime: Date.now(),lastTime: Date.now()};// 更新状态state.count++;state.lastTime = Date.now();this.state.set(rule.id, state);// 检查告警条件if (this.shouldAlert(rule, state)) {this.sendAlert(rule, state, data);}}// 判断是否需要告警private shouldAlert(rule: AlertRule, state: AlertState): boolean {// 检查告警间隔const interval = state.lastTime - state.firstTime;if (interval < rule.timeWindow) {return false;}// 检查告警次数return state.count >= rule.threshold;}// 发送告警private async sendAlert(rule: AlertRule,state: AlertState,data: MonitorData): Promise<void> {const alert: Alert = {id: rule.id,name: rule.name,level: rule.level,message: this.formatMessage(rule, state, data),time: Date.now()};// 发送到不同渠道await Promise.all(this.config.channels.map(channel => {return this.sendToChannel(channel, alert);}));// 重置状态this.state.delete(rule.id);}// 格式化告警消息private formatMessage(rule: AlertRule,state: AlertState,data: MonitorData): string {return `告警:${rule.name}级别:${rule.level}时间:${new Date().toLocaleString()}次数:${state.count}详情:${JSON.stringify(data)}`;}// 发送到告警渠道private async sendToChannel(channel: AlertChannel,alert: Alert): Promise<void> {try {await fetch(channel.url, {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify({channel: channel.type,alert})});} catch (error) {console.error(`Failed to send alert to ${channel.type}:`,error);}}
}// 接口定义
interface MonitorConfig {appId: string;userId: string;sessionId: string;environment: string;version: string;sampling: number;reportUrl?: string;reportType?: string;alertRules?: AlertRule[];alertChannels?: AlertChannel[];
}interface CollectorConfig {reportInterval?: number;
}interface ProcessorConfig {environment: string;
}interface ReporterConfig {url: string;flushInterval: number;maxBatchSize: number;
}interface AlertConfig {rules: AlertRule[];channels: AlertChannel[];
}interface MonitorData {type: string;subType: string;data: any;
}interface AlertRule {id: string;name: string;type: string;subType?: string;level: 'info' | 'warning' | 'error' | 'critical';condition: AlertCondition;timeWindow: number;threshold: number;
}interface AlertCondition {field: string;operator: '>' | '<' | '>=' | '<=' | '==' | '!=';value: any;
}interface AlertState {count: number;firstTime: number;lastTime: number;
}interface Alert {id: string;name: string;level: string;message: string;time: number;
}interface AlertChannel {type: string;url: string;
}// 使用示例
const monitor = MonitoringManager.getInstance();// 初始化监控
monitor.init({appId: 'my-app',userId: 'user-123',sessionId: 'session-456',environment: 'production',version: '1.0.0',sampling: 100,reportUrl: 'https://monitor.example.com/report',reportType: 'http',alertRules: [{id: 'error-rate',name: '错误率告警',type: 'error',level: 'error',condition: {field: 'count',operator: '>',value: 10},timeWindow: 60000,threshold: 5}],alertChannels: [{type: 'webhook',url: 'https://alert.example.com/webhook'}]
});// 手动上报
monitor.report({type: 'business',subType: 'conversion',data: {name: 'purchase',value: 100}
});// 停止监控
monitor.stop();
最佳实践与建议
-
监控范围
- 性能指标
- 错误信息
- 用户行为
- 业务数据
-
采集策略
- 采样控制
- 批量上报
- 优先级分级
- 实时性要求
-
告警机制
- 规则配置
- 级别定义
- 通知方式
- 处理流程
-
数据处理
- 数据清洗
- 聚合分析
- 存储策略
- 查询优化
总结
前端监控系统需要考虑以下方面:
- 监控指标的全面性
- 数据采集的可靠性
- 处理分析的及时性
- 告警通知的准确性
- 系统运维的可维护性
通过完善的监控体系,可以及时发现和解决问题,提高应用质量。
学习资源
- 性能监控指标
- 错误监控方案
- 用户行为分析
- 告警系统设计
- 监控平台实践
如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇
终身学习,共同成长。
咱们下一期见
💻
相关文章:
工程化与框架系列(36)--前端监控告警实践
前端监控告警实践 🔔 引言 前端监控是保障应用质量和用户体验的重要手段。本文将深入探讨前端监控的实现方案,包括性能监控、错误监控、用户行为监控等方面,以及相应的告警机制。 监控系统概述 前端监控系统主要包括以下方面:…...
【深度学习|目标检测】YOLO系列anchor-based原理详解
YOLO之anchor-based 一、关于anchors的设置二、网络如何利用anchor来训练关于register_buffer训练阶段的anchor使用推理阶段的anchor使用 三、训练时的正负样本匹配anchor匹配grid匹配 总结起来其实就是:基于anchor-based的yolo就是基于三个检测头的分支上的grids和…...
vue3+Ts+elementPlus二次封装Table分页表格,表格内展示图片、switch开关、支持
目录 一.项目文件结构 二.实现代码 1.子组件(表格组件) 2.父组件(使用表格) 一.项目文件结构 1.表格组件(子组件)位置 2.使用表格组件的页面文件(父组件)位置 3.演示图片位置 ele…...
【C/C++】文件句柄
什么是文件句柄? 文件句柄(File Handle)是操作系统中的一种抽象概念,它用来表示一个打开的文件或输入/输出设备。 文件句柄是程序与文件之间的桥梁,程序通过文件句柄来访问和操作文件的内容。 1. 文件句柄——作用 文…...
Matlab 基于专家pid控制的时滞系统
1、内容简介 Matlab 185-基于专家pid控制的时滞系统 可以交流、咨询、答疑 2、内容说明 略 在处理时滞系统(Time Delay Systems)时,使用传统的PID控制可能会面临挑战,因为时滞会导致系统的不稳定或性能下降。专家PID控制通过结…...
【高项】信息系统项目管理师(六)项目进度管理【3分】
项目进度管理是为了保证项目按时完成。对项目所需的各个过程进行管理,包括规划进度、定义活动、排列活动顺序、估算活动持续时间、制订项目进度计划和控制进度。小型项目中,定义活动、排列活动顺序、估算活动持续时间以及制订进度模型形成进度计划等过程的联系非常紧密,可以…...
通过MATLAB和Carsim进行联合仿真,利用强化学习实现自动驾驶人机控制权策略的详细步骤和示例代码
以下是一个通过MATLAB和Carsim进行联合仿真,利用强化学习实现自动驾驶人机控制权策略的详细步骤和示例代码: 步骤概述 Carsim配置:对Carsim进行必要的设置,包括车辆模型、道路场景等,并生成S - function接口。MATLAB环境搭建:在MATLAB中配置Carsim的S - function,并创建…...
iOS 模块化架构设计:主流方案与实现详解
随着 iOS 工程规模的扩大,模块化设计成为提升代码可维护性、团队协作效率和开发灵活性的关键。本文将探讨为什么需要模块化,介绍四种主流的模块化架构方案(协议抽象、依赖注入、路由机制和事件总线),并通过代码示例和对…...
PostreSQL指南-内幕探索-学习笔记-01-数据库集簇的逻辑与物理结构
目录 一、环境信息 二、参考内容 三、逻辑结构概念 四、物理结构概念 五、逻辑映射关系 1、数据库与oid映射关系 2、堆表对象与oid映射关系 五、物理映射关系 1、数据库与oid映射关系 2、堆表对象与oid映射关系 六、数据库文件布局 1、表格 2、postmaster.pid文件解…...
java使用(Preference、Properties、XML、JSON)实现处理(读写)配置信息或者用户首选项的方式的代码示例和表格对比
在Java应用程序中,处理应用首选项(preferences)有多种方法,包括使用java.util.prefs.Preferences类、属性文件(如.properties文件)、XML文件和JSON文件。下面是每种方法的详细说明和代码示例,最…...
spring动态代理是在生命周期的哪个阶段实现的
Spring AOP(面向切面编程)的动态代理是在 Bean 生命周期的 初始化后阶段 实现的,具体来说是在 BeanPostProcessor 的 postProcessAfterInitialization() 方法中完成的。下面我们来详细分析 Spring AOP 动态代理的实现位置及其工作原理。 1. S…...
Oracle静默安装方法
Web服务器上面的Linux一般是不会有图形界面的,所有通过图形界面来安装Linux的方式在没有图形界面的Linux上面是行不通的,我们要使用的安装方式叫做Linux的静默安装。即在没有图形界面的Linux上面安装。 1. 下载地址 http://www.oracle.com/technetwork…...
本地部署deepseek-r1建立向量知识库和知识库检索实践【代码】
目录 一、本地部署DS 二、建立本地知识库 1.安装python和必要的库 2.设置主目录工作区 3.编写文档解析脚本 4.构建向量数据库 三、基于DS,使用本地知识库检索 本地部署DS,其实非常简单,我写了一篇操作记录,我终于本地部署了DeepSeek-R1(图文全过程)-CSDN博客 安装…...
单词翻转(信息学奥赛一本通-1144)
【题目描述】 输入一个句子(一行),将句子中的每一个单词翻转后输出。 【输入】 只有一行,为一个字符串,不超过500个字符。单词之间以空格隔开。 【输出】 翻转每一个单词后的字符串,单词之间的空格需与原文一致。 【输入样例】 he…...
Python基础入门掌握(十三)
从基础到进阶,轻松掌握文件读写 目录 文件操作的基本概念 文件的打开与关闭 读取文件内容 写入文件内容 文件操作的高级技巧 总结与建议 文件操作的基本概念 在Python中,文件操作主要涉及以下几个步骤: 打开文件(open…...
【再读】R1-Onevision通过跨模态形式化为复杂多模态推理任务提供了系统性解决方案
R1-Onevision:跨模态形式化驱动的多模态推理技术突破,R1-Onevision通过跨模态形式化、双阶段训练和教育级基准测试,为多模态推理树立了新标杆。其技术创新不仅提升了模型在复杂任务中的表现,更重要的是为行业提供了一种可解释、可迁移的多模态处理范式。随着形式化方法的不断…...
【AWS入门】2025 AWS亚马逊云科技账户注册指南
【AWS入门】2025 AWS亚马逊云科技账户注册指南 A Guide To Register a New account on AWS By JacksonML 0. AWS亚马逊云科技简介 Amazon Web Service(AWS) 即亚马逊云科技,其在全球Cloud Computing(云计算)市场占有最为重要的地位。 AWS连续13年被Gartner评为…...
重生之我在学Vue--第18天 Vue 3 项目功能扩展
重生之我在学Vue–第18天 Vue 3 项目功能扩展 文章目录 重生之我在学Vue--第18天 Vue 3 项目功能扩展前言一、权限管理系统1.1 用户角色体系设计1.2 路由权限控制1.3 组件级权限控制 二、分页与搜索系统2.1 分页类型对比2.2 分页组件实现2.3 搜索功能实现 三、文件上传系统3.1 …...
基于SpringBoot的房地产销售管理系统【附源码】
基于SpringBoot的房地产销售管理系统(源码L文说明文档) 目录 4 系统设计 4.1用户登录功能的详细实现 4.2管理员权限的功能实现 4.2.1客户信息管理功能的详细实现 4.2.2房产管理功能的详细实现 4.2.3预约看房功能的详细实现 4.2.4论…...
数组题型-二分查找-JS
二分查找伪代码 1.定义 target 是在⼀个在左闭右闭的区间⾥,也就是[left, right] let left0;let rightnums.length-1;// 定义target在左闭右闭的区间⾥,[left, right]while(left<right){// 当leftright,区间[left, right]依然有效&#x…...
STL——vector
目录 1 vector介绍 2 vector使用 2.1 vector的定义 2.1.1 无参构造 2.1.2 构造并初始化N个Val 2.1.3 拷贝构造 2.1.4 使用迭代器初始化构造 2.1.5 使用大括号初始化构造 2.2 vector的迭代器 2.2.1 const 迭代器 2.3 vector的空间增长 2.4 vector的增删改查 2.5 ve…...
国内首款载重1吨级无人运输机TP1000首飞成功 2026年投入应急救援
大湾区经济网珠海快讯,据央视新闻报道,3月15日上午,国内首款载重1吨级大型无人运输机TP1000在山东成功首飞。该机由中国民航适航标准完全自主研发,起飞重量3.3吨,满载航程达1000公里,具备智能空投功能&…...
python-leetcode 54.全排列
题目: 给定不含重复数字的数组nums,返回其所有可能的全排列,可以按任意顺序返回答案 回溯法 一种通过探索所有可能的候选解来找出所有的解的算法。如果候选解被确认不是一个解(或者至少不是最后一个解),回溯算法会通…...
人工智能实现电脑任务自动化的开源软件
人工智能实现电脑任务自动化的开源软件 hallo大家好,我是星哥,今天给大家介绍一个开源软件,融合了人工智能与机器人流程自动化(AIRPA)的开源软件autoMate! autoMate是什么 autoMate 是一款由开源开发的本地自动化工…...
串口烧录出现频繁回复乱码 频繁回复一个数字且烧录失败 字节混乱
这是因为你的芯片没有处于系统存储区启动一直未进入bootloader 解决办法是检查boot引脚接正确没,要在系统存储器启动...
ens33没有分配到IPV4问题
方法一:手动为 ens33 接口分配 IP 地址 你能够借助 ip 命令手动给 ens33 接口分配 IP 地址。不过这种方式在系统重启之后就会失效。 步骤 查看网络信息 先查看一下当前网络的子网信息,例如网关地址和子网掩码等,你可以通过路由器管理界面或…...
搭建主从服务器
任务需求 客户端通过访问 www.nihao.com 后,能够通过 dns 域名解析,访问到 nginx 服务中由 nfs 共享的首页文件,内容为:Very good, you have successfully set up the system. 各个主机能够实现时间同步,并且都开启防…...
【实测闭坑】LazyGraphRAG利用本地ollama提供Embedding model服务和火山引擎的deepseek API构建本地知识库
LazyGraphRAG 2024年4月,为解决传统RAG在全局性的查询总结任务上表现不佳,微软多部门联合提出Project GraphRAG(大模型驱动的KG);2024年7月,微软正式开源GraphRAG项目,引起极大关注,…...
[Lc14_priority_queue] 最后一块石头重量 | 数据流中的第 K 大元素 | 前K个高频单词 | 数据流的中位数
目录 1.最后一块石头的重量 题解 2.数据流中的第 K 大元素 题解 3.前K个高频单词 题解 代码 ⭕4.数据流的中位数 题解 在C中,使用标准库中的priority_queue,默认情况下它是一个最大堆(即大堆排序),这意味着最…...
Electron使用WebAssembly实现CRC-16 MAXIM校验
Electron使用WebAssembly实现CRC-16 MAXIM校验 将C/C语言代码,经由WebAssembly编译为库函数,可以在JS语言环境进行调用。这里介绍在Electron工具环境使用WebAssembly调用CRC-16 MAXIM格式校验的方式。 CRC-16 MAXIM校验函数WebAssembly源文件 C语言实…...
案例5_1:单位数码管显示0
文章目录 文章介绍效果图仿真图5_1放置单位数码管 代码5_1.c 文章介绍 效果图 仿真图5_1 复制案例1_2的仿真图,在此基础上修改 注意:栅格大小需要缩小 放置单位数码管 代码5_1.c #include <reg52.h>#define uchar unsigned char #define uint un…...
OpenCV计算摄影学(20)非真实感渲染之增强图像的细节函数detailEnhance()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 此滤波器增强特定图像的细节。 cv::detailEnhance用于增强图像的细节,通过结合空间域和频率域的处理,提升图像中特定细节…...
linux按照nginx
第一步先按照依赖gcc 一键安装上面四个依赖 Nginx的编译安装需要一些依赖库,如gcc、make、zlib、openssl等。可以使用yum命令安装这些依赖: yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel 创建目录 mkdir /usr/nginx 切换…...
SpringMVC(八)Knife4j 接口文档
目录 一 基础使用 1 配置pom.xml相关依赖 2 项目配置 3 输入指定路径(http://localhost:8080/doc.html) 二 一些使用方法 1 Tag 2 Operation 3 Schema 4 Parameter 5 可以根据需求来设置 补充:日期的格式化 Knife4j 是基于 Swag…...
Java集成MQTT和Kafka实现稳定、可靠、高性能的物联网消息处理系统
Java集成MQTT和Kafka实现高可用方案 1. 概述 在物联网(IoT)和分布式系统中,消息传递的可靠性和高可用性至关重要。本文将详细介绍如何使用Java集成MQTT和Kafka来构建一个高可用的消息处理系统。 MQTT(消息队列遥测传输)是一种轻量级的发布/订阅协议,适用于资源受限的设备和…...
【操作系统安全】任务6:Linux 系统文件与文件系统安全 学习指南
目录 一、文件系统基础概念 二、查看文件系统信息 2.1 磁盘空间查看 2.2 分区与挂载管理 2.3 文件系统类型操作 三、文件系统权限配置 3.1 基础权限管理 3.2 所有权管理 3.3 特殊权限设置 四、文件操作基础 4.1 文件创建 4.2 文件删除 4.3 文件复制与移动 4.4 文件…...
华为中小型企业项目案例
实验目的(1) 熟悉华为交换机和路由器的应用场景 (2) 掌握华为交换机和路由器的配置方法 实验拓扑实验拓扑如图所示。 华为中小型企业项目案例拓扑图 实验配置市场部和技术部的配置创建VLANLSW1的配置 [LSW1]vlan batch 10 20 [LSW1]q…...
Zabbix安装(保姆级教程)
Zabbix 是一款开源的企业级监控解决方案,能够监控网络的多个参数以及服务器、虚拟机、应用程序、服务、数据库、网站和云的健康状况和完整性。它提供了灵活的通知机制,允许用户为几乎任何事件配置基于电子邮件的告警,从而能够快速响应服务器问题。Zabbix 基于存储的数据提供…...
JDBC数据库连接池技术详解——从传统连接方式到高效连接管理
1. 引言 在开发数据库应用时,我们通常需要与数据库建立连接并执行SQL语句。传统的JDBC连接方式虽然简单直接,但在高并发场景下容易带来性能问题,甚至导致系统崩溃。因此,引入数据库连接池(Connection Pool)…...
微服务存在的问题及解决方案
微服务存在的问题及解决方案 1. 存在问题 1.1 接口拖慢 因为一个接口在并发时,正好执行时长又比较长,那么当前这个接口占用过多的 Tomcat 连接,导致其他接口无法即时获取到 Tomcat 连接来完成请求,导致接口拖慢,甚至…...
C语言中的结构体数组
一、什么是结构体数组? 在C语言中,**结构体(struct)**是一种自定义数据类型,它可以将不同类型的数据组合成一个单一的数据结构。结构体数组则是多个结构体元素按顺序存储在内存中的集合。通过结构体数组,可以存储多个相同类型的结构体,每个结构体都拥有自己独立的成员变…...
[GESP 202412 一级 T1] 温度转换
描述 小杨最近学习了开尔文温度、摄氏温度和华氏温度的转换。令符号 KK 表示开尔文温度,符号 CC 表示摄氏温度,符号 FF 表示华氏温度,这三者的转换公式如下: C K - 273.15 F C*1.8 32 现在小杨想编写一个程序计算某一开尔文…...
虚幻基础:GAS
文章目录 Gameplay Tag:项目类:可直接按标签管理游戏中的各种对象。其他:数据表格:gameplaytag primary data asset:项目类:存储游戏中的数据:通常用于配置表蓝图:primary data asse…...
案例:图书管理
掌握图书管理案例的实现,能够使用Spring Boot整合Thymeleaf完成图书管理案例。 1.任务需求 (1)项目使用Spring Boot整合Thymeleaf,项目展示的页面效果全部通过Thymeleaf的模板文件实现。 (2)查询所有图书。…...
Pycharm 社区版安装教程
找到安装包双击安装文件---点击下一步 一般路径是:C:\Rambo\Software\Development 选择完成后就是如下地址: C:\Rambo\Software\Development\PyCharm Community Edition 2024.3.3 点击上述3个位置就可以了----下一步 等待安装就可以了---完成后点击完成…...
RabbitMQ 全面详解(附面试重点)
RabbitMQ 全面详解(附面试重点) 一、RabbitMQ 与其他消息队列对比 特性RabbitMQKafkaRocketMQActiveMQ设计定位企业级消息中间件(传统业务场景)高吞吐分布式流处理平台(日志、大数据)金融级高可靠消息中间…...
浏览器好用的去广告插件和暗黑模式护眼插件
提升浏览体验:Edge浏览器的Adblock和Dark Mode扩展 Adblock:告别广告干扰 功能:高效拦截弹窗、横幅和视频广告,提升网页整洁度,加快加载速度,节省流量。安装链接:安装Adblock Dark Mode for E…...
VBA第二十七期 数据录入中验证格式有效性
Excel的数据有效性验证是一个有用的工具,但会需要我们向使用数据单元格提前设定有效性验证规则。这样一来使数据的有效性验证功能不能使用在VBA编程中。下面介绍如何在工作表中使用Change事件来创建数据有效性验证过程。监视单元格区域验证数据输入的有效性…...
基于 Verilog 的时序设计:从理论到实践的深度探索
在数字电路设计领域,时序设计是一个至关重要的环节,它涉及到组合逻辑电路与时序逻辑电路的设计差异、时钟信号的运用以及触发器的工作原理等多个方面。本文将围绕基于 Verilog 的时序设计实验展开,详细阐述实验过程、代码实现以及结果分析,帮助读者深入理解时序设计的核心概…...
[JAVASE] 反射
一. 反射概念 反射(Reflection)允许程序在运行时查询、访问和修改类、接口、字段和方法的信息。反射提供了一种动态操作类的能力。 二. Java反射的基本使用和应用 java.lang.reflect 是 Java 反射机制的核心包 ,提供了操作类及其成员&…...