|
- /*
-
- Copyright (c) [2023] [pcm]
- [pcm-coordinator] is licensed under Mulan PSL v2.
- You can use this software according to the terms and conditions of the Mulan PSL v2.
- You may obtain a copy of Mulan PSL v2 at:
- http://license.coscl.org.cn/MulanPSL2
- THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
- EITHER EXPaRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
- MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
- See the Mulan PSL v2 for more details.
-
- */
-
- package core
-
- import (
- "context"
- "fmt"
- "strconv"
-
- "gitlink.org.cn/JointCloud/pcm-coordinator/internal/svc"
- "gitlink.org.cn/JointCloud/pcm-coordinator/internal/types"
-
- "github.com/zeromicro/go-zero/core/logx"
- )
-
- type GetComputilityStatisticsLogic struct {
- logx.Logger
- ctx context.Context
- svcCtx *svc.ServiceContext
- }
-
- func NewGetComputilityStatisticsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetComputilityStatisticsLogic {
- return &GetComputilityStatisticsLogic{
- Logger: logx.WithContext(ctx),
- ctx: ctx,
- svcCtx: svcCtx,
- }
- }
-
- func (l *GetComputilityStatisticsLogic) GetComputilityStatistics() (resp *types.ComputilityStatisticsResp, err error) {
- // todo: add your logic here and delete this line
-
- resp = &types.ComputilityStatisticsResp{}
- var computilityStatistics types.ComputilityStatistics
- var domainSum int64 //所有域的总和
- var AiFlopsNum float64 //所有域的总和
- var K8sFlopsNum float64 //所有域的总和
- var aiClusterSum int64 //所有域的总和
- var hpcClusterSum int64 //所有域的总和
- var PCClusterSum int64 //所有域的总和
- var ClusterSum int64 //所有域的总和
-
- //算力中心总数(计算域):包括所有云算域,智算域,超算域以及鹏城返回的所有域的总和
- sqlStr := "select count(*) as domainSum from `pcm`.domain_resource t where t.connection_state = 3 OR t.domain_source=0"
- tx := l.svcCtx.DbEngin.Raw(sqlStr).Scan(&domainSum)
- if tx.Error != nil {
- logx.Error(err)
- return nil, tx.Error
- }
-
- computilityStatistics.DomainSum = domainSum
-
- //统计集群
- clusterStr := "select count(*) from `joint_domain`.domain_cluster"
- tc := l.svcCtx.DbEngin.Raw(clusterStr).Scan(&ClusterSum)
- if tc.Error != nil {
- logx.Error(err)
- return nil, tc.Error
- }
- //智算算力总和
- aiFlopsStr := "select sum(t.flops) as flopsNum from `pcm`.domain_resource t"
- tf := l.svcCtx.DbEngin.Raw(aiFlopsStr).Scan(&AiFlopsNum)
- if tf.Error != nil {
- logx.Error(err)
- return nil, tf.Error
- }
-
- //云算算力总和 SELECT sum(t.flops) FROM `resources` t
- k8sFlopsStr := "SELECT sum(t.flops) as k8sFlopsNum FROM `joint_domain`.`resources` t"
- tk := l.svcCtx.DbEngin.Raw(k8sFlopsStr).Scan(&K8sFlopsNum)
- if tk.Error != nil {
- logx.Error(err)
- return nil, tk.Error
- }
- value, _ := strconv.ParseFloat(fmt.Sprintf("%.2f", K8sFlopsNum/1000000+AiFlopsNum), 64)
-
- computilityStatistics.TotalComputility = value
-
- //智算集群数
- aiClusterStr := "select count(*) as aiClusterSum from `pcm`.ai_cluster"
- ts := l.svcCtx.DbEngin.Raw(aiClusterStr).Scan(&aiClusterSum)
- if ts.Error != nil {
- logx.Error(err)
- return nil, ts.Error
- }
- //云算集群数
- hpcClusterStr := "select count(*) as hpcClusterSum from `pcm`.hpc_cluster"
- th := l.svcCtx.DbEngin.Raw(hpcClusterStr).Scan(&hpcClusterSum)
- if th.Error != nil {
- logx.Error(err)
- return nil, th.Error
- }
- //鹏城集群数
- PCClusterStr := "select count(*) as PCClusterSum from `pcm`.domain_resource t where t.connection_state = 3 "
- tp := l.svcCtx.DbEngin.Raw(PCClusterStr).Scan(&PCClusterSum)
- if tp.Error != nil {
- logx.Error(err)
- return nil, tp.Error
- }
- computilityStatistics.ClusterNum = ClusterSum + PCClusterSum + hpcClusterSum + aiClusterSum
- resp.ComputilityStatistics = computilityStatistics
- resp.Code = 200
- resp.Msg = "Success"
- return resp, nil
- }
|