通讯架构实战——4-3 日志打印实战,优化main函数调用顺序

一:基础设施之日志打印实战代码
    1-3万行代码,想收获多少就要付出多少,平衡
    注意代码的保护,私密性
    日志的重要性:供日后运行维护人员去查看、定位和解决问题;
    新文件:ngx_printf.cxx以及ngx_log.cxx。
    ngx_printf.cxx:放和打印格式相关的函数;
    ngx_log.cxx:放和日志相关的函数;

    ngx_log_stderr()  :三个特殊文件描述符【三章七节】,谈到了标准错误 STDERR_FILENO,代表屏幕
    ngx_log_stderr():往屏幕上打印一条错误信息;功能类似于printf
    printf("mystring=%s,myint=%d,%d","mytest",15,20);
    (1)根据可变的参数,组合出一个字符串:mystring=mytest,myint=15,20
    (2)往屏幕上显示出这个组合出来的字符串;
    讲解ngx_log_stderr()函数的理由:
    (1)提高大家编码能力;
    (2)ngx_log_stderr():可以支持任意我想支持的格式化字符 %d, %f,对于扩展原有功能非常有帮助
    (i)void ngx_log_stderr(int err, const char *fmt, ...)
    (i)    p = ngx_vslprintf(p,last,fmt,args); //实现了自我可定制的printf类似的功能
    (i)        buf = ngx_sprintf_num(buf, last, ui64, zero, hex, width);
    (i)    p = ngx_log_errno(p, last, err);

    二:设置时区
    我们要设置成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函数中代码执行顺序

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一门linux下c++通讯架构实战课程,针对c/c++语言已经掌握的很熟并希望进一步深造以将来用c++在linux下从事网络通讯领域/网络服务器的开发和架构工作。这门课程学习难度颇高但也有着极其优渥的薪水(最少30K月薪,最高可达60-80K月薪),这门课程,会先从nginx源码的分析和讲解开始,逐步开始书写属于自己的高性能服务器框架代码,完善个人代码库,这些,将会是您日后能取得高薪的重要筹码。本课程原计划带着大家逐行写代码,但因为代码实在过于复杂和精细,带着写代码可能会造成每节课至少要4~5小时的超长时间,所以老师会在课前先写好代码,主要的时间花费在逐行讲解这些代码上,这一点望同学们周知。如果你觉得非要老师领着写代码才行的话,老师会觉得你当前可能学习本门课程会比较吃力,请不要购买本课程,以免听不懂课程并给老师差评,差评也会非常影响老师课程的销售并造成其他同学的误解。 这门课程要求您具备下面的技能:(1)对c/c++语言掌握的非常熟练,语言本身已经不是继续学习的障碍,并不要求您一定熟悉网络或者linux;(2)对网络通讯架构领域有兴趣、勇于挑战这个高难度的开发领域并期望用大量的付出换取高薪;在这门课程,实现了一个完整的项目,其包括通讯框架和业务逻辑框架,浓缩总结起来包括如下几点:(1)项目本身是一个极完整的多线程高并发的服务器程序;(2)按照包头包体格式正确的接收客户端发送过来的数据包, 完美解决收包时的数据粘包问题;(3)根据收到的包的不同来执行不同的业务处理逻辑;(4)把业务处理产生的结果数据包正确返回给客户端;本项目用到的主要开发技术和特色包括:(1)epoll高并发通讯技术,用到的触发模式是epoll的水平触发模式【LT】;(2)自己写了一套线程池来处理业务逻辑,调用适当的业务逻辑处理函数处理业务并返回给客户端处理结果;(3)线程之间的同步技术包括互斥量,信号量等等;(4)连接池连接的延迟回收技术,这是整个项目的精华技术,极大程度上消除诸多导致服务器程序工作不稳定的因素;(5)专门处理数据发送的一整套数据发送逻辑以及对应的发送线程;(6)其他次要技术,包括信号、日志打印、fork()子进程、守护进程等等;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值