实战项目——基于多设计模式下的同步异步日志系统

news2024/11/15 15:37:32

系列文章目录

1.项目介绍

2.相关技术补充

3.日志系统框架

4.代码设计

5.功能测试

6.性能测试


文章目录

目录

系列文章目录

1.项目介绍

2.相关技术补充

3.日志系统框架

4.代码设计

5.功能测试

6.性能测试

文章目录

前言

一、项目介绍

二、开发环境

三、核心技术

四、日志系统介绍

日志系统的技术实现

同步日志

异步日志

总结


前言

为什么需要日志系统

  • 生产环境的产品喂了保证其稳定性以及安全性是不允许开发人员附加调试器去排查问题,可以借助日志系统来打印一些日志,帮助开发人员解决问题
  • 上线客户端的产品出现bug无法复现并解决,可以借助日志系统打印日志并上传到服务器端帮助开发人员进行分析
  • 对于一些高频操作(定时器、心跳包),在少量的调试次数下可能无法触发我们想要的行为,通过断点暂停的方式,我们不得不重复操作几十次或更多,导致排查问题效率非常底下,可以借助打印日志的方式查问题
  • 在分布式、多线程/多进程代码中,出现bug比较难以定位,可以借助日志系统打印log帮助定位Bug
  • 帮助首次接触代码的人员理解代码的运行流程

一、项目介绍

本项目主要实现一个日志系统,其主要支持以下功能:

  • 支持多级别日志消息
  • 支持同步和异步日志
  • 支持可靠写入日志到控制台、文件以及滚动文件中
  • 支持多线程程序并发写日志
  • 支持扩展不同的日志落地目标地

二、开发环境

  • centos7
  • vscode/vim
  • g++/gdb
  • Makefile

三、核心技术

  • 类层次设计(继承和多态的应用)
  • C++11的特性(多线程、auto、智能指针、右值引用等)
  • 双缓冲区
  • 生产消费模型
  • 多线程
  • 设计模式(单例、工厂、代理、模板等)

四、日志系统介绍

日志系统的技术实现

  • 利用printf,std::cout等输出函数将日志信息打印到控制台
  • 对于大型商业化项目,为了方便排查问题,一般将日志输出到文件或者数据库系统方便查询和分析日志,主要分为同步日志和异步日志

同步日志

同步日志是指输出日志时,必须等待日志输出语句执行完毕后,才能执行后面的业务逻辑语句。日志输出语句与业务逻辑语句在一个线程中运行,每调用一次打印日志API就对应一次系统调用write写日志文件

在高并发场景下,随着日志数量不断增加,同步日志系统容易产生瓶颈:

一方面,大量的日志陷入等量的write系统调用,有一定的系统开销

一方面,使得打印日志的进程附带了大量同步磁盘IO,影响了程序性能

异步日志

异步日志是指在进行日志输出时,日志输出语句与业务逻辑语句不在一个线程中运行,而是有专门的线程用于进行日志输出操作。业务线程只需要将日志放在一个内存缓冲区,不用等待即可执行后续业务逻辑(作为日志的生产者),而日志的落地操作单独交给日志线程去完成(作为日志的消费者),这是一个典型的生产者-消费者模型。

 这样的好处是即使日志没有完成输出,也不会影响程序的主业务,可以提高程序的性能:

主线程调用日志打印接口成为非阻塞操作

同步的磁盘IO从主线程中剥离出来交给单独的线程完成。


总结

本节主要介绍了日志系统的概要,详情请见后续文章。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/797200.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

企业博客资讯如何高效运营起来?

运营一个高效的企业博客资讯需要综合考虑多个因素,包括内容策划、发布频率、优化推广、互动反馈等。下面将从这些方面介绍如何高效运营企业博客资讯。 如何高效运营企业博客资讯 内容策划 首先,需要制定一个明确的内容策略。确定博客的定位和目标受众…

亚马逊云科技纽约峰会,充分释放数据价值和生成式AI的潜力

生成式AI将深刻改变每个公司的运营方式,标志着人工智能技术发展的新转折点。亚马逊云科技昨日在纽约峰会上宣布,推出七项生成式AI新功能,进一步降低了生成式AI的使用门槛,让无论是业务用户还是开发者都能从中受益。借助这些新功能…

Packet Tracer – 使用 CDP 映射网络

# Packet Tracer – 使用 CDP 映射网络 ## 地址分配表 设备 接口 IP 地址 子网掩码 本地接口和互联邻居 Edge1 G0/0 192.168.1.1 255.255.255.0 G0/1 - S1 S0/0/0 S0/0/0 - ISP Branch-Edge S0/0/1 209.165.200.10 255.255.255.252 S0/0/1 – ISP Branch…

window下运行sh脚本/Linux命令

安装Git 首先找到git安装官方网址,Git的官方网址如下所示 https://git-scm.com/download/win 选择合适的Git版本安装即可。 一般一直点击install即可,注意环境变量的environment path的复选框点击。具体操作以及成果标志如下博客所示。 Windows 命令…

「VS」常见提示图标含义

✨博客主页何曾参静谧的博客📌文章专栏「VS」Visual Studio📚全部专栏「UG/NX」NX二次开发「UG/NX」BlockUI集合「VS」Visual Studio「QT」QT5程序设计「C/C」C/C程序设计「Win」Windows程序设计「算法」数据结构与算法「File」数据文件格式 目录 VS官网…

深入了解HTTP代理在网络爬虫与SEO实践中的角色

