mirror of
https://github.com/sot-tech/mochi.git
synced 2026-05-14 20:18:35 -07:00
54 lines
1.2 KiB
Go
54 lines
1.2 KiB
Go
// Copyright 2014 The Chihaya Authors. All rights reserved.
|
|
// Use of this source code is governed by the BSD 2-Clause license,
|
|
// which can be found in the LICENSE file.
|
|
|
|
package tracker
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/golang/glog"
|
|
|
|
"github.com/chihaya/chihaya/config"
|
|
)
|
|
|
|
func purgeTorrents(p Pool, threshold time.Duration, interval time.Duration) {
|
|
for _ = range time.NewTicker(interval).C {
|
|
before := time.Now().Add(-threshold)
|
|
glog.V(0).Infof("Purging torrents before %s", before)
|
|
|
|
conn, err := p.Get()
|
|
|
|
if err != nil {
|
|
glog.Error("Unable to get connection for a routine")
|
|
continue
|
|
}
|
|
|
|
err = conn.PurgeInactiveTorrents(before)
|
|
if err != nil {
|
|
glog.Errorf("Error purging torrents: %s", err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func StartPurgingRoutines(p Pool, cfg *config.DriverConfig) error {
|
|
if purgeThreshold := cfg.Params["purge_inactive"]; purgeThreshold != "" {
|
|
threshold, err := time.ParseDuration(purgeThreshold)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
interval := time.Minute
|
|
|
|
if purgeInterval := cfg.Params["purge_interval"]; purgeInterval != "" {
|
|
interval, err = time.ParseDuration(purgeInterval)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
go purgeTorrents(p, threshold, interval)
|
|
}
|
|
return nil
|
|
}
|