*nix Thread, Internet Filter is Sloooooooow... in Technical; Hi all,
I'm pretty sure this is a Linux problem rather than a filter problem so I've put this here ...
23rd March 2010, 10:01 AM #1
Internet Filter is Sloooooooow...
I'm pretty sure this is a Linux problem rather than a filter problem so I've put this here for now...
Basically I have, at length and with the help of serveral guides written by people who know far more about linux that me, built an Intenet Filter using squid and dansguardian running on Ubuntu (desktop - not the server edition). It works fine, we use a little program on the client called smoothwallIDT (no relation to the smoothwall products themselve I'm told) that basically wraps the username and computer details in the IDENT protocal. DansGuardian can then read it and give appropriate group access (banned, moderate filtering, heavy filtering, unbanned).
The trouble has been that the idt program sometimes doesn't load on boot and so users are not getting internet. So this time I built the filter, bound it to the domain using winbind, samba, kerberos, squid and dans, and with much fiddling have fudged it to authenticate directly from Active Directory using NTLM.
All well and good - this does actually work. But it is unusably slow. It never takes less than 5 minutes to load google. Yahoo is timed at 9 minutes. The filter is designed to authenticate using either IDENT or NTLM, so if the idt program is running it uses that intead. In that case, it works fine and loads in seconds.
Now admittedly I'm not running this system on a proper server, just a desktop workstation. But it is a brand new desktop, an HP dc5800, C2D 3GHz, 2 GB ram, etc. And it is just me on my lone computer having my internet filtered to test it, rather than the whole school. So I don't think it has any excuse to be this slow!!
As I understand it, ntlm_auth uses a handshake protocol to authenticate, but nothing I have read implies that it should be this slow. If I swap over and make people use this, they will thing that we just downgraded to dial-up modems
Any thoughts on what I could do to speed things up?
23rd March 2010, 10:07 AM #2
Anything out of the ordinary in the log files?
/var/log/squid/ - cache.log, error.log (or whatever else is there)
Have you tried switching to just NTLM and getting rid of IDENT? Do you have IPv6 enabled? Having IPv6 enabled on IPv4-only networks can sometimes cause networking delays.
EDIT: And how many child processes do you use for the NTLM auth process? I remember a long time ago we made this a large amount as we thought it would be better; but 5 was sufficient.
Last edited by webman; 23rd March 2010 at 10:12 AM.
23rd March 2010, 10:08 AM #3
Weird! I wouldn't think its the speed, our proxy is an old RM FSeries with about 1GB Ram and a P4 2.4..... its shocking but delivers the web fast enough!!! We use IDENT authentication, its fails sometimes which is annoying but most of the time it is reliable.
Use wireshark to look for collisions or unneccesary traffic from the box.
23rd March 2010, 10:42 AM #4
I have 5 child processes running. I haven't intentionally set IPv6 to enabled - is that a setting in squid, or in the networking on the machine?
Originally Posted by webman
I'll try it without IDENT next and let you know how it does.
23rd March 2010, 10:43 AM #5
Good thought - I'll give that a shot!
Originally Posted by Jamo
23rd March 2010, 10:46 AM #6
I believe disabling IPv6 varies between versions. Google for "Ubuntu <version name> disable ipv6".
But it will be similar to the procedures outlined in these:
How-To: Disable IPV6 to speed up Internet. [Archive] - Ubuntu Forums
How to Disable IPV6 in Ubuntu|Ubuntu Geek
23rd March 2010, 11:27 AM #7
Hmm. It seems to have stopped working entirely now...
Earlier this morning when it was working I didn't have anything helpfull in the logs. Now I have errors in cache log as follows:
So it has stopped authenticating. All I've changed is disabled IPv6 (which we don't use, so that shouldn't be it) and disabled the IDENT. Which I have now turned back on, but it doesn't fix it. How weird!!
utils/ntlm_auth.c:173(get_winbind_domain) could not obtain winbind domain name!
WARNING: ntlmauthenticator #2 (FD 8) exited
WARNING: ntlmauthenticator #5 (FD 11) exited
WARNING: ntlmauthenticator #1 (FD 12) exited
WARNING: ntlmauthenticator #3 (FD 14) exited
Once I've beaten it until it works again, I'll carry on with your suggestions, but if this post goes dead for half a day or so, you know it's being stubborn!
Thanks for your help so far!!
23rd March 2010, 11:32 AM #8
Can the box still communicate with the internet and the Windows servers? Do things like wbinfo -u, wbinfo -t etc from the terminal.
23rd March 2010, 11:37 AM #9
wbinfo -u/-t both fail. The server can still see the internet itself, and ping the dc. The computer connected tot he internet through it is prompted for a windows dmoain-style login box, but rejects a correct login until I get the a "squid cache Access Denied" page.
Originally Posted by webman
Not sure what I did to it, but it's not happy
23rd March 2010, 11:39 AM #10
Perhaps it's grumbling about the IPv6 changes - just for curiosity's sake, un-do the disabling you did before to see if that helps it.
Again, there could be something in the logs - likely to be in /var/log/samba.
23rd March 2010, 12:26 PM #11
It may be that your Ad is taking too long to respond to queries? I know we cache auth results to keep things nippy, but then I have heard tell of setups like you describe working for smaller numbers of users.
Thanks to tom_newton from:
24th March 2010, 01:41 PM #12
Thanks for your help yesterday! It is all fixed now, but as is so often the case when I work in Linux, I'm not entirely sure what I did to fix it!! I just get frustrated until I just start changing things that look in some way suspicious until I either kill it completely or fix it. Guess I got lucky this time!
Seriously though, one of the reasons may well be the removal of Ident from the plugins as webman suggested straight out - I had tried this yesterday and had thought it hadn't worked, but as it transpired the system had already mysteriously died by that point.
In case anyone else stumbles upon this later, it is also worth noting that the permissions on /var/run/samba/winbindd_priviledged are set wrong everytime the service restarts - it needs the group to be "proxy" and the group needs write access. I'll have to work on a script to change that automatically on the service restart, but for now I'm busy being chuffed that my filter works and authenticates from a windows domain!! Beers for me tonight!!
Thanks again for all your suggestions!
24th March 2010, 01:43 PM #13
Sounds strangely familiar!
Originally Posted by Tyiell
By phughes in forum Network and Classroom Management
Last Post: 25th September 2008, 04:31 PM
By SimpleSi in forum General Chat
Last Post: 28th January 2008, 11:14 AM
By netadmin in forum *nix
Last Post: 30th May 2007, 09:12 AM
By _Bat_ in forum How do you do....it?
Last Post: 13th December 2006, 05:13 PM
Users Browsing this Thread
There are currently 1 users browsing this thread. (0 members and 1 guests)