-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Top n queries query details page (#9)
* Added query-details page Signed-off-by: Emily Guo <[email protected]> * Include dependences in package.json Signed-off-by: Emily Guo <[email protected]> * Fixed double config function Signed-off-by: Emily Guo <[email protected]> --------- Signed-off-by: Emily Guo <[email protected]> Signed-off-by: Emily Guo <[email protected]>
- Loading branch information
1 parent
405f5e7
commit 8a9e342
Showing
5 changed files
with
236 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
import React from 'react'; | ||
import { EuiFlexGrid, EuiFlexItem, EuiHorizontalRule, EuiPanel, EuiText } from '@elastic/eui'; | ||
|
||
const QuerySummary = ({ query }: { query: any }) => { | ||
const convertTime = (unixTime: number) => { | ||
const date = new Date(unixTime); | ||
const loc = date.toDateString().split(' '); | ||
return `${loc[1]} ${loc[2]}, ${loc[3]} @ ${date.toLocaleTimeString('en-US')}`; | ||
}; | ||
return ( | ||
<EuiPanel> | ||
<EuiText size="xs"> | ||
<h2>Summary</h2> | ||
</EuiText> | ||
<EuiHorizontalRule margin="m" /> | ||
<EuiFlexGrid columns={4}> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Timestamp</h4> | ||
</EuiText> | ||
<EuiText size="xs">{convertTime(query.timestamp)}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Latency</h4> | ||
</EuiText> | ||
<EuiText size="xs">{`${query.latency} ms`}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>CPU Usage</h4> | ||
</EuiText> | ||
<EuiText size="xs">{`${query.cpu} ns`}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Memory</h4> | ||
</EuiText> | ||
<EuiText size="xs">{`${query.memory} B`}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Indexes</h4> | ||
</EuiText> | ||
<EuiText size="xs">{query.indices.toString()}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Search type</h4> | ||
</EuiText> | ||
<EuiText size="xs">{query.search_type.replaceAll('_', ' ')}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Coordinator node ID</h4> | ||
</EuiText> | ||
<EuiText size="xs">{query.node_id}</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h4>Total shards</h4> | ||
</EuiText> | ||
<EuiText size="xs">{query.total_shards}</EuiText> | ||
</EuiFlexItem> | ||
</EuiFlexGrid> | ||
</EuiPanel> | ||
); | ||
}; | ||
|
||
// eslint-disable-next-line import/no-default-export | ||
export default QuerySummary; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,148 @@ | ||
import React, { useEffect } from 'react'; | ||
import Plotly from 'plotly.js-dist'; | ||
import { | ||
EuiButton, | ||
EuiCodeBlock, | ||
EuiFlexGrid, | ||
EuiFlexGroup, | ||
EuiFlexItem, | ||
EuiHorizontalRule, | ||
EuiPanel, | ||
EuiSpacer, | ||
EuiText, | ||
EuiTitle, | ||
} from '@elastic/eui'; | ||
import hash from 'object-hash'; | ||
import { useParams, useHistory, useLocation } from 'react-router-dom'; | ||
import { CoreStart } from '../../../../../src/core/public'; | ||
import QuerySummary from './Components/QuerySummary'; | ||
import { QUERY_INSIGHTS } from '../TopNQueries/TopNQueries'; | ||
|
||
const QueryDetails = ({ queries, core }: { queries: any; core: CoreStart }) => { | ||
const { hashedQuery } = useParams<{ hashedQuery: string }>(); | ||
const query = queries.find((q: any) => hash(q) === hashedQuery); | ||
|
||
const convertTime = (unixTime: number) => { | ||
const date = new Date(unixTime); | ||
const loc = date.toDateString().split(' '); | ||
return loc[1] + ' ' + loc[2] + ', ' + loc[3] + ' @ ' + date.toLocaleTimeString('en-US'); | ||
}; | ||
|
||
const history = useHistory(); | ||
const location = useLocation(); | ||
|
||
useEffect(() => { | ||
core.chrome.setBreadcrumbs([ | ||
{ | ||
text: 'Query insights', | ||
href: QUERY_INSIGHTS, | ||
onClick: (e) => { | ||
e.preventDefault(); | ||
history.push(QUERY_INSIGHTS); | ||
}, | ||
}, | ||
{ text: `Query details: ${convertTime(query.timestamp)}` }, | ||
]); | ||
}, [core.chrome, history, location, query.timestamp]); | ||
|
||
useEffect(() => { | ||
let x: number[] = Object.values(query.phase_latency_map); | ||
if (x.length < 3) { | ||
x = [0, 0, 0]; | ||
} | ||
const data = [ | ||
{ | ||
x: x.reverse(), | ||
y: ['Fetch ', 'Query ', 'Expand '], | ||
type: 'bar', | ||
orientation: 'h', | ||
width: 0.5, | ||
marker: { color: ['#F990C0', '#1BA9F5', '#7DE2D1'] }, | ||
base: [x[2] + x[1], x[2], 0], | ||
text: x.map((value) => `${value}ms`), | ||
textposition: 'outside', | ||
cliponaxis: false, | ||
}, | ||
]; | ||
const layout = { | ||
autosize: true, | ||
margin: { l: 80, r: 80, t: 25, b: 15, pad: 0 }, | ||
autorange: true, | ||
height: 120, | ||
xaxis: { | ||
side: 'top', | ||
zeroline: false, | ||
ticksuffix: 'ms', | ||
autorangeoptions: { clipmin: 0 }, | ||
tickfont: { color: '#535966' }, | ||
linecolor: '#D4DAE5', | ||
gridcolor: '#D4DAE5', | ||
}, | ||
yaxis: { linecolor: '#D4DAE5' }, | ||
}; | ||
const config = { responsive: true }; | ||
Plotly.newPlot('latency', data, layout, config); | ||
}, [query]); | ||
|
||
const queryString = JSON.stringify(JSON.parse(JSON.stringify(query.source)), null, 2); | ||
const queryDisplay = `{\n "query": ${queryString ? queryString.replace(/\n/g, '\n ') : ''}\n}`; | ||
|
||
return ( | ||
<div> | ||
<EuiTitle size="l"> | ||
<h1>Query details</h1> | ||
</EuiTitle> | ||
<EuiSpacer size="l" /> | ||
<EuiFlexItem> | ||
<QuerySummary query={query} /> | ||
<EuiSpacer size="m" /> | ||
<EuiFlexGrid columns={2}> | ||
<EuiFlexItem grow={1}> | ||
<EuiPanel> | ||
<EuiFlexGroup alignItems="center" justifyContent="spaceBetween"> | ||
<EuiFlexItem> | ||
<EuiText size="xs"> | ||
<h2>Query</h2> | ||
</EuiText> | ||
</EuiFlexItem> | ||
<EuiFlexItem grow={false}> | ||
<EuiButton | ||
iconSide="right" | ||
iconType="popout" | ||
target="_blank" | ||
href="https://playground.opensearch.org/app/searchRelevance#/" | ||
> | ||
Open in search comparision | ||
</EuiButton> | ||
</EuiFlexItem> | ||
</EuiFlexGroup> | ||
<EuiHorizontalRule margin="xs" /> | ||
<EuiSpacer size="xs" /> | ||
<EuiCodeBlock | ||
language="jsx" | ||
paddingSize="m" | ||
fontSize="s" | ||
overflowHeight={600} | ||
isCopyable | ||
> | ||
{queryDisplay} | ||
</EuiCodeBlock> | ||
</EuiPanel> | ||
</EuiFlexItem> | ||
<EuiFlexItem grow={1} style={{ alignSelf: 'start' }}> | ||
<EuiPanel> | ||
<EuiText size="xs"> | ||
<h2>Latency</h2> | ||
</EuiText> | ||
<EuiHorizontalRule margin="m" /> | ||
<div id="latency" /> | ||
</EuiPanel> | ||
</EuiFlexItem> | ||
</EuiFlexGrid> | ||
</EuiFlexItem> | ||
</div> | ||
); | ||
}; | ||
|
||
// eslint-disable-next-line import/no-default-export | ||
export default QueryDetails; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters