mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-22 22:58:25 +00:00
Very basic status service
This commit is contained in:
parent
030b1f3467
commit
81f4de965f
@ -32,6 +32,8 @@ var (
|
|||||||
globalLimitBps int
|
globalLimitBps int
|
||||||
sessionLimiter *ratelimit.Bucket
|
sessionLimiter *ratelimit.Bucket
|
||||||
globalLimiter *ratelimit.Bucket
|
globalLimiter *ratelimit.Bucket
|
||||||
|
|
||||||
|
statusAddr string
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@ -47,6 +49,7 @@ func main() {
|
|||||||
flag.IntVar(&sessionLimitBps, "per-session-rate", sessionLimitBps, "Per session rate limit, in bytes/s")
|
flag.IntVar(&sessionLimitBps, "per-session-rate", sessionLimitBps, "Per session rate limit, in bytes/s")
|
||||||
flag.IntVar(&globalLimitBps, "global-rate", globalLimitBps, "Global rate limit, in bytes/s")
|
flag.IntVar(&globalLimitBps, "global-rate", globalLimitBps, "Global rate limit, in bytes/s")
|
||||||
flag.BoolVar(&debug, "debug", false, "Enable debug output")
|
flag.BoolVar(&debug, "debug", false, "Enable debug output")
|
||||||
|
flag.StringVar(&statusAddr, "status-srv", ":22070", "Listen address for status service (blank to disable)")
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
@ -99,5 +102,9 @@ func main() {
|
|||||||
|
|
||||||
go sessionListener(listenSession)
|
go sessionListener(listenSession)
|
||||||
|
|
||||||
|
if statusAddr != "" {
|
||||||
|
go statusService(statusAddr)
|
||||||
|
}
|
||||||
|
|
||||||
protocolListener(listenProtocol, tlsCfg)
|
protocolListener(listenProtocol, tlsCfg)
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"sync"
|
"sync"
|
||||||
|
"sync/atomic"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/juju/ratelimit"
|
"github.com/juju/ratelimit"
|
||||||
@ -18,8 +19,10 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
sessionMut = sync.Mutex{}
|
sessionMut = sync.Mutex{}
|
||||||
sessions = make(map[string]*session, 0)
|
sessions = make(map[string]*session, 0)
|
||||||
|
numProxies int64
|
||||||
|
bytesProxied int64
|
||||||
)
|
)
|
||||||
|
|
||||||
type session struct {
|
type session struct {
|
||||||
@ -178,6 +181,9 @@ func (s *session) proxy(c1, c2 net.Conn) error {
|
|||||||
log.Println("Proxy", c1.RemoteAddr(), "->", c2.RemoteAddr())
|
log.Println("Proxy", c1.RemoteAddr(), "->", c2.RemoteAddr())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
atomic.AddInt64(&numProxies, 1)
|
||||||
|
defer atomic.AddInt64(&numProxies, -1)
|
||||||
|
|
||||||
buf := make([]byte, 65536)
|
buf := make([]byte, 65536)
|
||||||
for {
|
for {
|
||||||
c1.SetReadDeadline(time.Now().Add(networkTimeout))
|
c1.SetReadDeadline(time.Now().Add(networkTimeout))
|
||||||
@ -186,6 +192,8 @@ func (s *session) proxy(c1, c2 net.Conn) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
atomic.AddInt64(&bytesProxied, int64(n))
|
||||||
|
|
||||||
if debug {
|
if debug {
|
||||||
log.Printf("%d bytes from %s to %s", n, c1.RemoteAddr(), c2.RemoteAddr())
|
log.Printf("%d bytes from %s to %s", n, c1.RemoteAddr(), c2.RemoteAddr())
|
||||||
}
|
}
|
||||||
|
39
cmd/relaysrv/status.go
Normal file
39
cmd/relaysrv/status.go
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"runtime"
|
||||||
|
"sync/atomic"
|
||||||
|
)
|
||||||
|
|
||||||
|
func statusService(addr string) {
|
||||||
|
http.HandleFunc("/status", getStatus)
|
||||||
|
if err := http.ListenAndServe(addr, nil); err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func getStatus(w http.ResponseWriter, r *http.Request) {
|
||||||
|
status := make(map[string]interface{})
|
||||||
|
|
||||||
|
sessionMut.Lock()
|
||||||
|
status["numSessions"] = len(sessions)
|
||||||
|
sessionMut.Unlock()
|
||||||
|
status["numProxies"] = atomic.LoadInt64(&numProxies)
|
||||||
|
status["bytesProxied"] = atomic.LoadInt64(&bytesProxied)
|
||||||
|
status["goVersion"] = runtime.Version()
|
||||||
|
status["goOS"] = runtime.GOOS
|
||||||
|
status["goAarch"] = runtime.GOARCH
|
||||||
|
status["goMaxProcs"] = runtime.GOMAXPROCS(-1)
|
||||||
|
|
||||||
|
bs, err := json.MarshalIndent(status, "", " ")
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
w.Header().Set("Content-Type", "application/json")
|
||||||
|
w.Write(bs)
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user