<!DOCTYPE html>
|
<html>
|
<head>
|
<div th:replace="common/header.html"></div>
|
|
|
</head>
|
<body th:class="${application.sidebarCollapse}">
|
<div th:replace="common/chart.html"></div>
|
|
<div class="wrapper">
|
|
<div th:replace="common/navbar.html"></div>
|
|
<div th:replace="common/aside.html"></div>
|
|
<!-- Content Wrapper. Contains page content -->
|
<div class="content-wrapper" style="font-size:0.90rem">
|
<!-- Content Header (Page header) -->
|
<section class="content-header" style="height:38px">
|
<div class="container-fluid">
|
<div class="row mb-2" style="margin-top: -7px;">
|
<div class="col-sm-6"></div>
|
<div class="col-sm-6">
|
<ol class="breadcrumb float-sm-right">
|
<li class="breadcrumb-item"><a href="javascript:history.back()">返回上级</a></li>
|
</ol>
|
</div>
|
</div>
|
</div><!-- /.container-fluid -->
|
</section>
|
|
<!-- Main content -->
|
<section class="content">
|
<div class="container-fluid">
|
<div class="row">
|
|
<div class="col-md-12">
|
<div class="card">
|
<div class="card-header">
|
<h3 class="card-title"><i class="fas fa-star nav-icon"></i> 自定义监控项列表</h3>
|
<div class=" float-sm-right">
|
<!-- SEARCH FORM -->
|
<form class="form-inline ml-3" th:action="@{'/customInfo/list'}">
|
<button type="button" onclick="searchByOnline('')" class="btn btn-primary btn-sm" style="margin-right:5px;">全部</button>
|
<button type="button" onclick="searchByOnline('1')" class="btn btn-success btn-sm" style="margin-right:5px;">正常</button>
|
<button type="button" onclick="searchByOnline('2')" class="btn bg-danger btn-sm" style="margin-right:5px;">失败</button>
|
<th:block th:if="${session.LOGIN_KEY.role != 'guest'}">
|
<button type="button" onclick="delChecks('/customInfo/del')" class="btn bg-danger btn-sm" style="margin-right:5px;">删除</button>
|
<th:block th:if="${application.hostGroup == 'true'}"><button type="button" th:onclick="showSetGroupId()" class="btn btn-primary btn-sm" style="margin-right:5px;">设置分组</button></th:block>
|
<button type="button" onclick="add()" class="btn btn-primary btn-sm" style="margin-right:5px;">添加</button>
|
</th:block>
|
<div class="input-group input-group-sm" th:if="${application.hostGroup == 'true'}"><select style="width:150px;margin-right:5px;" class="form-control" onchange="searchByGroupId()" name="groupId" id="groupId">
|
<option value="">选择分组</option>
|
<th:block th:each="item,iterStat : ${hostGroupList}">
|
<option th:value="${item.id}" th:text="${item.groupName}">Alabama</option>
|
</th:block>
|
</select></div>
|
<div th:replace="common/accountSelect.html"></div>
|
<div class="input-group input-group-sm">
|
<input class="form-control" id="hostname" name="hostname" autocomplete="off" th:value="${customInfo.hostname}" type="text" placeholder="输入ip或进程名称">
|
<div class="input-group-append">
|
<button class="btn btn-primary" type="submit">
|
<i class="fas fa-search"></i>
|
</button>
|
</div>
|
|
</div>
|
</form>
|
|
</div>
|
</div>
|
<!-- /.card-header -->
|
<div class="card-body">
|
<table class="table table-bordered table-hover">
|
<thead>
|
<tr>
|
<th style="width: 20px"> <input type="checkbox" value="" name="checkall" id="checkall"></th>
|
<th style="width: 60px">序号</th>
|
<th:block th:if="${customInfo.orderBy == 'HOST_NAME'}">
|
<th:block th:if="${customInfo.orderType == 'ASC'}">
|
<th style="cursor:pointer" onclick="searchByOrder('HOST_NAME','DESC')">IP<small class="text-success mr-1 float-right"><i class="fas fa-arrow-up" style="vertical-align:bottom;"></i> </small>
|
</th:block>
|
<th:block th:if="${customInfo.orderType == 'DESC'}">
|
<th style="cursor:pointer" onclick="searchByOrder('HOST_NAME','ASC')">IP<small class="text-success mr-1 float-right"><i class="fas fa-arrow-down" style="color: #dc3545!important;vertical-align:bottom;"></i> </small>
|
</th:block>
|
</th:block>
|
<th:block th:if="${customInfo.orderBy ne 'HOST_NAME'}">
|
<th style="cursor:pointer" onclick="searchByOrder('HOST_NAME','ASC')">IP<small class="text-success mr-1 float-right"><i class="fas fa-arrow-up" style="vertical-align:bottom;"></i><i class="fas fa-arrow-down" style="color: #dc3545!important;vertical-align:bottom;"></i></small>
|
</th:block>
|
</th>
|
|
<th>监控项名称</th>
|
<th>监控项指令</th>
|
<th>告警表达式</th>
|
<th>结果值</th>
|
<th>监控项状态</th>
|
<th>监控状态</th>
|
<th th:if="${application.showWarnCount == 'true'}" title="累积告警次数">告警次数</th>
|
<th data-trigger="hover" data-container="body" data-toggle="popover" data-placement="right" data-content="若已下线,显示最后在线时间,但监控仍在继续">更新时间</th>
|
<th th:if="${application.hostGroup == 'true'}">分组</th>
|
<th th:if="${application.userInfoManage == 'true' && session.LOGIN_KEY.role == 'admin'}">账号</th>
|
<th>操作</th>
|
</tr>
|
</thead>
|
<tbody>
|
<th:block th:each="item,iterStat : ${page.list}">
|
<tr>
|
<td><input type="checkbox" th:value="${item.id}" name="todo2" th:id="${item.id}+'_check'"/></td>
|
<td th:text="${iterStat.index+1}">1</td>
|
<td th:text="${item.hostname}">Update software</td>
|
<td th:text="${item.customName}"></td>
|
<td><code data-trigger="hover" data-container="body" data-toggle="popover" data-placement="top" th:data-content="${item.customShell}" class="highlighter-rouge" style="font-size:100%" th:text="${#strings.abbreviate(item.customShell,50)}">result</code></td>
|
<td><code data-trigger="hover" data-container="body" data-toggle="popover" data-placement="top" th:data-content="${item.resultExp}" class="highlighter-rouge" style="font-size:100%" th:text="${#strings.abbreviate(item.resultExp,50)}">result</code></td>
|
<td th:text="${item.customValue}"></td>
|
<td>
|
<th:block th:if="${item.state == '2'}">
|
<span data-trigger="hover" data-container="body" data-toggle="popover" data-placement="top" data-content="主机已下线或告警表达式成立" class="badge bg-danger">失败</span>
|
</th:block>
|
<th:block th:if="${item.state == '1'}">
|
<span class="badge bg-primary" >正常</span>
|
</th:block>
|
</td>
|
<td>
|
<th:block th:if="${item.active == '1'}">
|
<span class="badge bg-primary">监控中</span>
|
</th:block>
|
<th:block th:if="${item.active != '1'}">
|
<span class="badge bg-danger">已停止</span>
|
</th:block>
|
</td>
|
<td th:if="${application.showWarnCount == 'true'}"><span style="cursor:pointer;color:#007bff;font-weight:bold" th:onclick="goHrefLogInfo([[${item.warnQueryWd}]])" th:text="${item.warnCount}"></span></td>
|
<td th:text="${#dates.format(item.createTime,'yyyy-MM-dd HH:mm:ss')}">Update software</td>
|
<td th:text="${item.groupId}" th:if="${application.hostGroup == 'true'}"></td>
|
<th th:text="${item.account}" th:if="${application.userInfoManage == 'true' && session.LOGIN_KEY.role == 'admin'}"></th>
|
<td>
|
<th:block th:if="${session.LOGIN_KEY.role != 'guest'}">
|
<button type="button" th:onclick="edit([[${item.id}]])" class="btn bg-gradient-primary btn-sm">编辑</button>
|
<button type="button" th:onclick="del([[${item.id}]])" class="btn bg-gradient-danger btn-sm">删除</button>
|
</th:block>
|
<button type="button" th:onclick="view([[${item.id}]])" class="btn bg-gradient-primary btn-sm">图表</button></td>
|
</tr>
|
</th:block>
|
|
</tbody>
|
</table>
|
</div>
|
<!-- /.card-body -->
|
<div th:replace="common/page.html"></div>
|
</div>
|
<!-- /.card -->
|
|
|
</div>
|
|
</div>
|
</div>
|
</section>
|
</div>
|
|
<div class="modal fade" id="modal-default3">
|
<div class="modal-dialog">
|
<form method="post" id="form4" th:action="@{'/customInfo/saveGroupId'}">
|
<div class="modal-content" style="font-size:0.90rem">
|
<div class="modal-header">
|
<h4 class="modal-title">设置分组<span class="text-muted">(在系统管理中维护分组)</span></h4>
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
<span aria-hidden="true">×</span>
|
</button>
|
</div>
|
<div class="modal-body">
|
<p>
|
<input type="hidden" id="id3" name="ids"/>
|
<select style="width:200px" class="form-control" name="groupId">
|
<th:block th:each="item,iterStat : ${hostGroupList}">
|
<option th:value="${item.id}" th:text="${item.groupName}">Alabama</option>
|
</th:block>
|
</select>
|
</p>
|
</div>
|
<div class="modal-footer justify-content-between">
|
<button type="button" class="btn btn-default btn-sm" data-dismiss="modal">关闭</button>
|
<button type="button" onclick="ajaxSaveGroupId()" class="btn btn-primary btn-sm">保存</button>
|
</div>
|
</div>
|
</form>
|
<!-- /.modal-content -->
|
</div>
|
<!-- /.modal-dialog -->
|
</div>
|
|
<div th:replace="common/footer.html"></div>
|
<script th:src="@{'/static/js/jQuery/jquery.form.min.js'}" type="text/javascript" charset="utf-8"></script>
|
|
</div>
|
<!-- ./wrapper -->
|
|
<script th:src="@{'/static/js/customInfo.js?v=3.4.1'}"></script>
|
|
<script th:inline="javascript">
|
$(document).ready(function(){
|
$("#groupId").val([[${customInfo.groupId}]]);
|
$("#account").val([[${customInfo.account}]]);
|
});
|
var msg = [[${msg}]];
|
if(msg!='' && msg!=null){
|
toastr.info(msg);
|
}
|
</script>
|
|
</body>
|
</html>
|