The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]




Версия для распечатки Пред. тема | След. тема
Новые ответы [ Отслеживать ]
Подсчет трафика по логам, !*! lex, 31-Мрт-05, 12:07  [смотреть все]
Написал программку может кому поможет...Да не судите строго...С англиским беда
по этому описание ключей писал на искаверкнутом латинском...
Идея прогрммки в следующем есть лог например сквид, указываем поля которые хотим обработать и получаем конечный результат  - >
Работает на мой взглят очень шустро 2 минуты 500mb лога
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
#include <stddef.h>
#include <string.h>
#include <fcntl.h>
#include </usr/include/sys/io.h>
#include </usr/include/sys/stat.h>

struct real_date
{
  char r_mes[10][20];
  char r_dey[10][10];
}real_date_info;

char data();

char summa(char *opt_ip, char *opt_name);

char options(char *znach1, char *znach2);

char open_access_file(char *znach1, char *znach2, char *kol_pol, char *vvod_data, char *vvod_ip, char *vvod_bait);
char final_sort_great_file(char *log_date, char *log_ip, char *log_url, char *log_bait);

int main(int argc, char *argv[])
{

data();

if(argv[1]!=0)
{
if(!strcmp(argv[1],"-d"))
  {
   open_access_file(argv[1],argv[2],argv[3],argv[4],argv[5],argv[6]); //argv[3]-kol-vo strok;argv[4]-date;argv[5]-ip;argv[6]-bait
   options(argv[1],argv[2]);
  
   printf("Vse OK\n");
  }

if(!strcmp(argv[1],"-m"))
  {
   open_access_file(argv[1],argv[2],argv[3],argv[4],argv[5],argv[6]);
   options(argv[1],argv[2]);
  
   printf("Vse OK\n");
  }
      
if(!strcmp(argv[1],"-a"))
   {
    printf("Y napisal a kto eche\n");
    printf("Mtraf -  parser for log SQUID\n");
    printf("Send mail: wiza_rd@mail.ru\n");
   }      

if(!strcmp(argv[1],"--help"))
   {
    printf("================================================================================================\n");
    printf("        ->       dey | razdelitel(-p;-t) | kol-vo stolbcov | ( stolbcu ot 0 -> esle data 0 to -1\n");
    printf("example -> mtraf -d         -p                   11                     -1 1 2\n");
    printf("================================================================================================\n");
    printf("-d    Enter key to tekchiy day\n");
    printf("-m    Enter key to month\n");
    printf("-p    Razdelitel probel\n");
    printf("-t    Razdelitel tab\n");
    printf("-a    Kto napisal\n");
    printf("Stolbcu ukazuvaqt v sleduqchem porydke ot 0 -> kol-vo stolbcov data,ip,bait pri etom esle data edet 0 um stolbcom to -1\n");  
  
   }
}else{
       printf("mtraf --help\n");
      }
  
  return 0;
}

