.\" Automatically generated by Pod::Man 2.22 (Pod::Simple 3.07) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is turned on, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .ie \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . nr % 0 . rr F .\} .el \{\ . de IX .. .\} .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "SQUIDANALYZER 1" .TH SQUIDANALYZER 1 "2012-04-26" "perl v5.10.1" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" SquidAnalyzer v4.3 \- Squid access log report generation tool .SH "DESCRIPTION" .IX Header "DESCRIPTION" SquidAnalyzer parse native access log format of the Squid proxy and generate general statistics about hits, bytes, users, networks, top url and top second level domain. .PP Statistic reports are oriented to user and bandwidth control, this is not a pure cache statistics generator. SquidAnalyzer use flat files to store data and don't need any \s-1SQL\s0, \s-1SQL\s0 Lite or Berkeley databases. .PP This analyzer is incremental so it should be run in a daily cron. Take care if you have rotate log enable to run it before rotation is done. .PP The \s-1HTML\s0 output need a huge size for large number of user. Here on my pentium \s-1III\s0 500 MHz with 15Mb of free memory, for 600 users and an access.log of 72 Mb it takes 20 minutes to run and generate 70 Mb of \s-1HTML\s0 output by month. If you have an older system than this and want to save space and time, you can disable url details feature that logs and reports statistics for every \s-1URL\s0 and domain. .SH "REQUIREMENT" .IX Header "REQUIREMENT" perl 5.005_03 or higher and the following Perl modules: .PP .Vb 4 \& GD \& GD::Graph \& GD::TextUtil \& GD::Graph::bars3d; .Ve .PP See \s-1GD\s0 and GD::Graph requirements for other needed libraries. .PP If they are not yet include in your \s-1OS\s0 distribution you can always find them at http://search.cpan.org/ .PP If you have Internet access from your server, you can execute the following command to install GD::Graph::bars3d and all its dependencies. .PP .Vb 1 \& perl \-MCPAN \-e \*(Aqinstall GD::Graph::bars3d\*(Aq .Ve .PP Images output format is \s-1PNG\s0 so libgd must be compiled with libpng. .SH "INSTALLATION" .IX Header "INSTALLATION" .SS "Generic install" .IX Subsection "Generic install" If you want the package to be intalled into the Perl distribution just do the following: .PP .Vb 3 \& perl Makefile.PL \& make \& make install .Ve .PP Follow the instruction given at the end of install. With this default install everything configurable will be installed under /etc/squidanalyzer. The Perl library SquidAnalyzer.pm will be installed under your site_perl directory and the squid-analyzer Perl script will be copied under /usr/local/bin. .PP The default output directory for html reports will be /var/www/squidanalyzer/. .SS "Custom install" .IX Subsection "Custom install" You can create your fully customized SquidAnalyzer installation by using the Makefile.PL Perl script. Here is a sample: .PP .Vb 8 \& perl Makefile.PL \e \& LOGFILE=/var/log/squid3/access.log \e \& BINDIR=/usr/bin \e \& CONFDIR=/etc \e \& HTMLDIR=/var/www/squidreport \e \& BASEURL=/squidreport \e \& MANDIR=/usr/man/man3 \e \& DOCDIR=/usr/share/doc/squidanalyzer .Ve .PP If you want to build a distro package, there are two other options that you may use. The \s-1QUIET\s0 option is to tell to Makefile.PL to not show the default post install \s-1README\s0. The \s-1DESTDIR\s0 is to create and install all files in a package build base directory. For example for Fedora \s-1RPM\s0, thing may look like that: .PP .Vb 12 \& # Make Perl and SendmailAnalyzer distrib files \& %{_\|_perl} Makefile.PL \e \& INSTALLDIRS=vendor \e \& QUIET=1 \e \& LOGFILE=/var/log/squid/access.log \e \& BINDIR=%{_bindir} \e \& CONFDIR=%{_sysconfdir} \e \& BASEDIR=%{_localstatedir}/lib/%{uname} \e \& HTMLDIR=%{webdir} \e \& MANDIR=%{_mandir}/man3 \e \& DOCDIR=%{_docdir}/%{uname}\-%{version} \e \& DESTDIR=%{buildroot} < /dev/null .Ve .PP See spec file in packaging/RPM for full \s-1RPM\s0 build script. .SS "Local install" .IX Subsection "Local install" You can also have a custom installation. Just copy the SquidAnalyzer.pm and the squid-analyzer perl script into a directory, copy and modify the configuration file and run the script from here with the \-c option. .PP Then copy files sorttable.js, squidanalyzer.css and logo\-squidanalyzer.png into the output directory. .SS "Post installation" .IX Subsection "Post installation" 1. Modify your httpd.conf to allow access to \s-1HTML\s0 output like follow: .PP .Vb 8 \& Alias /squidreport /var/www/squidanalyzer \& \& Options \-Indexes FollowSymLinks MultiViews \& AllowOverride None \& Order deny,allow \& Deny from all \& Allow from 127.0.0.1 \& .Ve .PP 2. If necessary, give additional host access to SquidAnalyzer in httpd.conf. Restart and ensure that httpd is running. .PP 3. Browse to http://my.host.dom/squidreport/ to ensure that things are working properly. .PP 4. Setup a cronjob to run squid-analyzer daily or more often: .PP .Vb 2 \& # SquidAnalyzer log reporting daily \& 0 2 * * * /usr/local/bin/squid\-analyzer > /dev/null 2>&1 .Ve .PP or run it manually. For more information, see \s-1README\s0 file. .PP You can use network name instead of network ip addresses by using the network-aliases file. Also if you don't have authentication enable and want to replace client ip addresses by some know user or computer you can use the user-aliases file to do so. .PP See the file squidanalyzer.conf to customized your output statistics and match your network and file system configuration. .SH "CONFIGURATION" .IX Header "CONFIGURATION" Unless previous version customization of SquidAnalyzer is now done by a single configuration file squidanalyzer.conf. .PP Here follow the configuration directives used by Squid Analyzer. .IP "Output output_directory" 4 .IX Item "Output output_directory" Where SquidAnalyzer should dump all \s-1HTML\s0, data and images files. You should give a path that can be read by a Web browser. .IP "LogFile squid_access_log_file" 4 .IX Item "LogFile squid_access_log_file" Set the path to the Squid log file. .IP "NetworkAlias network\-aliases_file" 4 .IX Item "NetworkAlias network-aliases_file" Set path to the file containing network alias name. Network are show as Ip addresses so if you want to display name instead create a file with this format: .Sp .Vb 1 \& LOCATION_NAME IP_NETWORK_ADDRESS .Ve .Sp Separator must be a tabulation. .Sp You can use regex to match and group some network addresses. See network-aliases file for examples. .IP "UserAlias user\-aliases_file" 4 .IX Item "UserAlias user-aliases_file" Set path to the file containing user alias name. If you don't have auth_proxy enable users are seen as ip addresses. So if you want to show username or computer name instead, create a file with this format: .Sp .Vb 1 \& FULL_USERNAME IP_ADDRESS .Ve .Sp If you have auth_proxy enable but want to replace login name by full user name, create a file with this format: .Sp .Vb 1 \& FULL_USERNAME LOGIN_NAME .Ve .Sp Separator for both must be a tabulation. .Sp You can use regex to match and group some user login or ip addresses. See user-aliases file for examples. .IP "AnonymizeLogin 0" 4 .IX Item "AnonymizeLogin 0" Set this to 1 if you want to anonymize all user login. The username will be replaced by an unique id that change at each squid-analyzer run. Default disable. .IP "OrderNetwork bytes|hits|duration" 4 .IX Item "OrderNetwork bytes|hits|duration" .PD 0 .IP "OrderUser bytes|hits|duration" 4 .IX Item "OrderUser bytes|hits|duration" .IP "OrderUrl bytes|hits|duration" 4 .IX Item "OrderUrl bytes|hits|duration" .PD Used to set how SquidAnalyzer sort Network, User and Url report screen. Value can be: bytes, hits or duration. Default is bytes. .IP "OrderMime bytes|hits" 4 .IX Item "OrderMime bytes|hits" Used to set how SquidAnalyzer sort Mime types report screen Value can be: bytes or hits. Default is bytes. .IP "UrlReport 0|1" 4 .IX Item "UrlReport 0|1" Should SquidAnalyzer display user details. This will show all \&\s-1URL\s0 read by user. Take care to have enougth space disk for large user. Default is 0, no url detail report. .IP "QuietMode 0|1" 4 .IX Item "QuietMode 0|1" Run in quiet mode for batch processing or print debug information. Default is 0, verbose mode. .IP "CostPrice price/Mb" 4 .IX Item "CostPrice price/Mb" Used to set a cost of the bandwith per Mb. If you want to generate invoice per Mb for bandwith traffic this can help you. Value 0 mean no cost, this is the default value, the \*(L"Cost\*(R" column is not displayed .IP "Currency currency_abreviation" 4 .IX Item "Currency currency_abreviation" Used to set the currency of the bandwith cost. Preferably the html special character. Default is € .IP "TopNumber number" 4 .IX Item "TopNumber number" Used to set the number of top url and second level domain to show. Default is top 10. .IP "Exclude exclusion_file" 4 .IX Item "Exclude exclusion_file" Used to set client ip addresses, network addresses and/or auth login name to exclude from report. Format of the file is a login or an ip address by line. .IP "Lang language_file" 4 .IX Item "Lang language_file" Used to set the translation file to be used. Value must be set to a file containing all string translated. See the lang directory for translation files. Default is defined internally in English. .IP "HeaderFile custom_header_file" 4 .IX Item "HeaderFile custom_header_file" Custom header. Must be a path to a text file containing \s-1HTML\s0 code that will be placed just after the body tag and just before the program name and version. Default is defined internally if this directive is not set to a valid file. .IP "FooterFile custom_footer_file" 4 .IX Item "FooterFile custom_footer_file" Custom Footer. Must be a path to a text file containing \s-1HTML\s0 code that will be placed at the bottom of each page just before the end if the body tag. Default is defined internally if this directive is not set to a valid file. .IP "SiblingHit" 4 .IX Item "SiblingHit" Adds peer cache hit (\s-1CD_SIBLING_HIT\s0) to be taken has local cache hit. Enabled by default, you must disabled it if you don't want to report peer cache hit onto your stats. .SH "AUTHOR" .IX Header "AUTHOR" Gilles \s-1DAROLD\s0 .SH "COPYRIGHT" .IX Header "COPYRIGHT" Copyright (c) 2001\-2012 Gilles \s-1DAROLD\s0 .PP This package is free software and published under the \s-1GPL\s0 v3 or above license.