Thread Apache splitlog (8 answers)
Opened by Balthazor at 2005-03-18 16:52

GwenDragon
 2005-03-18 18:43
#31020 #31020
User since
2005-01-17
14784 Artikel
Admin1
[Homepage]
user image
So könnte es gehen:
Code: (dl )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#!/usr/bin/perl
#
# This script will take a combined Web server access
# log file and break its contents into separate files.
# It assumes that the first field of each line is the
# virtual host identity (put there by "%v"), and that
# the logfiles should be named that+".log" in the current
# directory.
#
# The combined log file is read from stdin. Records read
# will be appended to any existing log files.
#
%is_open = ();

$apachelogdir = "/var/log/apache";

$logdir = "/home";

while ($log_line = <STDIN>) {
  #
  # Get the first token from the log record; it's the
  # identity of the virtual host to which the record
  # applies.
  #
  ($vhost) = split (/\s/, $log_line);
  #
  # Normalize the virtual host name to all lowercase.
  # If it's blank, the request was handled by the default
  # server, so supply a default name.  This shouldn't
  # happen, but caution rocks.
  #
  $vhost = lc ($vhost) or "access";
  #
  # if the vhost contains a "/" or "\", it is illegal so just use
  # the default log to avoid any security issues due if it is interprted
  # as a directory separator.
# log to apache access log if no vhost!
$logfile = "$apachelogdir/access.log";
#
  if ($vhost =~ m#[/\\]#) {
    $vhost = "access";
  } else
  {
    $logfile = "$logdir/$vhost/access.log";
  }
  #
  # If the log file for this virtual host isn't opened
  # yet, do it now.
  #
  if (! $is_open{$vhost}) {
      open $vhost, ">> $logfile"
          or die ("Can't open $logfile");
      $is_open{$vhost} = 1;
  }
  #
  # Strip off the first token (which may be null in the
  # case of the default server), and write the edited
  # record to the current log file.
  #
  $log_line =~ s/^\S*\s+//;
  printf $vhost "%s", $log_line;
}
exit 0;

Das Apache-Log muß dann wohl per Pipe an dieses Skript geschickt werden.
Also wahrscheinlich in der httpd.conf
Code: (dl )
CustomLog "| splitlog"


//Edit: Code leicht geändert\n\n

<!--EDIT|GwenDragon|1111166431-->

View full thread Apache splitlog