随着互联网的不断发展,搜索引擎优化(SEO)成为各大企业和网站重要的推广手段。然而,传统的SEO方法已经难以应对日益复杂和智能化的搜索引擎算法。在这样的背景下,HTTP代理爬虫作为一种重要的工具,正在逐渐被…

金蝶云星空对接打通管易云物料查询接口与商品新增接口

金蝶云星空对接打通管易云物料查询接口与商品新增接口 数据源系统:金蝶云星空 金蝶K/3Cloud(金蝶云星空)是移动互联网时代的新型ERP,是基于WEB2.0与云技术的新时代企业管理服务平台。金蝶K/3Cloud围绕着“生态、人人、体验”,旨在…

java实现简单的购物车

文章目录 包含的功能增加商品删除商品修改商品购买数量展示商品 源代码Item.javaShoppingCart.java 包含的功能 增加商品 private static void addItem(ArrayList<Item> shoppingCartList, Scanner sc) {String id null;while(true){System.out.println("请输入商…

HTML <picture> 标签

实例 如何使用 <picture> 标签: <picture><source media="(min-width:650px)" srcset="/i/photo/flower-4.jpg"><source media="(min-width:465px)" srcset="/i/photo/tulip.jpg"><img src="/i/ph…

难道真是小年?24浙大MBA项目报考形势研判:避开锋芒,逆势而行

还有几天时间&#xff0c;七月就过去了&#xff01;今年浙大MBA项目提前批面试还有最后六个批次&#xff1a; 但如果把区域便利性因素考虑进去&#xff0c;对于多数考生来说只有不超过三个批次的申请机会&#xff01;随着前面批次的面试完成&#xff0c;其实看得出来今年…

机器学习01 -Hello World(对鸢尾花(Iris Flower)进行训练及测试)

什么是机器学习&#xff1f; 机器学习是一种人工智能&#xff08;AI&#xff09;的子领域&#xff0c;它探索和开发计算机系统&#xff0c;使其能够从数据中学习和改进&#xff0c;并在没有明确编程指令的情况下做出决策或完成任务。 传统的程序需要程序员明确编写指令来告诉…

《Python高并发与高性能编程:原理与实践》——小解送书第六期

目录 书籍介绍 抽奖 书籍介绍 Python成为时下技术革新的弄潮儿&#xff0c;全民Python的发展趋势让人们不再满足于简单地运行Python程序&#xff0c;逐步探索其更为广泛的日常应用和高性能设计。以ChatGPT为代表的大模型产品对初级程序开发人员提出了挑战&#xff0c;要想在开…

目前主流的平面设计工具都有哪些?

对于初学者来说&#xff0c;图形设计看起来非常复杂。其实&#xff0c;只要选择合适的平面图设计软件&#xff0c;小白就能很快做出引人注目的平面图设计作品。在下面的文章中&#xff0c;将附上市场上流行的8款平面图设计软件的详细介绍&#xff0c;供设计师选择合适的平面图设…

异地远程访问连接家里的群晖NAS【内网穿透】

文章目录 异地远程访问连接家里的群晖NAS【内网穿透】 异地远程访问连接家里的群晖NAS【内网穿透】 在现代企业中&#xff0c;协同办公和数据共享的作用已经受到广泛认可&#xff0c;而群晖作为小型数据处理中心&#xff0c;也已经进入很多公司&#xff0c;并成为局域网内的数…

【智能可视化---02】艺术数据可视化:释放Python AI中Matplotlib的力量!寻觅AI里的Matplotlib,这两篇就够了!

如果对面太得寸进尺,请反思一下是不是自己太怂,这个世界上的恶人都是被怂人惯出来的。——拿破仑 🎯作者主页: 追光者♂🔥 🌸个人简介: 💖[1] 计算机专业硕士研究生💖 🌟[2] 2022年度博客之星人工智能领域TOP4🌟 🏅[3] 阿里云社区特邀专家博…

excel要如何自动累加某个单元格上方的所有单元格?

输入公式 SUM(INDIRECT("A1:A"&ROW()-1)) 运行实例如下图 注意图中b4&#xff0c;和b5单元格都输入相同的公式。 此方法可以避免写vba&#xff0c;以前此类问题的解决都是通过vba代码进行处理 对函数进行解析 主要使用了 INDIRECT() 2、公式说明&#xff1a;…

0基础学习VR全景平台篇 第72篇:VR直播-直播模板

直播模板是指直播间的模板样式&#xff0c;目前有两种&#xff0c;分别是经典模本和极简模板。 经典模板即默认的模板&#xff0c;极简模板则是一种更简单的模板样式&#xff0c;只有背景图、直播窗口和活动介绍&#xff0c;无菜单、公告、广告、互动开关等功能。点击“极简模板…

pandas追加写入数据

前言 阅读本文约2分钟 方式 使用df对象的_append方法&#xff08;老版本为append&#xff0c;新版本为_append&#xff09; 示例 # -*- coding: utf-8 -*- # Author : markadcimport pandas as pditems [{uid: i, name: a_{}.format(i)} for i in range(3)] df pd.D…

【时频分析,非线性中频】非线性STFT在瞬时频率估计中的应用(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

SecureCRT 屏幕输出行数设置

SecureCRT 屏幕输出行数设置 第一步&#xff1a;打开设置 第二步&#xff1a;设置历史展示行数 第三步&#xff1a;保存后重启软件即可 https://www.cnblogs.com/robots2/p/17130380.html