Linux下实现跟踪程序执行信息记录日志文件

2024-02-19 22:18

本文主要是介绍Linux下实现跟踪程序执行信息记录日志文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

//debug.h

/*************************************************************    
FileName : debug.h
FileFunc : 头文件
Version  : V0.1    
Author   : Sunrier    
Date     : 2012-06-09
Descp    : Linux下实现跟踪程序执行信息记录日志文件   
*************************************************************/
#ifndef   _DEBUG_H_    
#define   _DEBUG_H_ 
#ifdef __cplusplus
extern "C" {
#endif
#include <stdio.h>
#include <stdlib.h> 
#include <string.h>  
#include <time.h> 
#include <dirent.h>
#include <stdarg.h> 
#include <sys/stat.h>
#define ERROR        __FILE__,__LINE__,0x01
#define DEBUG        __FILE__,__LINE__,0x02
void GetCurrentTime(char *pTime);
void SetLogName(char *pLogPath,char *pProcName,char *pLogName);
void TRACE_LOG(char *pFileName,int iLine,int iLogType,char *pLogName,const char *fmt, ...);
#ifdef __cplusplus
}
#endif
#endif 


 

//debug.c

/*************************************************************    
FileName : debug.c
FileFunc : 实现文件
Version  : V0.1    
Author   : Sunrier    
Date     : 2012-06-09
Descp    : Linux下实现跟踪程序执行信息记录日志文件  
*************************************************************/
#include "debug.h"
void GetCurrentTime(char *pTime)
{
time_t t;
struct tm tm1;
t=time(NULL);
memcpy(&tm1,localtime(&t),sizeof(struct tm));
sprintf(pTime,"%04d%02d%02d%02d%02d%02d",tm1.tm_year+1900,tm1.tm_mon+1,tm1.tm_mday,tm1.tm_hour,tm1.tm_min,tm1.tm_sec);
}
void SetLogName(char *pLogPath,char *pProcName,char *pLogName)
{
char szTime[15];
DIR *pDir = NULL;
memset(szTime,0,sizeof(szTime));
GetCurrentTime(szTime);
pDir = opendir(pLogPath);
if( pDir==NULL )
{	
mkdir(pLogPath,S_IREAD|S_IWRITE|S_IEXEC);
}	
else
{	
closedir(pDir);
}	
sprintf(pLogName,"%s/%s%.6s.log",pLogPath,pProcName,&szTime[2]);
}
void  TRACE_LOG(char *pFileName,int iLine,int iLogType,char *pLogName,const char *fmt, ...)
{
FILE *fp;
va_list vap;
char szTime[15];
char szLogType[10];
char szTemp[512];
int iLen=0;
memset(szTime,0,sizeof(szTime));
memset(szLogType,0,sizeof(szLogType));
memset(szTemp,0,sizeof(szTemp));
GetCurrentTime(szTime);
va_start(vap,fmt);
if(iLogType==0x01)
{	
strcpy(szLogType,"ERROR");
}	
else if(iLogType==0x02)
{	
strcpy(szLogType,"DEBUG");
}
sprintf(szTemp,"[%14s][P%d][%10s][L%04d][%.6s]:\n",szTime,getpid(),pFileName,iLine,szLogType);
//iLen=strlen(pLogName)-10;
//memcpy(pLogName+iLen,&szTime[2],6);
fp=fopen(pLogName,"a+");
fprintf(fp,"%s",szTemp);
vfprintf(fp,fmt,vap);
fprintf(fp,"\n");
fflush(fp);
fclose(fp);
fprintf(stderr,"[%s][P%d][%s][%d]:",szLogType,getpid(),pFileName,iLine);
memset(szTemp,0,sizeof(szTemp));
vsprintf(szTemp,fmt,vap);
va_end(vap);
fprintf(stderr,"%s\n",szTemp);//打印到屏幕
fflush(stderr);
}


 

//demo.c

/*************************************************************    
FileName : demo.c
FileFunc : 跟踪程序执行信息并把相应执行结果记录到日志文件
Version  : V0.1    
Author   : Sunrier    
Date     : 2012-06-09
Descp    : Linux下实现跟踪程序执行信息记录日志文件  
*************************************************************/
#include <stdio.h>
#include <string.h>
#include "debug.h"
int func( int iFlag )
{
if( iFlag )
{
return 0;
}
else
{
return 1;
}		 
}
int main(int argc,char *argv[])
{
char szLogPath[100],szProcName[100],szLogName[100];
char *p = NULL;
int iRetCode = 0;
int iFlag = 0;
memset(szLogPath,0,sizeof(szLogPath));
memset(szProcName,0,sizeof(szProcName));
memset(szLogName,0,sizeof(szLogName));
p = strrchr(argv[0],'/');
sprintf(szProcName,"%s_",p);
sprintf(szLogPath,"%s/log",getenv("HOME"));
SetLogName(szLogPath,szProcName,szLogName);
iFlag = 0;
iRetCode = func( iFlag );
if( iRetCode )
{
TRACE_LOG(ERROR,szLogName,"func error,iRetCode=[%d]\n",iRetCode);
return 1;
}
TRACE_LOG(DEBUG,szLogName,"Success =[%d]\n",iRetCode);
//TRACE_LOG(DEBUG,"Success !");
return 0;
}


 

//makefile

#makefile
demo:demo.c debug.c debug.h
@gcc -o demo demo.c debug.c
clean	:
@cd /mnt/hgfs/Sunrier/code/ && \
ls | grep -v ^makefile$$ | grep -v [.]c$$ | grep -v [.]h$$ | grep -v [.]sql$$ | grep -v [.]sh$$ | xargs rm -rf
#makefile	


 

这篇关于Linux下实现跟踪程序执行信息记录日志文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali