153 Linux C++ 通讯架构实战8 ,日志打印实战,设置时区,main函数中顺序调整

本文主要是介绍153 Linux C++ 通讯架构实战8 ,日志打印实战,设置时区,main函数中顺序调整,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

日志打印实战

    //日志的重要性:供日后运行维护人员去查看、定位和解决问题;
    //新文件:ngx_printf.cxx以及ngx_log.cxx。
    //ngx_printf.cxx:放和打印格式相关的函数;
    //ngx_log.cxx:放和日志相关的函数;

实际上这一节的主要内容是实现一个类似printf的函数,以及如何在代码有问题的时候保存日志。

 

这部分将老师的笔记记录在这里,需要消化一下,应该需要花费的时间在1天以上,才能看个7788

二:设置时区

我们要设置成CST时区,以保证日期,时间显示的都正确

使用date查看 ,如果不是CST的,就说明我们要改动:

当前结果为2024年 03月 29日 星期五 18:06:03 CST

当前开机有效

linux 命令行 : tzselect

然后选4,再选9,选1,选1

下次开机也有效

 sudo cp /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime


    //我们要设置成CST时区,以保证日期,时间显示的都正确
    //我们常看到的时区,有如下几个:
    //a)PST【PST美国太平洋标准时间】 = GMT - 8;
    //b)GMT【格林尼治平均时间Greenwich Mean Time】等同于英国伦敦本地时间
    //c)UTC【通用协调时Universal Time Coordinated】 = GMT
    //d)CST【北京时间:北京时区是东八区,领先UTC八个小时】

三:基础设施之日志打印实战代码二


    //(3.1)日志等级划分
    //划分日志等级,一共分8级,分级的目的是方便管理,显示,过滤等等;
    //日志级别从高到低,数字最小的级别最高,数字最大的级别最低;

    //(3.2)配置文件中和日志有关的选项
    //继续介绍void ngx_log_init();打开/创建日志文件
    //介绍ngx_log_error_core()函数:写日志文件的核心函数
    //ngx_slprintf
    //    ngx_vslprintf

四:捋顺main函数中代码执行顺序

这篇关于153 Linux C++ 通讯架构实战8 ,日志打印实战,设置时区,main函数中顺序调整的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/859485

相关文章

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr