定时检测文件大小

来源:互联网 发布:云计算零基础教程 编辑:程序博客网 时间:2024/05/19 05:30

前段时间写了一个检测文件大小的函数,记录一下,以备后来使用:) 

 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;
}

原创粉丝点击