定时检测文件大小

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值