IndexController.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  1. package com.jjt.biz.controller;
  2. import com.jjt.biz.domain.*;
  3. import com.jjt.biz.service.*;
  4. import com.jjt.biz.vo.BizAccessVO;
  5. import com.jjt.biz.vo.BizTypeVO;
  6. import com.jjt.biz.vo.HlScoreVO;
  7. import com.jjt.biz.vo.ScoreVO;
  8. import com.jjt.common.core.controller.BaseController;
  9. import com.jjt.common.core.domain.AjaxResult;
  10. import com.jjt.common.core.page.TableDataInfo;
  11. import com.jjt.common.utils.DateUtils;
  12. import com.jjt.hl.domain.HlScore;
  13. import com.jjt.hl.service.IHlScoreService;
  14. import io.swagger.annotations.Api;
  15. import io.swagger.annotations.ApiOperation;
  16. import io.swagger.annotations.ApiParam;
  17. import org.springframework.jdbc.core.JdbcTemplate;
  18. import org.springframework.web.bind.annotation.*;
  19. import javax.annotation.Resource;
  20. import java.text.DecimalFormat;
  21. import java.time.LocalDate;
  22. import java.time.LocalDateTime;
  23. import java.time.LocalTime;
  24. import java.time.format.DateTimeFormatter;
  25. import java.util.*;
  26. import java.util.stream.Collectors;
  27. /**
  28. * 业务对象Controller
  29. *
  30. * @author jjt
  31. * @date 2024-08-09
  32. */
  33. @Api(tags = "首页")
  34. @RestController
  35. @RequestMapping("/index")
  36. public class IndexController extends BaseController {
  37. @Resource
  38. private IIndexMetricsService imService;
  39. @Resource
  40. private IBizObjMetricsService omService;
  41. @Resource
  42. private IHlScoreService scoreService;
  43. @Resource
  44. private IBizModelService bizModelService;
  45. @Resource
  46. private IBizObjMetricsDataService dataService;
  47. @Resource
  48. private IAlarmRecordService alarmRecordService;
  49. @Resource
  50. private JdbcTemplate jdbcTemplate;
  51. String[] MODEL_NAMES = {"市场服务", "市场出清", "信息发布", "市场合规", "市场结算"};
  52. @ApiOperation("巡检提示")
  53. @GetMapping("/hl/check")
  54. public AjaxResult hlCheck() {
  55. Map<String, Object> result = new HashMap<>(16);
  56. result.put("time", DateUtils.getTime());
  57. result.put("model", 5);
  58. result.put("metrics", new Random().nextInt(200));
  59. result.put("problem", new Random().nextInt(80));
  60. return AjaxResult.success(result);
  61. }
  62. @ApiOperation("当前健康度")
  63. @GetMapping("/hl/curr")
  64. public AjaxResult hlCurr() {
  65. List<HlScoreVO> list = scoreService.selectHlScoreListLast();
  66. // List<Map<String, Object>> result = new ArrayList<>();
  67. // for (int i = 0; i < MODEL_NAMES.length; i++) {
  68. // Map<String, Object> map = new HashMap<>(16);
  69. // map.put("name", MODEL_NAMES[i]);
  70. // Float score = Float.valueOf(new Random().nextInt(50) + 50);
  71. // map.put("score", score);
  72. // result.add(map);
  73. // }
  74. return AjaxResult.success(list);
  75. }
  76. @ApiOperation("应用健康趋势-按月")
  77. @GetMapping("/hl/month/{date}")
  78. public AjaxResult hlMonth(@ApiParam(value = "时间 yyyy-mm", required = true) @PathVariable("date") String date) {
  79. List<Map<String, Object>> result = new ArrayList<>();
  80. int year = Integer.parseInt(date.split("-")[0]);
  81. int month = Integer.parseInt(date.split("-")[1]);
  82. LocalDate localDate = LocalDate.of(year, month, 1);
  83. for (int i = 0; i < MODEL_NAMES.length; i++) {
  84. Map<String, Object> map = new HashMap<>(16);
  85. map.put("name", MODEL_NAMES[i]);
  86. List<String> times = new ArrayList<>();
  87. List<Float> scores = new ArrayList<>();
  88. for (int j = 0; j < localDate.lengthOfMonth(); j++) {
  89. times.add((j + 1) + "");
  90. Float score = Float.valueOf(new Random().nextInt(50) + 50);
  91. scores.add(score);
  92. }
  93. map.put("time", times);
  94. map.put("score", scores);
  95. result.add(map);
  96. }
  97. return success(result);
  98. }
  99. @ApiOperation("应用健康趋势-按天")
  100. @GetMapping("/hl/day/{date}")
  101. public AjaxResult hlDay(@ApiParam(value = "时间(yyyy-mm-dd", required = true) @PathVariable("date") Date date) {
  102. List<Map<String, Object>> result = new ArrayList<>();
  103. HlScore search = new HlScore();
  104. search.setHlType("1");
  105. Map<String, Object> params = new HashMap<>(16);
  106. params.put("beginTime", DateUtils.parseDateToStr("yyyy-MM-dd", date) + " 00:00:00");
  107. params.put("endTime", DateUtils.parseDateToStr("yyyy-MM-dd", date) + " 23:59:59");
  108. search.setParams(params);
  109. List<HlScore> list = scoreService.selectHlScoreList(search);
  110. Map<Long, List<HlScore>> resultMap = list.stream().collect(Collectors.groupingBy(HlScore::getModelId));
  111. for (Long modelId : resultMap.keySet()) {
  112. Map<String, Object> map = new HashMap<>(16);
  113. ScoreVO vo = new ScoreVO();
  114. BizModel model = bizModelService.selectBizModelByModelId(modelId);
  115. map.put("name", model.getModelName());
  116. List<String> times = new ArrayList<>();
  117. List<Float> scores = new ArrayList<>();
  118. List<HlScore> scoreList = resultMap.get(modelId);
  119. scoreList = scoreList.stream().sorted(Comparator.comparing(HlScore::getHlDate)).collect(Collectors.toList());
  120. scoreList.forEach(hs -> {
  121. times.add(DateUtils.parseDateToStr("HH:mm", hs.getHlDate()));
  122. if (hs.getHlScore() != null) {
  123. scores.add(hs.getHlScore().floatValue());
  124. } else {
  125. scores.add(100f);
  126. }
  127. });
  128. map.put("time", times);
  129. map.put("score", scores);
  130. result.add(map);
  131. }
  132. return success(result);
  133. }
  134. @ApiOperation("运行风险预测结果")
  135. @GetMapping("/risk")
  136. public AjaxResult risk() {
  137. String sql = "SELECT b.metrics_name metricsName,c.obj_name objName,'2' status" +
  138. " FROM (SELECT a.obj_id FROM risk_analysis a,risk_model b WHERE a.ANALYSE_TIME = (SELECT MAX(ANALYSE_TIME) FROM risk_analysis) AND a.risk_id=b.risk_id AND b.risk_type!='3' AND result LIKE '%恶化%') a," +
  139. "biz_obj_metrics b,biz_obj c" +
  140. " where a.obj_id = b.obj_metrics_id AND b.obj_id=c.obj_id";
  141. List<Map<String, Object>> list = jdbcTemplate.queryForList(sql);
  142. Map<String, Object> result = new HashMap<>();
  143. result.put("num", list.size());
  144. result.put("data", list);
  145. // List<Map<String, Object>> resul = new ArrayList<>();
  146. // String[] objs = {"出清node1", "出清ecs", "业务应用3", "业务应用4", "业务应用5", "业务应用6", "业务应用7"};
  147. // String[] ms = {"cpu使用率", "慢访问次数", "GC次数", "空间交换", "打开文件数", "交换分区访问"};
  148. // Random random = new Random();
  149. // int x = objs.length * ms.length;
  150. // int xx = x / 2;
  151. // int max = random.nextInt(xx) + 12;
  152. // int num = 0;
  153. // for (int i = 0; i < max; i++) {
  154. // boolean flag = random.nextInt(888) % 2 == 0;
  155. // int mi = random.nextInt(ms.length - 1);
  156. // Map<String, Object> map = new HashMap<>(16);
  157. // String objName = objs[i % 6];
  158. // String metricsName = ms[mi];
  159. // map.put("objName", objName);
  160. // map.put("metricsName", metricsName);
  161. // String status = "1";
  162. //// if (flag) {
  163. // //风险
  164. // num++;
  165. // status = "2";
  166. //// }
  167. // map.put("status", status);
  168. // resul.add(map);
  169. // }
  170. //
  171. // result.put("num", num);
  172. // result.put("data", resul);
  173. return success(result);
  174. }
  175. @ApiOperation("业务访问报错排名")
  176. @GetMapping("/biz/access")
  177. public AjaxResult access() {
  178. List<Map<String, Object>> result = new ArrayList<>();
  179. LocalDateTime endTime = LocalDateTime.now();
  180. LocalDateTime beginTime = LocalDateTime.of(LocalDate.now(), LocalTime.MIN);
  181. String start = beginTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
  182. String end = endTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
  183. List<BizAccessVO> list = alarmRecordService.objAccess(null, start, end);
  184. list.forEach(vo -> {
  185. Map<String, Object> map = new HashMap<>(16);
  186. map.put("name", vo.getModelName());
  187. map.put("total", vo.getAccess());
  188. map.put("error", vo.getNum());
  189. result.add(map);
  190. });
  191. // String[] names = {"市场出清/mysql", "市场出清/redis", "市场出清/user", "市场服务/auth", "市场结算/mysql"};
  192. // Random random = new Random();
  193. // for (int i = 0; i < names.length; i++) {
  194. // Map<String, Object> map = new HashMap<>(16);
  195. // map.put("name", names[i]);
  196. // map.put("total", random.nextInt(500) + 500);
  197. // map.put("error", random.nextInt(20));
  198. // result.add(map);
  199. // }
  200. return success(result);
  201. }
  202. @ApiOperation("组件告警数排名")
  203. @GetMapping("/obj/alarm")
  204. public AjaxResult alarm() {
  205. Map<String, Object> result = new HashMap<>();
  206. LocalDateTime endTime = LocalDateTime.now();
  207. LocalDateTime beginTime = endTime.minusDays(7);
  208. String start = beginTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
  209. String end = endTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
  210. List<BizTypeVO> list = alarmRecordService.listBizObj(null, start, end);
  211. list = list.stream().sorted(Comparator.comparing(BizTypeVO::getNum).reversed()).collect(Collectors.toList());
  212. AlarmRecord q = new AlarmRecord();
  213. q.setAlarmType("1");
  214. List<AlarmRecord> al = alarmRecordService.selectAlarmRecordList(q);
  215. result.put("curr", al.size());
  216. result.put("data", list);
  217. return success(result);
  218. }
  219. @ApiOperation("指标配置列表")
  220. @GetMapping("/ms/config/list")
  221. public AjaxResult configList() {
  222. List<IndexMetrics> list = imService.selectIndexMetricsList(new IndexMetrics());
  223. return AjaxResult.success(list);
  224. }
  225. @ApiOperation("重点指标运行趋势列表")
  226. @GetMapping("/ms/trend")
  227. public AjaxResult msList() {
  228. List<IndexMetrics> list = imService.selectIndexMetricsList(new IndexMetrics());
  229. list.forEach(im -> {
  230. Random r = new Random();
  231. DecimalFormat df = new DecimalFormat("#0.00");
  232. im.setValue(Float.parseFloat(df.format(r.nextFloat() * 100)));
  233. });
  234. return AjaxResult.success(list);
  235. }
  236. @ApiOperation("重点指标运行趋势图")
  237. @GetMapping("/ms/trend/{objMetricsId}")
  238. public AjaxResult msChat(@PathVariable("objMetricsId") Long objMetricsId) {
  239. List<Map<String, Object>> trendList = new ArrayList<>();
  240. LocalDateTime endTime = LocalDateTime.now();
  241. LocalDateTime beginTime = endTime.minusDays(7);
  242. Map<String, Object> params = new HashMap<>(16);
  243. params.put("beginTime", beginTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
  244. params.put("endTime", endTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
  245. BizObjMetricsData q = new BizObjMetricsData();
  246. q.setObjMetricsId(objMetricsId);
  247. q.setParams(params);
  248. List<BizObjMetricsData> list = dataService.selectBizObjMetricsDataList(q);
  249. list.forEach(data -> {
  250. Map<String, Object> map = new HashMap<>(16);
  251. map.put("time", data.getCreateTime());
  252. map.put("value", data.getdValue().floatValue());
  253. trendList.add(map);
  254. });
  255. // LocalDateTime ed = LocalDateTime.now();
  256. // LocalDateTime st = ed.minusDays(8);
  257. // Random r = new Random();
  258. // DecimalFormat df = new DecimalFormat("#0.00");
  259. // do {
  260. // Map<String, Object> map = new HashMap<>(16);
  261. // long time = st.toEpochSecond(ZoneOffset.ofHours(8)) * 1000;
  262. // map.put("time", time);
  263. // float f = r.nextFloat() * 100;
  264. // map.put("value", Float.parseFloat(df.format(f)));
  265. // st = st.plusDays(1);
  266. // trendList.add(map);
  267. // } while (!st.isAfter(ed));
  268. return AjaxResult.success(trendList);
  269. }
  270. @ApiOperation("指标配置--选择指标列表")
  271. @GetMapping("/ms/config/select")
  272. public TableDataInfo list(BizObjMetrics bizObjMetrics) {
  273. startPage();
  274. List<BizObjMetrics> list = omService.selectBizObjMetricsList(bizObjMetrics);
  275. return getDataTable(list);
  276. }
  277. @ApiOperation("指标配置--添加指标")
  278. @GetMapping("/ms/config/add")
  279. public AjaxResult selectAdd(@ApiParam(value = "指标ID数组", required = true) Long[] ids) {
  280. for (int i = 0; i < ids.length; i++) {
  281. Long id = ids[i];
  282. IndexMetrics im = new IndexMetrics();
  283. im.setObjMetricsId(id);
  284. List list = imService.selectIndexMetricsList(im);
  285. if (list.size() == 0) {
  286. BizObjMetrics bom = omService.selectBizObjMetricsByObjMetricsId(id);
  287. im.setObjId(bom.getObjId());
  288. im.setObjName(bom.getObjName());
  289. im.setMetricsId(bom.getMetricsId());
  290. im.setMetricsName(bom.getMetricsName());
  291. imService.insertIndexMetrics(im);
  292. }
  293. }
  294. return AjaxResult.success();
  295. }
  296. @ApiOperation("指标配置--删除指标")
  297. @DeleteMapping("/ms/config/del/{imIds}")
  298. public AjaxResult configDel(@ApiParam(value = "指标imId", required = true) @PathVariable Long[] imIds) {
  299. return AjaxResult.success(imService.deleteIndexMetricsByImIds(imIds));
  300. }
  301. }