123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- package service
- import (
- "context"
- "encoding/json"
- "net/http"
- "go-common/app/admin/ep/melloi/model"
- "go-common/library/ecode"
- "go-common/library/log"
- )
- //AddJob add perf job
- func (s *Service) AddJob(c context.Context, job model.Job) (firstRetMap *model.PaasJobResponse, err error) {
- var (
- token string
- clusterMap *model.PaasJobResponse
- JSON []byte
- )
- if JSON, err = json.Marshal(job); err != nil {
- log.Error("json.Marshal err: (%v)", err)
- return
- }
- log.Info("JOBINFO: (%s)", string(JSON))
- if token, err = s.RmToken(c); err != nil {
- log.Error("token err :(%v)", err)
- return
- }
- // 调度逻辑:先从ptest_job 表里面查看
- log.Info("创建job的 token:(%s) ", token)
- if clusterMap, err = s.dao.AddJob(c, token, &job); err != nil {
- log.Error("s.dao.AddJob err :(%v)", err)
- return
- }
- if clusterMap == nil {
- return
- }
- firstRetMap = clusterMap
- return
- }
- //DeleteJob force stop perf job
- func (s *Service) DeleteJob(c context.Context, name string) (firstRetMap *model.PaasJobResponse, err error) {
- var token string
- if token, err = s.RmToken(c); err != nil {
- return
- }
- log.Info("开始执行删除容器的 dao 层******* ")
- if firstRetMap, err = s.dao.DeleteJob(c, token, name); err != nil {
- err = ecode.MelloiPaasRequestErr
- return
- }
- return
- }
- // CleanJob clean None running job
- func (s *Service) CleanJob(c context.Context) (err error) {
- var dockers = []*model.CleanableDocker{}
- if dockers, err = s.dao.QueryCleanableDocker(c); err != nil {
- log.Error("s.job query docker error(%v)", err)
- return
- }
- for _, docker := range dockers {
- if _, err := s.DeleteJob(c, docker.Name); err != nil {
- continue
- }
- }
- return
- }
- // QueryCleanableDocker query clearable Docker
- func (s *Service) QueryCleanableDocker(c context.Context) (dockers []*model.CleanableDocker, err error) {
- return s.dao.QueryCleanableDocker(c)
- }
- //DeleteJobBatch force stop perf job batch
- func (s *Service) DeleteJobBatch(c context.Context, JobBatch model.JobBatch) (status string) {
- for _, reportSuID := range JobBatch.ReportSuIDs {
- go s.QueryOrStopAllPtestByJobName(context.TODO(), reportSuID, true, 3)
- }
- status = "success"
- return
- }
- //QueryJobCPU query job cpu
- func (s *Service) QueryJobCPU(c context.Context, jobNamed string) (responseBody *model.PaasQueryJobCPUResult, err error) {
- var token string
- if token, err = s.RmToken(c); err != nil {
- return
- }
- log.Info("执行查询容器实时cpu 接口 ")
- if responseBody, err = s.dao.QueryJobCPU(c, token, jobNamed); err != nil {
- log.Error("query job cpu err (%v)", err)
- err = ecode.MelloiPaasRequestErr
- return
- }
- return
- }
- //QueryJobCPUByEP query job cpu
- func (s *Service) QueryJobCPUByEP(c context.Context, id, hostIP string) (dockerStats *model.DockerStats, err error) {
- if dockerStats, err = s.dao.QueryJobCPUByEP(c, id, hostIP); err != nil {
- log.Error("query QueryJobCpuByEP err (%v)", err)
- return
- }
- return
- }
- //Job get job info
- func (s *Service) Job(c context.Context, name string) (firstRetMap *model.PaasJobQueryStatus, err error) {
- var token string
- if token, err = s.RmToken(c); err != nil {
- err = ecode.MelloiPaasRequestErr
- return
- }
- if firstRetMap, err = s.dao.Job(c, token, name); err != nil {
- err = ecode.MelloiPaasRequestErr
- return
- }
- return
- }
- //ForceDeleteJob Force Delete Job
- func (s *Service) ForceDeleteJob(c context.Context, reportSuId int) (jobList *model.JobInfoList, err error) {
- log.Info("开始执行强制删除容器******* ")
- if jobList, err = s.dao.ForceDeleteJob(reportSuId); err != nil {
- return
- }
- for _, job := range jobList.JobList {
- url := "http://" + job.HostIp + ":8999" + "/ep/docker/remove?job_name=" + job.JobName
- if _, delErr := http.Get(url); delErr != nil {
- //log.Error("强制删除失败,请重试!")
- s.QueryOrStopAllPtestByJobName(c, reportSuId, true, 3)
- return
- }
- }
- if upErr := s.dao.UpdateJobStatus(reportSuId); upErr != nil {
- return
- }
- return
- }
|