mirror of
https://github.com/OneUptime/oneuptime.git
synced 2026-04-06 00:32:12 +02:00
2.0 KiB
2.0 KiB
Clickhouse Ops
To access clickhouse use port forwarding in kubernetes
kubectl port-forward --address 0.0.0.0 service/oneuptime-oneuptime 8123:8123
then you should be able to access from the localhost and port 8123
# Username for Postgres user is `oneuptime`
echo $(kubectl get secret --namespace "default" oneuptime-clickhouse -o jsonpath="{.data.admin-password}" | base64 -d)
Important: Please ignore % in the end of the password output.
Basic Ops Queries
Check Size of Tables in Clickhouse
SELECT
database,
table,
formatReadableSize(sum(data_compressed_bytes) AS size) AS compressed,
formatReadableSize(sum(data_uncompressed_bytes) AS usize) AS uncompressed,
round(usize / size, 2) AS compr_rate,
sum(rows) AS rows,
count() AS part_count
FROM system.parts
WHERE (active = 1) AND (database LIKE '%') AND (table LIKE '%')
GROUP BY
database,
table
ORDER BY size DESC;
Check the size fo used and free space in Clickhouse
SELECT
d.name AS disk_name,
formatReadableSize(d.free_space) AS free_space,
formatReadableSize(d.total_space) AS total_space,
formatReadableSize(d.total_space - d.free_space) AS used_space,
round((d.total_space - d.free_space) / d.total_space * 100, 2) AS used_percent
FROM system.disks d
ORDER BY used_percent DESC;
Get List of queries running in Clickhouse
SELECT
*
FROM system.processes
ORDER BY elapsed DESC;
Kill a query in Clickhouse
KILL QUERY WHERE query_id = 'your_query_id';
Get size of avg row in bytes by table.
SELECT
c.table,
sum(c.data_uncompressed_bytes) AS total_uncompressed_bytes,
t.total_rows,
sum(c.data_uncompressed_bytes) / t.total_rows AS avg_uncompressed_row_size_bytes
FROM system.columns c
JOIN system.tables t
ON c.database = t.database AND c.table = t.name
WHERE c.database = 'oneuptime'
GROUP BY c.table, t.total_rows
ORDER BY avg_uncompressed_row_size_bytes DESC;