View Full Version : Multi IP balancing
Flamer
08-24-2004, 05:31 AM
First I want to tell you how impressed I am of the speed and ressource usage of ioFTPd! WOW! GREAT!
I wonder if the registered version can top this (will reg soon)...
Currently I'm using v5.8.4u and I have 3 NICs -> 3 IPs in my server.
I have setup io to use these and it works very well.
BUT I still have a suggestion for the operation of the selection of the IP for the next PASV command :D
Instead of randomly or round-robin selecting the IP could you implement an algorithm that selects on usage? E.g. count the connections each IP has and choose the one with least connections for next PASV. (Shouldn't be too hard to implement I think)
And to improve this scheme: don't count connections for listings if clients don't use "STAT -l", not to mention the control connection ;)
<- Umh, I just thought about it a second time, you had to wait what client does next after it gets PASV reply to decide if its listing or transfer, so it might not be that good since it consumes ressources...so don't bother about that too much, first suggestion would be great if you would implement it :) ->
Thank you!
Regards,
Flamer
Flamer
09-11-2004, 04:31 AM
Any comments on my suggestion, darkone? ;p
darkone
09-11-2004, 08:29 AM
What comes to registered version, it should be somewhat faster (as number of threads handling input/output, is limited to 1 in unregistered version + there's memory pooling in the registered version - which reduces memory fragmentation + it speeds up memory allocations)
There are certain problems related to load balancing per number of connections / bandwidth / bytes transfered per device.
Number of connections: directory lists make it nearly impossible to guess how many of the connections are being used for file transfers. If someone issues list at same time you begin your transfer, there's 50% chance that wrong device is selected (device 'x' has two file transfers while device 'z' has none). Not to mention problems that stalled connections, slow transfers etc. cause.
Bytes transfered: What if two clients concurrently begin transfering 'n'gb file. Server would need to know name of file that is going to be transfered, before client issues PASV/PORT.
Bandwidth: You'd need to know average transfer rate for transfer that has not yet been done, before the client begins transfering.
Number of connections is the only thing that _could_ actually provide decent accuracy, but it requires hundreds of simultanous transfers.
Flamer
09-11-2004, 09:24 AM
Thank you for your answer!
(Although I'm not quite satisfied with it ;) )
I should have mentioned my thoughts when I posted my suggestion: the intended usage is for a LAN where you have high-speed transfers.
I think in a situation where there are many users (lets say from twice the number of NICs) downloading not too large files from the ftp server, the round-robin scheme is a good selection.
I want to explain a scenario where IP selection based on connection count would be of great advantage:
(Lets assume my config with 3 NICs used for balancing)
Lets further assume there are mostly large (>500MB) files on the server, like videos or stuff...
Now let 2 or 3 clients browse and add files to their queues.
After that they begin downloading. So client1 will start on NIC1, client2 on NIC2 and client3 on NIC3, so far so fine.
But now client1 does not use full bandwidth cause it is downloading from other source or pc is slow or whatever so it gets only 4 mb/s. clients 2 and 3 get 11 mb/s and are far earlier ready and request the next file. So client2 will be on NIC1, together with client1 and gets only 7 mb/s. Client3 is fine alone on NIC2... now I assume worst case and client2 now has very large file to transfer, so both client 1 and 2 dl from NIC1 a long time. And Client 3 has some smaller files and will end up sharing NIC1 with the 2 others, effectively its download will be 1/3 what it could be, because NICs 2 and 3 idle... with greater number of users this -could- be worse.
I know this is not very likely to happen, BUT I want my clients always served at best possibilities :) , so if connections were counted they would get most bandwidth for their transfers.
For the listing connections, I don't think they affect this scheme too much, because 1.) who uses LIST anymore, we have STAT ;) and 2.) its only a short time this connection is used, its unlikely that during this time a transfer starts.
So enough now...I think you already understand what I wanted to explain.
I don't want you to waste time implementing such an algorithm if you think its not worth it, I just want you to consider my suggestion next time you have some spare time and don't know what to do :D
But maybe you think now that its a not so bad idea after all and implement it in the not so far future, then I would be very glad!
Anyways, you've done great work on this ftp server!!
Regards,
Flamer
Mouton
09-11-2004, 10:23 AM
I don't think any ftp client uses STAT by default, so I would say 99%+ of the users on a FTP server uses LIST.
ioFTPD is designed to optimally handle thousands of simultaneous connections. The target audience is not FTP servers with only 3 simultaneous clients. When you have thousands of clients, the chances of LISTs occuring at the same time as RETR is pretty high I would guess.
Flamer
09-11-2004, 10:56 AM
I totally agree with you, Mouton.
I know that my scenario is not the usual case, but nevertheless I have use for this balancing algorithm.
And that's also why I said -if darkone has some spare time- and does not know what to do he could think of my suggestion ;)
Regards,
Flamer
darkone
09-11-2004, 12:39 PM
Well I think I can fit it into service/device rewrite. As I need to make them more generic (kinda like what my socket/file sturctures are atm with the new core)
Flamer
09-11-2004, 07:13 PM
Sounds great :)
Looking forward to testing the new feature.
I just bought a license of ioFTPd, needed SSL and wanna see how the regged version compares in term of speed and resource usage to the unregged one...
Regards,
Flamer
vBulletin® v3.8.11 Alpha 3, Copyright ©2000-2025, vBulletin Solutions, Inc.