pd/server/api/stats.go

64 lines
2.1 KiB
Go

// Copyright 2017 TiKV Project Authors.
//
// 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,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package api
import (
"net/http"
"github.com/unrolled/render"
"github.com/tikv/pd/pkg/statistics"
"github.com/tikv/pd/server"
)
type statsHandler struct {
svr *server.Server
rd *render.Render
}
func newStatsHandler(svr *server.Server, rd *render.Render) *statsHandler {
return &statsHandler{
svr: svr,
rd: rd,
}
}
// GetRegionStatus gets the region statistics of a specified range.
// @Tags stats
// @Summary Get region statistics of a specified range.
// @Param start_key query string true "Start key"
// @Param end_key query string true "End key"
// @Param count query bool false "Whether only count the number of regions"
// @Param use_hot query bool false "Whether use hot region statistics"
// @Param engine query string false "Engine type"
// @Produce json
// @Success 200 {object} statistics.RegionStats
// @Router /stats/region [get]
func (h *statsHandler) GetRegionStatus(w http.ResponseWriter, r *http.Request) {
rc := getCluster(r)
startKey, endKey := r.URL.Query().Get("start_key"), r.URL.Query().Get("end_key")
var stats *statistics.RegionStats
if r.URL.Query().Has("count") {
stats = rc.GetRegionStatsCount([]byte(startKey), []byte(endKey))
} else if r.URL.Query().Has("use_hot") {
engine := r.URL.Query().Get("engine")
stats = rc.GetHotRegionStatusByRange([]byte(startKey), []byte(endKey), engine)
} else {
stats = rc.GetRegionStatsByRange([]byte(startKey), []byte(endKey))
}
h.rd.JSON(w, http.StatusOK, stats)
}