mirror of
https://github.com/supabase/supabase.git
synced 2026-06-22 00:02:50 +08:00
Add a Query Performance page implementation powered by [supamonitor](https://github.com/supabase/supamonitor). [Context](https://linear.app/supabase/project/build-extension-for-supabase-query-insights-df4fb145352c/overview) This looks largely the same as the pg_stat_monitor implementation: <img width="2556" height="960" alt="Screenshot 2026-02-12 at 7 35 47 PM" src="https://github.com/user-attachments/assets/bf37466e-f7af-41f2-b4f2-cf8eb6a8c76f" /> Only available on projects on custom AMI - existing users are unaffected <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **New Features** * Supamonitor-based query performance view: charts, aggregated metrics, date-range controls, and export/download. * Added "Application" column for per-application tracking. * Interactive Supamonitor grid: sorting, filtering, keyboard navigation, selection, retry/error handling. * Automatic per-project Supamonitor detection with toggleable UI integration. * **Bug Fixes** * Chart latency calculation prefers histogram data for more accurate p95. * **Documentation** * Minor blog formatting fix. <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: kemal <hello@kemal.earth> Co-authored-by: Ali Waseem <waseema393@gmail.com>
51 lines
1.4 KiB
TypeScript
51 lines
1.4 KiB
TypeScript
import { useEffect } from 'react'
|
|
|
|
import { WithStatements } from './WithStatements/WithStatements'
|
|
import { WithSupamonitor } from './WithSupamonitor/WithSupamonitor'
|
|
import { useParams } from 'common'
|
|
import { DbQueryHook } from 'hooks/analytics/useDbQuery'
|
|
import { useDatabaseSelectorStateSnapshot } from 'state/database-selector'
|
|
import { PresetHookResult } from '../Reports/Reports.utils'
|
|
|
|
interface QueryPerformanceProps {
|
|
queryHitRate: PresetHookResult
|
|
queryPerformanceQuery: DbQueryHook<any>
|
|
queryMetrics: PresetHookResult
|
|
isSupamonitorEnabled: boolean
|
|
dateRange?: {
|
|
period_start: { date: string; time_period: string }
|
|
period_end: { date: string; time_period: string }
|
|
interval: string
|
|
}
|
|
onDateRangeChange?: (from: string, to: string) => void
|
|
}
|
|
|
|
export const QueryPerformance = ({
|
|
queryHitRate,
|
|
queryPerformanceQuery,
|
|
queryMetrics,
|
|
isSupamonitorEnabled,
|
|
dateRange,
|
|
onDateRangeChange,
|
|
}: QueryPerformanceProps) => {
|
|
const { ref } = useParams()
|
|
const state = useDatabaseSelectorStateSnapshot()
|
|
|
|
useEffect(() => {
|
|
state.setSelectedDatabaseId(ref)
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, [ref])
|
|
|
|
if (isSupamonitorEnabled) {
|
|
return <WithSupamonitor dateRange={dateRange} onDateRangeChange={onDateRangeChange} />
|
|
}
|
|
|
|
return (
|
|
<WithStatements
|
|
queryHitRate={queryHitRate}
|
|
queryPerformanceQuery={queryPerformanceQuery}
|
|
queryMetrics={queryMetrics}
|
|
/>
|
|
)
|
|
}
|