char open_access_file(char *znach1, char *znach2, char *kol_pol, char *vvod_data, char *vvod_ip, char *vvod_bait)
{
  FILE *fp;
  
  char buffer[5000];    //strka iz access.log
  char buffer1[5000];   //razbituy na leksemu stroka
  char buffer2[50][50]; //stroka & kol-vo simvolov
  char datess[50][50];
  
  char new_date[11];
  char new_date1[11];

  int buflen,x,dates,k,syze_kol,syze_data,syze_ip,syze_bait;
  char len;
  
  char *p;
  char *p1;
  char *g;
  char *g1;
  
  char *dte;
  
    
  time_t now;
  dte=(char *)malloc(11);
  now = time(NULL);
  strncpy(dte,ctime(&now),11);
  
  p1=buffer1;
  p=buffer;
  buflen=5000;

  g=new_date;
  g1=new_date1;

  if ((fp = fopen("access.log", "r")) == NULL)       //otkruvaem config fail
                  {
     printf("Error open file\n");
     exit(1);
    }

  syze_kol=atoi(kol_pol);          //poluchaem kol-vo stolbcov
  syze_data=atoi(vvod_data);          //poluchaem kol-vo stolbcov
  syze_ip=atoi(vvod_ip);          //poluchaem kol-vo stolbcov
  syze_bait=atoi(vvod_bait);          //poluchaem kol-vo stolbcov

  while(!feof(fp))                 //read fail  
       {
        fgets(buffer, buflen, fp); //reaf fail and write "buffer"
        len=strlen(buffer);        //see size "buffer"
    
     if(!strcmp(znach2,"-p"))
       {
        p1 = strtok(p," ");        //tak kak pbuffer nachinaem razbor strok
       }else{
             if(!strcmp(znach2,"-t"))
              {
               p1 = strtok(p,"\t");        //tak kak pbuffer nachinaem razbor strok
              }else{
                    printf("%s\n", "Error key!!!");
             exit(0);
                   }
     }    

for(x=0;x<=syze_kol;x++)          //9 ento kolichestvo stolbcov
  {
           while  (p1  != NULL)              //otkruvaem cukl poka p1 ne stanet ravno 0
         {
  if(!strcmp(znach2,"-p"))
   {
    p1 = strtok(NULL," ");      
          }
                if(!strcmp(znach2,"-t"))
   {
    p1 = strtok(NULL,"\t");      
          }

   if(p1 != NULL)
     {
      strcpy(buffer2[x],p1);   //pomechaem leksemu v buffer2
          break;
     }
   }
   }

       if(!strcmp(znach1,"-d"))
        {
        
         if(syze_data == -1)
    {    
    dates=atoi(buffer);
           strncpy(new_date,ctime(&dates),11);

    if(!strcmp(dte,new_date))
             {
              final_sort_great_file(new_date,&buffer2[syze_ip-1][0],&buffer2[5][0],&buffer2[syze_bait-1][0]);
             }

          }else{
         dates=atoi(&buffer2[syze_data-1][0]);
  strncpy(new_date,ctime(&dates),11);
    
         if(!strcmp(dte,new_date))
                  {
            final_sort_great_file(&buffer2[syze_data-1][0],&buffer2[syze_ip-1][0],&buffer2[5][0],
                                                                  &buffer2[syze_bait-1][0]);
                  }
               }
  
        }
      
       if(!strcmp(znach1,"-m"))
        {
         if(syze_data == -1)
   {
           dates=atoi(buffer);
          
    strncpy(new_date,ctime(&dates),11);
        
    g1 = strtok(g," ");
  
    for(k=0;k<=2;k++)
    {
     while(g1 != NULL)
          {
    g1 = strtok(NULL," ");
    if(g1 != NULL)
     {
      strcpy(datess[k],g1);
      break;
     }
   }
    }
  
     //printf("%s\n",&datess[0][0]);
  
     if(!strcmp(&datess[0][0],&real_date_info.r_mes[0][0]))
             {
              final_sort_great_file(&datess[0][0],&buffer2[syze_ip-1][0],&buffer2[5][0],&buffer2[syze_bait-1][0]);
             }
    
    }else{
           dates=atoi(&buffer2[syze_data-1][0]);
          
    strncpy(new_date,ctime(&dates),11);
        
    g1 = strtok(g," ");
  
    //printf("%s",g1);
  
    for(k=0;k<=2;k++)
    {
     while(g1 != NULL)
          {
    g1 = strtok(NULL," ");
    if(g1 != NULL)
     {
      strcpy(datess[k],g1);
             // printf("%s",g1);
             break;
     }
   }
    }
  
     printf("%s\n",&datess[0][0]);
  
     if(!strcmp(&datess[0][0],&real_date_info.r_mes[0][0]))
             {
              final_sort_great_file(&datess[0][0],&buffer2[syze_ip-1][0],&buffer2[5][0],&buffer2[syze_bait-1][0]);
             }
    
    }
    
    
         }
  
      }//end while
      
fclose(fp);
free(dte);//osvobajdaem datu
return;
}

