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

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque