2016-10-22 00:21:28 -07:00
|
|
|
// Accounting and limiting reader
|
|
|
|
// Unix specific functions.
|
|
|
|
|
2021-09-09 15:25:25 +03:00
|
|
|
//go:build darwin || dragonfly || freebsd || linux || netbsd || openbsd || solaris
|
2016-10-22 00:21:28 -07:00
|
|
|
|
2018-01-12 16:30:54 +00:00
|
|
|
package accounting
|
2016-10-22 00:21:28 -07:00
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
2018-01-12 16:30:54 +00:00
|
|
|
|
2019-07-28 18:47:38 +01:00
|
|
|
"github.com/rclone/rclone/fs"
|
2016-10-22 00:21:28 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// startSignalHandler() sets a signal handler to catch SIGUSR2 and toggle throttling.
|
2020-07-04 17:20:54 +01:00
|
|
|
func (tb *tokenBucket) startSignalHandler() {
|
2016-10-22 00:21:28 -07:00
|
|
|
signals := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(signals, syscall.SIGUSR2)
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
// This runs forever, but blocks until the signal is received.
|
|
|
|
for {
|
|
|
|
<-signals
|
2023-06-22 17:59:24 +01:00
|
|
|
|
|
|
|
func() {
|
|
|
|
tb.mu.Lock()
|
|
|
|
defer tb.mu.Unlock()
|
|
|
|
|
|
|
|
// if there's no bandwidth limit configured now, do nothing
|
|
|
|
if !tb.currLimit.Bandwidth.IsSet() {
|
|
|
|
fs.Debugf(nil, "SIGUSR2 received but no bandwidth limit configured right now, ignoring")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
tb.toggledOff = !tb.toggledOff
|
|
|
|
tb.curr, tb.prev = tb.prev, tb.curr
|
2024-09-26 18:01:18 +01:00
|
|
|
s, limit := "disabled", "off"
|
2023-06-22 17:59:24 +01:00
|
|
|
if !tb.curr._isOff() {
|
|
|
|
s = "enabled"
|
2024-09-26 18:01:18 +01:00
|
|
|
limit = tb.currLimit.Bandwidth.String()
|
2023-06-22 17:59:24 +01:00
|
|
|
}
|
|
|
|
|
2024-09-26 18:01:18 +01:00
|
|
|
fs.Logf(nil, "Bandwidth limit %s by user (now %s)", s, limit)
|
2023-06-22 17:59:24 +01:00
|
|
|
}()
|
2016-10-22 00:21:28 -07:00
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|