// Copyright 2017 PingCAP, Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // See the License for the specific language governing permissions and // limitations under the License. package server import ( "bytes" "encoding/json" "fmt" "net" "net/http" "net/http/pprof" "net/url" "strings" "github.com/gorilla/mux" "github.com/pingcap/errors" "github.com/pingcap/parser/mysql" "github.com/pingcap/parser/terror" "github.com/pingcap/tidb/kv" "github.com/pingcap/tidb/util/printer" "github.com/prometheus/client_golang/prometheus" log "github.com/sirupsen/logrus" "github.com/tiancaiamao/appdash/traceapp" static "sourcegraph.com/sourcegraph/appdash-data" ) const defaultStatusAddr = ":10080" func (s *Server) startStatusHTTP() { go s.startHTTPServer() } func (s *Server) startHTTPServer() { router := mux.NewRouter() router.HandleFunc("/status", s.handleStatus).Name("Status") // HTTP path for prometheus. router.Handle("/metrics", prometheus.Handler()).Name("Metrics") // HTTP path for dump statistics. router.Handle("/stats/dump/{db}/{table}", s.newStatsHandler()).Name("StatsDump") router.Handle("/settings", settingsHandler{}).Name("Settings") router.Handle("/binlog/recover", binlogRecover{}).Name("BinlogRecover") tikvHandlerTool := s.newTikvHandlerTool() router.Handle("/schema", schemaHandler{tikvHandlerTool}).Name("Schema") router.Handle("/schema/{db}", schemaHandler{tikvHandlerTool}) router.Handle("/schema/{db}/{table}", schemaHandler{tikvHandlerTool}) router.Handle("/tables/{colID}/{colTp}/{colFlag}/{colLen}", valueHandler{}) router.Handle("/ddl/history", ddlHistoryJobHandler{tikvHandlerTool}).Name("DDL_History") router.Handle("/ddl/owner/resign", ddlResignOwnerHandler{tikvHandlerTool.store.(kv.Storage)}).Name("DDL_Owner_Resign") // HTTP path for get server info. router.Handle("/info", serverInfoHandler{tikvHandlerTool}).Name("Info") router.Handle("/info/all", allServerInfoHandler{tikvHandlerTool}).Name("InfoALL") // HTTP path for get db and table info that is related to the tableID. router.Handle("/db-table/{tableID}", dbTableHandler{tikvHandlerTool}) if s.cfg.Store == "tikv" { // HTTP path for tikv. router.Handle("/tables/{db}/{table}/regions", tableHandler{tikvHandlerTool, opTableRegions}) router.Handle("/tables/{db}/{table}/scatter", tableHandler{tikvHandlerTool, opTableScatter}) router.Handle("/tables/{db}/{table}/stop-scatter", tableHandler{tikvHandlerTool, opStopTableScatter}) router.Handle("/tables/{db}/{table}/disk-usage", tableHandler{tikvHandlerTool, opTableDiskUsage}) router.Handle("/regions/meta", regionHandler{tikvHandlerTool}).Name("RegionsMeta") router.Handle("/regions/hot", regionHandler{tikvHandlerTool}).Name("RegionHot") router.Handle("/regions/{regionID}", regionHandler{tikvHandlerTool}) router.Handle("/mvcc/key/{db}/{table}/{handle}", mvccTxnHandler{tikvHandlerTool, opMvccGetByKey}) router.Handle("/mvcc/txn/{startTS}/{db}/{table}", mvccTxnHandler{tikvHandlerTool, opMvccGetByTxn}) router.Handle("/mvcc/hex/{hexKey}", mvccTxnHandler{tikvHandlerTool, opMvccGetByHex}) router.Handle("/mvcc/index/{db}/{table}/{index}/{handle}", mvccTxnHandler{tikvHandlerTool, opMvccGetByIdx}) } addr := fmt.Sprintf(":%d", s.cfg.Status.StatusPort) if s.cfg.Status.StatusPort == 0 { addr = defaultStatusAddr } // HTTP path for web UI. if host, port, err := net.SplitHostPort(addr); err == nil { if host == "" { host = "localhost" } baseURL := &url.URL{ Scheme: "http", Host: fmt.Sprintf("%s:%s", host, port), } router.HandleFunc("/web/trace", traceapp.HandleTiDB).Name("Trace Viewer") sr := router.PathPrefix("/web/trace/").Subrouter() if _, err := traceapp.New(traceapp.NewRouter(sr), baseURL); err != nil { log.Error(err) } router.PathPrefix("/static/").Handler(http.StripPrefix("/static", http.FileServer(static.Data))) } serverMux := http.NewServeMux() serverMux.Handle("/", router) serverMux.HandleFunc("/debug/pprof/", pprof.Index) serverMux.HandleFunc("/debug/pprof/cmdline", pprof.Cmdline) serverMux.HandleFunc("/debug/pprof/profile", pprof.Profile) serverMux.HandleFunc("/debug/pprof/symbol", pprof.Symbol) serverMux.HandleFunc("/debug/pprof/trace", pprof.Trace) var ( err error httpRouterPage bytes.Buffer pathTemplate string ) httpRouterPage.WriteString("
| " + name + " | |
| Debug |