-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ability to limit/throttle bandwidth #34
Comments
I have begun working on this in the development branch here: https://github.com/yunginnanet/HellPot/blob/development/internal/util/speedometer.go |
only need to implement now |
crosspost from #35 |
this doesn't work properly when the buffer is larger than the frame, it sends the entire first buffer, and then takes a lot of time throttling out the rest, basically stalling |
makes sense. the implementation was going to come along with a unit test to assure this works properly, part of why i am not rushing it likely i may just need to create a non-blocking implementation option within the ratelimiter package and respond to an error within HellPot upon throttle instead of blocking/sleeping on write calls |
while this made sense when I initially read it, it'd be helpful to see an example in the form of a go playground share or a test case to properly demonstrate this flaw tldr; PoC pls current code is here: https://github.com/yunginnanet/Rate5/tree/main/speedometer note that here i use a buffer twice as large as the burst value during the TCP testcase: |
when i set the frame to 1024 bytes and the interval to 1 second, it writes the entire buffer at once, a few times over, before stopping when it meets a "check every byte" boundary when i made that check work every write, it seems to throttle and stall after the first buffer write sp, nerr := util.NewLimitedSpeedometer(bw, &util.SpeedLimit{
Burst: 1024 * 4,
Frame: 1 * time.Second,
CheckEveryBytes: -1,
Delay: 100 * time.Millisecond,
})
if nerr != nil {
return n, nerr
}
if n, err = io.CopyBuffer(sp, h.mm, buf); err != nil {
return n, nil
} (Here i've changed the backend code of the speedlimiter to behave better (by writing buffers in chunks, and checking speed every time), but the current version will not work with this. You might wanna set |
thank you, i'll look further into this |
An option to limit bandwidth usage per second or per day/month would be a welcome feature.
The text was updated successfully, but these errors were encountered: