Search squid archive

Re: Reverse Proxy Redirector Help

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Joe,
you are not allowed to use echo statements that write to stdout because
Squid is expecting ONE line and one line only per line that the script reads.
In case of an error Squid gets a second line from the script and issues an
'I do not expect this' error.

the "exit" is also not very nice.  Squid will complain about
a redirector that died and immediately start a new one.

BTW: ufdbGuard is a free redirector that can log all requests.

Marcus


Joe Tiedeman wrote:
Hi All,

I'm using Squid 2.6 Stable 18 on RHEL4 in a reverse proxy configuration
and haven't been able to find any redirectors out there which do exactly
what I would like, so I'm in the process of writing my own very simple
one in php (code below - it's by NO means complete, I'm still in the
really early development stages)

It seems to be working fine so far, just outputting to my logfile
everything which squid passes to it, however every minute (to the
second) each of the spawned redirectors puts this into the cache.log and
I can't for the life of me figure out why!

helperHandleRead: unexpected read from url_rewriter #2, 1 bytes '

It also seems that every now and again squid sends a black request to
the redirectors as they put blank lines into the temporary logfile.

It could be that I'm doing something very stupid (highly likely!) but I
was wondering if anyone could help.

Many Thanks in advance!

Joe

<?php

$stdin = fopen('php://stdin', 'r');

while (1) {

#$stdin = fopen('php://stdin', 'r');

        $line = trim(fgets($stdin));
        $filename = '/tmp/phpredirector.log';
        $somecontent = $line."\n";

// Let's make sure the file exists and is writable first.
if (is_writable($filename)) {

    // In our example we're opening $filename in append mode.
    // The file pointer is at the bottom of the file hence
    // that's where $somecontent will go when we fwrite() it.
    if (!$handle = fopen($filename, 'a')) {
         echo "couldn't open the file";
    }

    // Write $somecontent to our opened file.
    if (fwrite($handle, $somecontent) === FALSE) {
        echo "couldn't write to the file";
    }


    fclose($handle);
    echo PHP_EOL;

} else {
    exit;
}
}

?>

_____________________________________________________________________

Higher Education Statistics Agency Ltd (HESA) is a company limited by
guarantee, registered in England at 95 Promenade Cheltenham GL50 1HZ.
Registered No. 2766993. The members are Universities UK and GuildHE.
Registered Charity No. 1039709. Certified to ISO 9001 and BS 7799. HESA Services Ltd (HSL) is a wholly owned subsidiary of HESA,
registered in England at the same address. Registered No. 3109219.
_____________________________________________________________________

This outgoing email was virus scanned for HESA by MessageLabs.
_____________________________________________________________________



[Index of Archives]     [Linux Audio Users]     [Samba]     [Big List of Linux Books]     [Linux USB]     [Yosemite News]

  Powered by Linux