Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How do you throttle the bandwidth of a socket connection in C?

Tags:

I'm writing a client-server app using BSD sockets. It needs to run in the background, continuously transferring data, but cannot hog the bandwidth of the network interface from normal use. Depending on the speed of the interface, I need to throttle this connection to a certain max transfer rate.

What is the best way to achieve this, programmatically?

like image 549
robottobor Avatar asked Oct 25 '08 01:10

robottobor


People also ask

How fast is socket communication?

The speed of socket is 120MB/s on a computer, is it normal?


2 Answers

The problem with sleeping a constant amount of 1 second after each transfer is that you will have choppy network performance.

Let BandwidthMaxThreshold be the desired bandwidth threshold.

Let TransferRate be the current transfer rate of the connection.

Then...

If you detect your TransferRate > BandwidthMaxThreshold then you do a SleepTime = 1 + SleepTime * 1.02 (increase sleep time by 2%)

Before or after each network operation do a Sleep(SleepTime)

If you detect your TransferRate is a lot lower than your BandwidthMaxThreshold you can decrease your SleepTime. Alternatively you could just decay/decrease your SleepTime over time always. Eventually your SleepTime will reach 0 again.

Instead of an increase of 2% you could also do an increase by a larger amount linearly of the difference between TransferRate - BandwidthMaxThreshold.

This solution is good, because you will have no sleeps if the user's network is already not as high as you would like.

like image 168
Brian R. Bondy Avatar answered Oct 12 '22 21:10

Brian R. Bondy


The best way would be to use a token bucket.

Transmit only when you have enough tokens to fill a packet (1460 bytes would be a good amount), or if you are the receive side, read from the socket only when you have enough tokens; a bit of simple math will tell you how long you have to wait before you have enough tokens, so you can sleep that amount of time (be careful to calculate how many tokens you gained by how much you actually slept, since most operating systems can sleep your process for longer than you asked).

To control the size of the bursts, limit the maximum amount of tokens you can have; a good amount could be one second worth of tokens.

like image 30
CesarB Avatar answered Oct 12 '22 22:10

CesarB