]> granicus.if.org Git - apache/blob - support/split-logfile
Update to Apache Software License version 1.1
[apache] / support / split-logfile
1 #!/usr/local/bin/perl
2 # ====================================================================
3 # The Apache Software License, Version 1.1
4 #
5 # Copyright (c) 2000 The Apache Software Foundation.  All rights
6 # reserved.
7 #
8 # Redistribution and use in source and binary forms, with or without
9 # modification, are permitted provided that the following conditions
10 # are met:
11 #
12 # 1. Redistributions of source code must retain the above copyright
13 #    notice, this list of conditions and the following disclaimer.
14 #
15 # 2. Redistributions in binary form must reproduce the above copyright
16 #    notice, this list of conditions and the following disclaimer in
17 #    the documentation and/or other materials provided with the
18 #    distribution.
19 #
20 # 3. The end-user documentation included with the redistribution,
21 #    if any, must include the following acknowledgment:
22 #       "This product includes software developed by the
23 #        Apache Software Foundation (http://www.apache.org/)."
24 #    Alternately, this acknowledgment may appear in the software itself,
25 #    if and wherever such third-party acknowledgments normally appear.
26 #
27 # 4. The names "Apache" and "Apache Software Foundation" must
28 #    not be used to endorse or promote products derived from this
29 #    software without prior written permission. For written
30 #    permission, please contact apache@apache.org.
31 #
32 # 5. Products derived from this software may not be called "Apache",
33 #    nor may "Apache" appear in their name, without prior written
34 #    permission of the Apache Software Foundation.
35 #
36 # THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37 # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38 # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39 # DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
40 # ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43 # USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44 # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45 # OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46 # OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47 # SUCH DAMAGE.
48 # ====================================================================
49 #
50 # This software consists of voluntary contributions made by many
51 # individuals on behalf of the Apache Software Foundation.  For more
52 # information on the Apache Software Foundation, please see
53 # <http://www.apache.org/>.
54
55 # This script will take a combined Web server access
56 # log file and break its contents into separate files.
57 # It assumes that the first field of each line is the
58 # virtual host identity (put there by "%v"), and that
59 # the logfiles should be named that+".log" in the current
60 # directory.
61 #
62 # The combined log file is read from stdin. Records read
63 # will be appended to any existing log files.
64 #
65 %is_open = ();
66
67 while ($log_line = <STDIN>) {
68     #
69     # Get the first token from the log record; it's the
70     # identity of the virtual host to which the record
71     # applies.
72     #
73     ($vhost) = split (/\s/, $log_line);
74     #
75     # Normalize the virtual host name to all lowercase.
76     # If it's blank, the request was handled by the default
77     # server, so supply a default name.  This shouldn't
78     # happen, but caution rocks.
79     #
80     $vhost = lc ($vhost) or "access";
81     #
82     # If the log file for this virtual host isn't opened
83     # yet, do it now.
84     #
85     if (! $is_open{$vhost}) {
86         open $vhost, ">>${vhost}.log"
87             or die ("Can't open ${vhost}.log");
88         $is_open{$vhost} = 1;
89     }
90     #
91     # Strip off the first token (which may be null in the
92     # case of the default server), and write the edited
93     # record to the current log file.
94     #
95     $log_line =~ s/^\S*\s+//;
96     printf $vhost "%s", $log_line;
97 }
98 exit 0;