package rigger
import (
"math/rand"
"net/http"
"ciyon/web/admin"
c "ciyon/zciyon"
)
func statsfunc_setwhere(post *c.CiyPost) (map[string]any, *c.CiySQL) {
query := post.Getobj("query")
csql := c.NewCiySQL("zc_stats")
csql.Where_daterange("addtimes", c.Getstr(query, "addtimes"))
csql.Where_numrange("func_succ", c.Getstr(query, "func_succ_1"), c.Getstr(query, "func_succ_2"), 1)
csql.Where_numrange("func_fail", c.Getstr(query, "func_fail_1"), c.Getstr(query, "func_fail_2"), 1)
csql.Where_numrange("func_rollback", c.Getstr(query, "func_rollback_1"), c.Getstr(query, "func_rollback_2"), 1)
csql.Where_numrange("func_runms", c.Getstr(query, "func_runms_1"), c.Getstr(query, "func_runms_2"), 1)
order := c.Getstr(query, "order", "id desc")
csql.Order(order)
query["order"] = order
return query, csql
}
func Statsfunc_init(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
where, csql := statsfunc_setwhere(post)
pageno := post.Getint("pageno", 1)
pagecount := post.Getint("pagecount", 10)
csql.Limit(pageno, pagecount)
rows, mainrowcount, err := c.CiyDB.Get(csql, post.Getint("count"))
if err != nil {
return c.ErrJSON(w, "读取错误", err)
}
ret := map[string]any{}
ret["where"] = where
ret["pageno"] = pageno
ret["pagecount"] = pagecount
ret["count"] = mainrowcount
ret["list"] = rows
if post.Getbool("field") {
field, fshow := c.CiyDB.GetField(csql)
ret["fshow"] = fshow
ret["field"] = field
}
if post.Getbool("once") {
once := map[string]any{}
input := make([]map[string]any, 0)
input = append(input, map[string]any{
"form": "addtimes",
"type": "daterange",
"name": "记录时间",
})
input = append(input, map[string]any{
"form": "func_succ",
"type": "num",
"name": "成功数",
"prop": ` style="width:4em;"`,
})
input = append(input, map[string]any{
"form": "func_fail",
"type": "num",
"name": "失败数",
"prop": ` style="width:4em;"`,
})
input = append(input, map[string]any{
"form": "func_rollback",
"type": "num",
"name": "回滚数",
"prop": ` style="width:4em;"`,
})
input = append(input, map[string]any{
"form": "func_runms",
"type": "num",
"name": "平均用时",
"prop": ` style="width:4em;"`,
})
once["input"] = input
ret["once"] = once
}
return c.SuccJSON(w, r, ret)
}
func Statsfunc_del(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
if admin.Nopower(c.CiyDB, userid, "p550d") {
return c.ErrJSON(w, "您未被授权操作")
}
ids := post.Get("ids")
if ids == "" {
return c.ErrJSON(w, "请选择至少一条")
}
csql := c.NewCiySQL("zc_stats")
csql.Where("id in", ids)
rows, _, err := c.CiyDB.Get(csql)
if err != nil {
return c.ErrJSON(w, "读取数据错误", err)
}
vids := make([]int, 0)
err = c.CiyDB.Tran(func() error {
for _, row := range rows {
delid := c.Toint(row["id"])
c.Delme(c.CiyDB, delid, "zc_stats")
admin.SaveLogDB(c.CiyDB, "zc_stats", row, nil)
vids = append(vids, delid)
}
return nil
})
if err != nil {
return c.ErrJSON(w, "事务"+err.Error())
}
ret := map[string]any{}
ret["ids"] = vids
return c.SuccJSON(w, r, ret)
}
func Statsfunc_exportxls(w http.ResponseWriter, r *http.Request) bool {
post := c.NewCiyPost(w, r)
_, userid := admin.Verifyfast(r, c.CiyDB, post)
if userid == 0 {
return false
}
if admin.Nopower(c.CiyDB, userid, "p550e") {
return c.ErrJSON(w, "您未被授权操作")
}
_, csql := statsfunc_setwhere(post)
rows, _, err := c.CiyDB.Get(csql)
if err != nil {
return c.ErrJSON(w, "读取错误", err)
}
if len(rows) > 10000 {
return c.ErrJSON(w, "将导出"+c.Tostr(len(rows))+"条,不建议超过1万条,请筛选缩小范围", err)
}
fields := []map[string]string{}
fields = append(fields, map[string]string{"style": "c", "width": "60", "field": "id", "name": "行码"})
fields = append(fields, map[string]string{"style": "c", "width": "100", "field": "addtimes", "name": "记录时间"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "func_succ", "name": "成功数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "func_fail", "name": "失败数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "func_commit", "name": "提交数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "func_rollback", "name": "回滚数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "func_runms", "name": "平均用时"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "disk_sysfree", "name": "磁盘系统剩余空间"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "disk_datafree", "name": "磁盘数据剩余空间"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "disk_ioms", "name": "磁盘IO响应"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "cpu_free", "name": "CPU空闲占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "cpu_db", "name": "CPU数据库占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "cpu_web", "name": "CPU应用占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "cpu_oth", "name": "CPU其他占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "mem_free", "name": "空闲内存"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "mem_db", "name": "数据库内存占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "mem_web", "name": "应用内存占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "mem_oth", "name": "其他内存占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "net_tcp", "name": "网络连接数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "net_ioms", "name": "网络响应"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_query", "name": "数据库查询数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_commit", "name": "数据库提交数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_rollback", "name": "数据库回滚数"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_keyhit", "name": "索引命中率"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_dbhit", "name": "缓存命中率"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_tmptable", "name": "临时表占比"})
fields = append(fields, map[string]string{"style": "r", "width": "100", "field": "db_lock", "name": "当前锁数量"})
datas := [][]string{}
for _, row := range rows {
dat := make([]string, 0)
for _, f := range fields {
field := f["field"]
if val, ok := row[field]; ok {
var str string
if field == "id" {
str = c.EnID(c.Toint(val))
} else if field == "addtimes" {
t := c.Toint(val)
if t <= 0 {
str = "--"
} else {
str = c.Todate(t, "Y-m-d H:i")
}
} else {
str = c.Tostr(val)
}
dat = append(dat, str)
} else {
dat = append(dat, "")
}
}
datas = append(datas, dat)
}
param := map[string]any{}
param["sheetname"] = "数据报表"
param["titleheight"] = "25" //列头高度
param["landscape"] = true //横向打印
param["fixtopage"] = true //打印整个工作表
param["toptitle"] = "系统健康数据报表"
total := []map[string]any{} //单行统计数据
// total = append(total, map[string]any{"style": "l", "name": "合计", "merge": 5})
// total = append(total, map[string]any{"style": "r", "name": "=SUM(R[-" + c.Tostr(len(datas)) + "]C:R[-1]C)"})
// total = append(total, map[string]any{"style": "r", "name": "=MAX(R[-" + c.Tostr(len(datas)) + "]C:R[-1]C)"})
// param["rowstop"] = `| 众产Ciyon |
`
// param["rowsfooter"] = `| 总计 | |
`
str := c.General_excel_xml(fields, datas, param, total)
filename := "/ud/tmp/" + c.Todate(-1, "Ymd_His") + c.Tostr(rand.Intn(8999)+1000) + ".xls"
err = c.FileSave(c.CiyWebDir+filename, str)
if err != nil {
return c.ErrJSON(w, "导出保存文件错误:%v[%v]", err, filename)
}
ret := map[string]any{}
ret["url"] = filename
return c.SuccJSON(w, r, ret)
}