This commit is contained in:
zhangzhiqiang
2023-02-09 19:47:04 +08:00
parent 798c9cb024
commit 8ae9237b45

View File

@@ -3,12 +3,19 @@
<div class="head-container"> <div class="head-container">
<!--工具栏--> <!--工具栏-->
<el-form :inline="true" class="demo-form-inline" label-suffix=":" label-width="90px"> <el-form :inline="true" class="demo-form-inline" label-suffix=":" label-width="90px">
<el-form-item label="日志标签"> <el-form-item label="日志级别">
<el-cascader <el-select
v-model="labelAndValue" v-model="logLevelValue"
:options="labelsOptions" style="width: 100px; height: 35px;top: -5px;"
placeholder="选择标签" placeholder="选择级别"
/> >
<el-option
v-for="item in labelsOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item> </el-form-item>
<el-form-item label="关键字"> <el-form-item label="关键字">
<el-input <el-input
@@ -18,6 +25,34 @@
clearable clearable
/> />
</el-form-item> </el-form-item>
<el-form-item label="链路追踪">
<el-input
v-model="traceId"
size="mini"
placeholder="请输入链路id"
clearable
/>
</el-form-item>
<el-form-item label="SQL日志" prop="filterSql">
<el-switch
v-model="filterSql"
active-color="#409EFF"
inactive-color="#F56C6C"
active-value="1"
inactive-valu="0"
/>
</el-form-item>
<el-form-item label="HTTP日志" prop="isRequest">
<el-switch
v-model="isRequest"
active-color="#409EFF"
inactive-color="#F56C6C"
active-value="1"
inactive-valu="0"
/>
</el-form-item>
<el-form-item v-show="!showOptions" label="时间范围"> <el-form-item v-show="!showOptions" label="时间范围">
<el-date-picker <el-date-picker
v-model="timeRange" v-model="timeRange"
@@ -47,24 +82,6 @@
<span class="el-icon-sort" @click="changeShow" /> <span class="el-icon-sort" @click="changeShow" />
</el-tooltip> </el-tooltip>
</el-form-item> </el-form-item>
<el-form-item label="SQL日志" prop="filterSql">
<el-switch
v-model="filterSql"
active-color="#409EFF"
inactive-color="#F56C6C"
active-value="1"
inactive-valu="0"
/>
</el-form-item>
<el-form-item label="HTTP日志" prop="isRequest">
<el-switch
v-model="isRequest"
active-color="#409EFF"
inactive-color="#F56C6C"
active-value="1"
inactive-valu="0"
/>
</el-form-item>
<el-form-item label="显示条数"> <el-form-item label="显示条数">
<el-input-number <el-input-number
v-model="size" v-model="size"
@@ -117,8 +134,14 @@
<div style="width: 100%"> <div style="width: 100%">
<div v-for="(log, index) in logs" :key="index"> <div v-for="(log, index) in logs" :key="index">
<div> <div>
<span >{{log.system}}</span>
<span style="margin: 5px;">{{log.system}}---{{log.message}}</span> <span style="color: #13ce66">{{log.thread}}</span>
<span style="color: #00afff">{{log.logLevel}}</span>
<span>{{log.requestIp}}</span>
<span style="color: #b4bccc">{{log.requestTime}}</span>
<span style="color: chocolate">{{log.traceId}}</span>
<span style="color: #7a6df0">{{log.requestMethod}}</span>
<span style="margin: 5px;">-----{{log.message}}</span>
</div> </div>
</div> </div>
@@ -136,6 +159,7 @@ let queryParam = {
logLevel: null, logLevel: null,
startTime: null, startTime: null,
endTime: null, endTime: null,
traceId: null,
message: null, message: null,
filterSql: true, filterSql: true,
isRequest: true, isRequest: true,
@@ -146,10 +170,11 @@ export default {
name: 'ES', name: 'ES',
data() { data() {
return { return {
labelAndValue: [], // 搜索的值
labelsOptions: [], // 所有标签和对应所有值数据 labelsOptions: [], // 所有标签和对应所有值数据
logLevelValue: '',
timeRange: [], timeRange: [],
message: '', message: '',
traceId: '',
size: 20, size: 20,
logData: [], logData: [],
filterSql: '1', filterSql: '1',
@@ -222,20 +247,27 @@ export default {
methods: { methods: {
initLabelsValues() { initLabelsValues() {
logOperation.labelsValues().then(res => { logOperation.labelsValues().then(res => {
this.labelsOptions = res this.labelsOptions = res
}) })
}, },
queryData() { queryData() {
// 清空查询数据 // 清空查询数据
this.clearParam() this.clearParam()
queryParam.logLabel = this.labelAndValue[0] queryParam.logLevel = this.logLevelValue
const time = new Date() const time = new Date()
if (this.timeZoneValue !== '') { if (this.timeZoneValue !== '') {
queryParam.endTime = ((time.getTime() - this.timeZoneValue) * 1000000).toString() queryParam.startTime = new Date(((time.getTime() - this.timeZoneValue)))
}
debugger
if (this.timeRange !== '' && this.timeRange.length > 0) {
queryParam.startTime = this.timeRange[0]
queryParam.endTime = this.timeRange[1]
} }
queryParam.message = this.message.replace(/^\s*|\s*$/g, '') queryParam.message = this.message.replace(/^\s*|\s*$/g, '')
queryParam.filterSql = this.filterSql === '1' queryParam.filterSql = this.filterSql === '1'
queryParam.isRequest = this.filterSql === '1' queryParam.isRequest = this.filterSql === '1'
queryParam.traceId = this.traceId
queryParam.size = this.size queryParam.size = this.size
queryParam.page = this.page queryParam.page = this.page
@@ -247,14 +279,17 @@ export default {
this.logs.push(res.records[j]) this.logs.push(res.records[j])
} }
}) })
},
changetype() {
}, },
clearParam() { clearParam() {
queryParam = { queryParam = {
logLabel: null, logLevel: null,
logLabelValue: null,
startTime: null, startTime: null,
endTime: null, endTime: null,
message: null, message: null,
traceId: null,
isRequest: true, isRequest: true,
filterSql: true, filterSql: true,
size: 20 size: 20