From c5b71f451470c3b195e591844a8ce4d57bdd2907 Mon Sep 17 00:00:00 2001 From: aozhiwei Date: Thu, 29 Oct 2020 11:19:42 +0800 Subject: [PATCH] 1 --- httpserver.go | 34 +++++++++++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) diff --git a/httpserver.go b/httpserver.go index f4f58fd..6f4593e 100644 --- a/httpserver.go +++ b/httpserver.go @@ -3,22 +3,46 @@ package f5 import ( "net/http" "sync" + "sync/atomic" "fmt" "q5" ) type HttpServer struct { + totalRequestTimes int64 + okTimes int64 + pageNotFoundTimes int64 + maxHandleTime int64 + handlersMutex sync.RWMutex handlers map[string]func(http.ResponseWriter, *http.Request) } -func (this *HttpServer) Init() *HttpServer { +func (this *HttpServer) Init(serviceName string, logOutputTime int32) *HttpServer { this.handlers = make(map[string]func(http.ResponseWriter, *http.Request)) http.HandleFunc("/webapp/index.php", this.dispatchRequest) this.RegisterHandle("Ops", "selfChecking", func (w http.ResponseWriter,r *http.Request) { w.Write([]byte(`{"errcode":0, "errmsg":"", "health":1, "max_rundelay": 10}`)) }) SysLog().Info("HttpServer.Init") + if logOutputTime > 0 { + Timer().AddRepeatTimer( + logOutputTime, + func (params* q5.XParams) { + params.Sender.SetString(serviceName) + }, + func (params* q5.XParams) { + SysLog().Info("%s maxHandleTime:%d totalRequestTimes:%d okTimes:%d pageNotFoundTimes:%d", + params.Sender.GetString(), + this.maxHandleTime, + this.totalRequestTimes, + this.okTimes, + this.pageNotFoundTimes) + this.maxHandleTime = 0 + this.okTimes = 0 + this.pageNotFoundTimes = 0 + }) + } return this } @@ -32,12 +56,20 @@ func (this *HttpServer) Start(listen_port int32) { } func (this *HttpServer) dispatchRequest(w http.ResponseWriter, r *http.Request) { + atomic.AddInt64(&this.totalRequestTimes, 1) handleName := q5.Request(r, "c").GetString() + "$" + q5.Request(r, "a").GetString() handle := this.getHandle(handleName) if handle != nil { + beginTick := q5.GetTickCount() handle(w, r) + endTick := q5.GetTickCount() + if oldVal := atomic.LoadInt64(&this.maxHandleTime); beginTick - endTick > oldVal { + atomic.CompareAndSwapInt64(&this.maxHandleTime, oldVal, endTick - beginTick) + } + atomic.AddInt64(&this.okTimes, 1) } else { w.Write([]byte(`{"errcode":404, "errmsg":"接口不存在"}`)) + atomic.AddInt64(&this.pageNotFoundTimes, 1) } }