seaweedfs/weed/server/volume_server_handlers_ui.go

57 lines
1.5 KiB
Go
Raw Normal View History

2015-03-19 17:39:22 +00:00
package weed_server
import (
"net/http"
"path/filepath"
2015-03-22 19:50:04 +00:00
"time"
2015-03-19 17:39:22 +00:00
2018-10-24 06:59:49 +00:00
"github.com/chrislusf/seaweedfs/weed/pb/volume_server_pb"
2018-05-27 18:52:26 +00:00
ui "github.com/chrislusf/seaweedfs/weed/server/volume_server_ui"
"github.com/chrislusf/seaweedfs/weed/stats"
"github.com/chrislusf/seaweedfs/weed/storage"
"github.com/chrislusf/seaweedfs/weed/util"
2015-03-19 17:39:22 +00:00
)
func (vs *VolumeServer) uiStatusHandler(w http.ResponseWriter, r *http.Request) {
2020-09-20 23:00:01 +00:00
w.Header().Set("Server", "SeaweedFS Volume "+util.VERSION)
2015-03-19 17:39:22 +00:00
infos := make(map[string]interface{})
2015-03-22 19:50:04 +00:00
infos["Up Time"] = time.Now().Sub(startTime).String()
var ds []*volume_server_pb.DiskStatus
2015-03-19 17:39:22 +00:00
for _, loc := range vs.store.Locations {
if dir, e := filepath.Abs(loc.Directory); e == nil {
2020-12-14 08:51:57 +00:00
newDiskStatus := stats.NewDiskStatus(dir)
newDiskStatus.DiskType = loc.GetDiskType()
ds = append(ds, newDiskStatus)
2015-03-19 17:39:22 +00:00
}
}
volumeInfos := vs.store.VolumeInfos()
var normalVolumeInfos, remoteVolumeInfos []*storage.VolumeInfo
for _, vinfo := range volumeInfos {
if vinfo.IsRemote() {
remoteVolumeInfos = append(remoteVolumeInfos, vinfo)
} else {
normalVolumeInfos = append(normalVolumeInfos, vinfo)
}
}
2015-03-19 17:39:22 +00:00
args := struct {
Version string
Masters []string
Volumes interface{}
EcVolumes interface{}
RemoteVolumes interface{}
DiskStatuses interface{}
Stats interface{}
Counters *stats.ServerStats
2015-03-19 17:39:22 +00:00
}{
2020-06-02 07:10:35 +00:00
util.Version(),
vs.SeedMasterNodes,
normalVolumeInfos,
2019-06-05 04:52:37 +00:00
vs.store.EcVolumes(),
remoteVolumeInfos,
2015-03-19 17:39:22 +00:00
ds,
infos,
2015-03-22 19:50:04 +00:00
serverStats,
2015-03-19 17:39:22 +00:00
}
ui.StatusTpl.Execute(w, args)
}