|
@@ -758,9 +758,9 @@ func (s *Service) CompareServiceLiveness(ctx context.Context, params *dto.SpanSc
|
|
// err = s.ChOrm.Raw(sql, params.AppAlias, params.ServiceName, startTime.Unix(), endTime.Unix()).Scan(&list).Error
|
|
// err = s.ChOrm.Raw(sql, params.AppAlias, params.ServiceName, startTime.Unix(), endTime.Unix()).Scan(&list).Error
|
|
|
|
|
|
tbl, star, end := cUtils.MetricTableName("service_metrics", startTime, endTime)
|
|
tbl, star, end := cUtils.MetricTableName("service_metrics", startTime, endTime)
|
|
- err = s.PgOrm.Table(tbl).Select("timestamp as start, request_count as total").
|
|
|
|
|
|
+ err = s.PgOrm.Table(tbl).Select("timestamp as start, sum(request_count) as total").
|
|
Where("app_name=? and service_name=?", params.AppAlias, params.ServiceName).
|
|
Where("app_name=? and service_name=?", params.AppAlias, params.ServiceName).
|
|
- Where("timestamp>=? and timestamp<?", star, end).Order("start").Scan(&list).Error
|
|
|
|
|
|
+ Where("timestamp>=? and timestamp<?", star, end).Group("timestamp").Order("start").Scan(&list).Error
|
|
|
|
|
|
// 使用视图效率低,会扫描全表
|
|
// 使用视图效率低,会扫描全表
|
|
// err = s.ChOrm.Model(&models.TracesAggbysvcMerge{}).Debug().
|
|
// err = s.ChOrm.Model(&models.TracesAggbysvcMerge{}).Debug().
|
|
@@ -831,7 +831,8 @@ func (s *Service) CompareServiceErrors(ctx context.Context, params *dto.SpanScat
|
|
tbl, start, end := cUtils.MetricTableName("service_metrics", startTime, endTime)
|
|
tbl, start, end := cUtils.MetricTableName("service_metrics", startTime, endTime)
|
|
err = s.PgOrm.Table(tbl).Where("app_name=? and service_name=?", params.AppAlias, params.ServiceName).
|
|
err = s.PgOrm.Table(tbl).Where("app_name=? and service_name=?", params.AppAlias, params.ServiceName).
|
|
Where("timestamp>=? and timestamp<?", start, end).
|
|
Where("timestamp>=? and timestamp<?", start, end).
|
|
- Select("timestamp as start_time, span_status_error_count as total").
|
|
|
|
|
|
+ Select("timestamp as start_time, sum(span_status_error_count) as total").
|
|
|
|
+ Group("timestamp").
|
|
Order("timestamp ASC").Scan(&list).Error
|
|
Order("timestamp ASC").Scan(&list).Error
|
|
if err != nil {
|
|
if err != nil {
|
|
return
|
|
return
|
|
@@ -1476,7 +1477,7 @@ func (s *Service) List(req *dto.ServiceListReq, resp *[]dto.ServiceListResp, tot
|
|
}
|
|
}
|
|
}
|
|
}
|
|
pageScopes := cDto.Paginate(req.GetPageSize(), req.GetPageIndex())
|
|
pageScopes := cDto.Paginate(req.GetPageSize(), req.GetPageIndex())
|
|
- start, end := time.Unix(req.StartTime, 0).Local(), time.Unix(req.EndTime, 0).Local()
|
|
|
|
|
|
+ // start, end := time.Unix(req.StartTime, 0).Local(), time.Unix(req.EndTime, 0).Local()
|
|
fieldMap := map[string]string{
|
|
fieldMap := map[string]string{
|
|
"total": "sum(request_count)",
|
|
"total": "sum(request_count)",
|
|
"error_num": "sum(span_status_error_count)",
|
|
"error_num": "sum(span_status_error_count)",
|
|
@@ -1494,9 +1495,7 @@ func (s *Service) List(req *dto.ServiceListReq, resp *[]dto.ServiceListResp, tot
|
|
}
|
|
}
|
|
req.SortInfo.Field = fieldMap[req.SortInfo.Field] // 之所以这么写,是因为order by 后跟 total desc不知道为什么报错,提示total不存在,但在直接执行sql是可以的
|
|
req.SortInfo.Field = fieldMap[req.SortInfo.Field] // 之所以这么写,是因为order by 后跟 total desc不知道为什么报错,提示total不存在,但在直接执行sql是可以的
|
|
orderby := req.SortInfo.OrderBy(fieldVals, fieldMap["total"], "desc")
|
|
orderby := req.SortInfo.OrderBy(fieldVals, fieldMap["total"], "desc")
|
|
- fmt.Println(start, end)
|
|
|
|
tbl, start, end := cUtils.MetricTableName("service_metrics", req.StartTime, req.EndTime)
|
|
tbl, start, end := cUtils.MetricTableName("service_metrics", req.StartTime, req.EndTime)
|
|
- fmt.Println(start, end)
|
|
|
|
db := s.PgOrm.Debug().Table(tbl).
|
|
db := s.PgOrm.Debug().Table(tbl).
|
|
Where("app_name=?", appAlias).
|
|
Where("app_name=?", appAlias).
|
|
Where("timestamp>=? and timestamp<?", start, end)
|
|
Where("timestamp>=? and timestamp<?", start, end)
|
|
@@ -1506,7 +1505,7 @@ func (s *Service) List(req *dto.ServiceListReq, resp *[]dto.ServiceListResp, tot
|
|
err := db.Scopes(pageScopes).
|
|
err := db.Scopes(pageScopes).
|
|
Select(
|
|
Select(
|
|
"service_name, " + strings.Join(fields, ", "),
|
|
"service_name, " + strings.Join(fields, ", "),
|
|
- ).Group("service_name").Order(orderby).Scan(resp).Limit(-1).Offset(-1).Count(total).Error
|
|
|
|
|
|
+ ).Group("service_name, timestamp").Order(orderby).Scan(resp).Limit(-1).Offset(-1).Count(total).Error
|
|
if err != nil {
|
|
if err != nil {
|
|
return errors.Wrap(err, "获取服务统计数据失败")
|
|
return errors.Wrap(err, "获取服务统计数据失败")
|
|
}
|
|
}
|