monitor.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml"
  3. xmlns:th="http://www.thymeleaf.org" lang="zh-CN">
  4. <!-- Monitor -->
  5. <div class="container-fluid">
  6. <div class="row">
  7. <form class="form-horizontal" role="form" method="post">
  8. <!-- 应用性能 -->
  9. <div class="col-md-12">
  10. <div class="panel-group">
  11. <div class="panel panel-success">
  12. <div class="panel-heading">
  13. <h4 class="panel-title">
  14. <u data-toggle="collapse" class="dbsyncer_pointer" href="#systemMetrics">应用性能</u>
  15. </h4>
  16. </div>
  17. <div id="systemMetrics" class="panel-body panel-collapse collapse in">
  18. <div class="col-md-7">
  19. <div class="row">
  20. <div class="col-md-4">
  21. <h3><small>总共</small>&nbsp;<span class="label label-info" id="totalSpan">0</span></h3>
  22. </div>
  23. <div class="col-md-4">
  24. <h3><small>成功</small>&nbsp;<span class="label label-success" id="successSpan">0</span></h3>
  25. </div>
  26. <div class="col-md-4">
  27. <h3><small>失败</small>&nbsp;<span class="label label-warning" id="failSpan">0</span></h3>
  28. </div>
  29. </div>
  30. <div class="row">
  31. <div class="col-md-4">
  32. <h3><small>新增</small>&nbsp;<span class="label label-default" id="insertSpan">0</span></h3>
  33. </div>
  34. <div class="col-md-4">
  35. <h3><small>修改</small>&nbsp;<span class="label label-default" id="updateSpan">0</span></h3>
  36. </div>
  37. <div class="col-md-4">
  38. <h3><small>删除</small>&nbsp;<span class="label label-default" id="deleteSpan">0</span></h3>
  39. </div>
  40. </div>
  41. <hr>
  42. <div class="row">
  43. <div class="col-md-4">
  44. <div id="totalChart" style="height: 260px;"></div>
  45. </div>
  46. <div class="col-md-4">
  47. <div id="eventChart" style="height: 260px;"></div>
  48. </div>
  49. <div class="col-md-4">
  50. <div id="queueChart" style="height: 260px;"></div>
  51. </div>
  52. </div>
  53. <div class="row">
  54. <div class="col-md-6">
  55. <div id="cpuChart" style="height: 260px; "></div>
  56. </div>
  57. <div class="col-md-6">
  58. <div id="memoryChart" style="height: 260px;"></div>
  59. </div>
  60. </div>
  61. </div>
  62. <div class="col-md-5">
  63. <div class="row">
  64. <div class="col-md-12">
  65. <table id="metricTable" class="table table-hover">
  66. <tr th:each="m,s : ${metrics}">
  67. <td style="width:5%;" th:text="${s.index}+1"></td>
  68. <td th:text="${'['+ m?.group + '] ' + m?.metricName}"></td>
  69. <td th:text="${m?.detail}"></td>
  70. </tr>
  71. </table>
  72. </div>
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. </div>
  79. <!-- 数据 -->
  80. <div class="col-md-12" th:if="${meta?.size() gt 0}">
  81. <div class="panel-group">
  82. <div class="panel panel-default">
  83. <div class="panel-heading">
  84. <h4 class="panel-title">
  85. <u data-toggle="collapse" class="dbsyncer_pointer" href="#queryDataPanel">查询数据</u>
  86. </h4>
  87. </div>
  88. <div id="queryDataPanel" class="panel-body panel-collapse collapse in">
  89. <div class="form-group">
  90. <div class="col-md-3">
  91. <!-- 驱动下拉 -->
  92. <select id="searchMetaData" class="form-control select-control">
  93. <option th:each="m,s:${meta}" th:value="${m?.id}" th:text="${m?.mappingName} +' (' + ${m?.model} +')'" th:selected="${m?.id eq metaId}"/>
  94. </select>
  95. </div>
  96. <div class="col-md-1">
  97. <!-- 是否包含成功 -->
  98. <select id="searchDataSuccess" class="form-control select-control">
  99. <option th:value="${c?.value}" th:text="${c?.message}" th:each="c,state : ${storageDataStatus}" th:selected="${c?.value eq 0}"/>
  100. </select>
  101. </div>
  102. <div class="col-sm-4">
  103. <input id="searchDataKeyword" class="form-control" type="text" maxlength="32" placeholder="请输入异常关键字(最多32个字)." />
  104. </div>
  105. <div class="col-md-1">
  106. <button id="queryDataBtn" type="button" class="btn btn-primary">查询数据</button>
  107. </div>
  108. <div class="col-md-3 text-right">
  109. <button th:id="${metaId}" type="button" class="btn btn-default clearDataBtn">清空数据</button>
  110. </div>
  111. </div>
  112. <table class="table table-hover metaDataList">
  113. <thead>
  114. <tr>
  115. <th style="width:3%;"></th>
  116. <th style="width:5%;">目标表</th>
  117. <th style="width:5%;">事件</th>
  118. <th style="width:5%;">结果</th>
  119. <th style="width:55%;">异常</th>
  120. <th style="width:17%;">时间</th>
  121. <th style="width:10%;">详情</th>
  122. </tr>
  123. </thead>
  124. <tbody id="dataList">
  125. <tr th:each="d,s : ${pagingData?.data}">
  126. <td th:text="${s.index}+1" />
  127. <td th:text="${d?.targetTableName}" />
  128. <td th:text="${d?.event}" />
  129. <td>
  130. <span th:if="${d?.success == 1}" class="label label-success">成功</span>
  131. <span th:if="${d?.success == 0}" class="label label-warning">失败</span>
  132. </td>
  133. <td style="max-width:100px;" class="dbsyncer_over_hidden"><a href="javascript:;" class="dbsyncer_pointer queryError">[[${d?.error}]]</a></td>
  134. <td th:text="${#dates.format(d?.createTime, 'yyyy-MM-dd HH:mm:ss')}" />
  135. <td>
  136. <a th:json="${d?.json}" href="javascript:;" class="label label-info queryData">查看数据</a>
  137. <a th:if="${d?.success == 0}" th:id="${d?.id}" href="javascript:;" class="label label-warning retryData">重试</a>
  138. <div class="hidden" th:text="${d?.json}"></div>
  139. </td>
  140. </tr>
  141. </tbody>
  142. </table>
  143. <div class="form-group">
  144. <div class="col-md-5">共计: <span id="dataTotal">[[${pagingData?.total}]]</span>条</div>
  145. <div class="col-md-7">
  146. <a href="javascript:void(0);" id="queryDataMore" num="1">显示更多<i class="fa fa-angle-double-down" aria-hidden="true"></i></a>
  147. </div>
  148. </div>
  149. </div>
  150. </div>
  151. </div>
  152. </div>
  153. <!-- 日志 -->
  154. <div class="col-md-12">
  155. <div class="panel-group">
  156. <div class="panel panel-default">
  157. <div class="panel-heading">
  158. <h4 class="panel-title">
  159. <u data-toggle="collapse" class="dbsyncer_pointer" href="#queryLogPanel">查询日志</u>
  160. </h4>
  161. </div>
  162. <div id="queryLogPanel" class="panel-body panel-collapse collapse in">
  163. <div class="form-group">
  164. <div class="col-sm-4">
  165. <input id="searchLogKeyword" class="form-control" type="text" maxlength="32" placeholder="请输入内容关键字(最多32个字)." />
  166. </div>
  167. <div class="col-md-1">
  168. <button id="queryLogBtn" type="button" class="btn btn-primary">查询日志</button>
  169. </div>
  170. <div class="col-md-4"></div>
  171. <div class="col-md-3 text-right">
  172. <button th:id="${metaId}" type="button" class="btn btn-default clearLogBtn">清空日志</button>
  173. </div>
  174. </div>
  175. <table class="table table-hover">
  176. <thead>
  177. <tr>
  178. <th style="width:3%;"></th>
  179. <th style="width:70%;">内容</th>
  180. <th style="width:27%;">时间</th>
  181. </tr>
  182. </thead>
  183. <tbody id="logList">
  184. <tr th:each="l,s : ${pagingLog?.data}">
  185. <td th:text="${s.index}+1"></td>
  186. <td th:text="${l?.json}"></td>
  187. <td th:text="${#dates.format(l?.createTime, 'yyyy-MM-dd HH:mm:ss')}"></td>
  188. </tr>
  189. </tbody>
  190. </table>
  191. <div class="form-group">
  192. <div class="col-md-5">共计: <span id="logTotal">[[${pagingLog?.total}]]</span>条</div>
  193. <div class="col-md-7">
  194. <a href="javascript:void(0);" id="queryLogMore" num="1">显示更多<i class="fa fa-angle-double-down" aria-hidden="true"></i></a>
  195. </div>
  196. </div>
  197. </div>
  198. </div>
  199. </div>
  200. </div>
  201. </form>
  202. </div>
  203. </div>
  204. <script th:src="@{/js/monitor/index.js}"></script>
  205. </html>