前段时间写了一个检测文件大小的函数,记录一下,以备后来使用:)
linux exec3 文件大小最好好象是2G,所以当一个文件大于2G的时候,就会写不进去了。由于一个日志文件特别大,所以,在写入的时候,考虑先检测文件大小,如果大于1.8个G的话,就给它rename一下。
需要定义的结构
struct stat *buf;
struct dirent **namelist;
fp = fopen(fname, "a");
if (NULL != fp)
{/* 当文件大小超过 2G 的时候,ipspy就不会记日志了,现在分析文件大小,当大于1.9G的时候,rename一下
* 保存依次为log.1,log.2等文件 add by zdm */
fd = fileno(fp);
stat(fd,buf);
if( buf->st_size >= (1.9*1024*1024*1024 ))
{ n= scandir("dir",namelist, select_logs, NULL);
if (n < 0)
{
//perror("scandir err");
DEBUG("scandir err");
}
else {
while(n--) {
//DEBUG("%s/n", namelist[n]->d_name);
snprintf(fname_bak,64,"%s.%d",fname,n+1);
if(n!=0)
snprintf(fname_old,64,"%s.%d",fname,n);
else
snprintf(fname_old,64,"%s",fname);
rename(fname_old,fname_bak);
free(namelist[n]);
}
free(namelist);
}
}
/* 只拿到符合要求的今天的日志 */
int select_logs (const struct dirent *d )
{
time_t now;
struct tm *ptm;
char today[64]={'/0'};
now = time(NULL);
ptm = localtime(&now);
snprintf(today, 64, "%04d-%02d-%02d.log",
1900 + ptm->tm_year,
ptm->tm_mon + 1,
ptm->tm_mday);
if(strstr(d->d_name, today) == 0)
return 1;
return 0;
}