char final_sort_great_file(char *log_date, char *log_ip, char *log_url, char *log_bait)
{
  FILE *fpip;
  if((fpip=fopen(log_ip,"a+"))==NULL)
   {
    printf("Error creat ip file\n");
    exit(1);
   }
  fprintf(fpip,"%s %s\n",log_ip,log_bait);
  fclose(fpip);
}

//2 Chast programmu
char options(char *znach1, char *znach2)
{
  FILE *fpop;
  char *opt_ip;
  char *opt_name;
  
  if((fpop=fopen("options","r"))==NULL)
    {
     printf("Error OPTIONS file\n");
     exit(1);
    }

  while(fpop)
   {
    opt_ip=(char *)malloc(100);
    opt_name=(char *)malloc(100);
  
    if(fscanf(fpop,"%s %s\n",opt_ip,opt_name)!=EOF)
      {
          
      summa(opt_ip,opt_name);
      
      free(opt_ip);
      free(opt_name);
      }else{
            fclose(fpop);
            return;
            }
   }
}

char summa(char *opt_ip, char *opt_name)
{
FILE *fpip;
FILE *fpit;

char *log_ip;
char *log_bait;
double sum,kon_bait;

sum=0;

if((fpip=fopen(opt_ip,"r"))==NULL)
   {
//   printf("Error ip file\n");
   }

if((fpit=fopen("Itog_day","a+"))==NULL)
   {
    printf("Error ETOG file\n");
    exit(1);
   }

while(fpip)
  {
  log_ip=(char *)malloc(100);
  log_bait=(char *)malloc(100);
  
  if(fscanf(fpip,"%s %s",log_ip,log_bait)!=EOF)
    {
    kon_bait=atof(log_bait);
    sum=kon_bait+sum;
    
    free(log_ip);
    free(log_bait);  
    }else{
         //printf("%d\n",sum);
         fprintf(fpit,"%s %s %f\n",opt_ip,opt_name,sum);
         fclose(fpip);
  fclose(fpit);
  return;
         }
  }
}


char data()
{
  char *dte;
  char *dte1;
  char dates1[50][50];
  int x;
  
  time_t now;
  dte=(char *)malloc(11);
  dte1=(char *)malloc(11);

  now = time(NULL);
  strncpy(dte,ctime(&now),11);
  
  dte1 = strtok(dte," ");

for(x=0;x<=2;x++)
   {
  while(dte1 != NULL)
       {
        dte1=strtok(NULL," ");
        if(dte1 != NULL)
{
  strcpy(dates1[x],dte1);
  break;
}
       }
   }      
//printf("-%s\n",&dates1[0][0]);
for(x=0;x<=2;x++)
  {
   strcpy(real_date_info.r_mes[x],&dates1[0][0]);
  }
free(dte);
free(dte1);

return;
}
Только не слишком бейте!

  • Подсчет трафика по логам, !*! dimus, 15:16 , 31-Мрт-05 (1)
    В принципе это полезная программа, только вот есть sarg, который очень хорошо генерирует отчет в формате html. Думаю, что он обладает несколько большей функциональностью, так что вам вряд ли удасться широко ее внедрить :) Я думаю, что есть две хороших возможности для усовершенствования.
    1 - Интернационализация
    2 - Повышение быстродействия
    3 - Генерация красивых отчетов

    Чтобы переплюнуть sarg вам прийдется постараться. Желаю вам удачи на этом пути.

  • Подсчет трафика по логам, !*! MaximKuznetsov, 20:19 , 31-Мрт-05 (2)
    почин хороший, НО
    ценность программы близка к 0 по нескольким причинам :
    1 - вообще-то неплохо писать документацию. (что и с чем программа делает)
    2 - пишите комментарии..если не знаете английского - пишите по русски, но не на латинице (не издевайтесь над родным языком)..
    + полно багов ;(
    изучите детальнее вывод gcc -Wall ,
    пропустите код через splint и изучите выводы ;-)
    отучитесь держать массивы(тем более для работы со строками) в стеке..
    итд
    ..
    Успехов !




Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2025 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру