Skip to content

Commit 11e073b

Browse files
committed
add Hydra 👋
1 parent 22239f7 commit 11e073b

File tree

9 files changed

+351
-0
lines changed

9 files changed

+351
-0
lines changed

hydra/README.md

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
# Hydra
2+
3+
Hydra is an open source data warehouse built on Postgres.
4+
5+
* [Homepage](https://hydras.io)
6+
* [GitHub](https://github.com/HydrasDB/hydra)
7+
8+
## Running the benchmark
9+
10+
The benchmark has been configured for a `c6a.4xlarge` running Ubuntu 22.04 and can be run without attendance.
11+
12+
```
13+
export HOST=ec2-127-0-0-1.compute-1.amazonaws.com
14+
scp -i ~/.ssh/aws.pem *.sh *.sql ubuntu@$HOST:~
15+
ssh -i ~/.ssh/aws.pem ubuntu@$HOST ./benchmark.sh
16+
```

hydra/benchmark.sh

+35
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
#!/bin/bash
2+
set -euo pipefail
3+
IFS=$'\n\t'
4+
5+
# sets up PG14, configs, and build deps on ubuntu 22.04
6+
sudo ./install.sh
7+
8+
# download hits.tsv if we dont already have it
9+
if [ ! -e hits.tsv ]; then
10+
wget --continue 'https://datasets.clickhouse.com/hits_compatible/hits.tsv.gz'
11+
gzip -d hits.tsv.gz
12+
fi
13+
14+
# ensure postgres user can access hits.tsv
15+
chmod a+rX . hits.tsv
16+
17+
# set up db, user, table; load data.
18+
sudo -u postgres psql -t -c 'CREATE DATABASE test'
19+
sudo -u postgres psql test -t < create.sql
20+
sudo -u postgres psql test -t -c 'TRUNCATE hits'
21+
sudo -u postgres psql test -t -c '\timing' -c "\\copy hits FROM 'hits.tsv'"
22+
23+
# COPY 99997497
24+
# Time: 1320024.670 ms (22:00.025)
25+
26+
# run test
27+
./run.sh 2>&1 | tee log.txt
28+
29+
# disk usage
30+
sudo du -bcs /var/lib/postgresql/14/main/
31+
32+
# 18979994590
33+
34+
# parse results for json file
35+
./parse.sh < log.txt

hydra/create.sql

+111
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,111 @@
1+
CREATE EXTENSION IF NOT EXISTS columnar;
2+
CREATE TABLE IF NOT EXISTS hits
3+
(
4+
WatchID BIGINT NOT NULL,
5+
JavaEnable SMALLINT NOT NULL,
6+
Title TEXT NOT NULL,
7+
GoodEvent SMALLINT NOT NULL,
8+
EventTime TIMESTAMP NOT NULL,
9+
EventDate Date NOT NULL,
10+
CounterID INTEGER NOT NULL,
11+
ClientIP INTEGER NOT NULL,
12+
RegionID INTEGER NOT NULL,
13+
UserID BIGINT NOT NULL,
14+
CounterClass SMALLINT NOT NULL,
15+
OS SMALLINT NOT NULL,
16+
UserAgent SMALLINT NOT NULL,
17+
URL TEXT NOT NULL,
18+
Referer TEXT NOT NULL,
19+
IsRefresh SMALLINT NOT NULL,
20+
RefererCategoryID SMALLINT NOT NULL,
21+
RefererRegionID INTEGER NOT NULL,
22+
URLCategoryID SMALLINT NOT NULL,
23+
URLRegionID INTEGER NOT NULL,
24+
ResolutionWidth SMALLINT NOT NULL,
25+
ResolutionHeight SMALLINT NOT NULL,
26+
ResolutionDepth SMALLINT NOT NULL,
27+
FlashMajor SMALLINT NOT NULL,
28+
FlashMinor SMALLINT NOT NULL,
29+
FlashMinor2 TEXT NOT NULL,
30+
NetMajor SMALLINT NOT NULL,
31+
NetMinor SMALLINT NOT NULL,
32+
UserAgentMajor SMALLINT NOT NULL,
33+
UserAgentMinor VARCHAR(255) NOT NULL,
34+
CookieEnable SMALLINT NOT NULL,
35+
JavascriptEnable SMALLINT NOT NULL,
36+
IsMobile SMALLINT NOT NULL,
37+
MobilePhone SMALLINT NOT NULL,
38+
MobilePhoneModel TEXT NOT NULL,
39+
Params TEXT NOT NULL,
40+
IPNetworkID INTEGER NOT NULL,
41+
TraficSourceID SMALLINT NOT NULL,
42+
SearchEngineID SMALLINT NOT NULL,
43+
SearchPhrase TEXT NOT NULL,
44+
AdvEngineID SMALLINT NOT NULL,
45+
IsArtifical SMALLINT NOT NULL,
46+
WindowClientWidth SMALLINT NOT NULL,
47+
WindowClientHeight SMALLINT NOT NULL,
48+
ClientTimeZone SMALLINT NOT NULL,
49+
ClientEventTime TIMESTAMP NOT NULL,
50+
SilverlightVersion1 SMALLINT NOT NULL,
51+
SilverlightVersion2 SMALLINT NOT NULL,
52+
SilverlightVersion3 INTEGER NOT NULL,
53+
SilverlightVersion4 SMALLINT NOT NULL,
54+
PageCharset TEXT NOT NULL,
55+
CodeVersion INTEGER NOT NULL,
56+
IsLink SMALLINT NOT NULL,
57+
IsDownload SMALLINT NOT NULL,
58+
IsNotBounce SMALLINT NOT NULL,
59+
FUniqID BIGINT NOT NULL,
60+
OriginalURL TEXT NOT NULL,
61+
HID INTEGER NOT NULL,
62+
IsOldCounter SMALLINT NOT NULL,
63+
IsEvent SMALLINT NOT NULL,
64+
IsParameter SMALLINT NOT NULL,
65+
DontCountHits SMALLINT NOT NULL,
66+
WithHash SMALLINT NOT NULL,
67+
HitColor CHAR NOT NULL,
68+
LocalEventTime TIMESTAMP NOT NULL,
69+
Age SMALLINT NOT NULL,
70+
Sex SMALLINT NOT NULL,
71+
Income SMALLINT NOT NULL,
72+
Interests SMALLINT NOT NULL,
73+
Robotness SMALLINT NOT NULL,
74+
RemoteIP INTEGER NOT NULL,
75+
WindowName INTEGER NOT NULL,
76+
OpenerName INTEGER NOT NULL,
77+
HistoryLength SMALLINT NOT NULL,
78+
BrowserLanguage TEXT NOT NULL,
79+
BrowserCountry TEXT NOT NULL,
80+
SocialNetwork TEXT NOT NULL,
81+
SocialAction TEXT NOT NULL,
82+
HTTPError SMALLINT NOT NULL,
83+
SendTiming INTEGER NOT NULL,
84+
DNSTiming INTEGER NOT NULL,
85+
ConnectTiming INTEGER NOT NULL,
86+
ResponseStartTiming INTEGER NOT NULL,
87+
ResponseEndTiming INTEGER NOT NULL,
88+
FetchTiming INTEGER NOT NULL,
89+
SocialSourceNetworkID SMALLINT NOT NULL,
90+
SocialSourcePage TEXT NOT NULL,
91+
ParamPrice BIGINT NOT NULL,
92+
ParamOrderID TEXT NOT NULL,
93+
ParamCurrency TEXT NOT NULL,
94+
ParamCurrencyID SMALLINT NOT NULL,
95+
OpenstatServiceName TEXT NOT NULL,
96+
OpenstatCampaignID TEXT NOT NULL,
97+
OpenstatAdID TEXT NOT NULL,
98+
OpenstatSourceID TEXT NOT NULL,
99+
UTMSource TEXT NOT NULL,
100+
UTMMedium TEXT NOT NULL,
101+
UTMCampaign TEXT NOT NULL,
102+
UTMContent TEXT NOT NULL,
103+
UTMTerm TEXT NOT NULL,
104+
FromTag TEXT NOT NULL,
105+
HasGCLID SMALLINT NOT NULL,
106+
RefererHash BIGINT NOT NULL,
107+
URLHash BIGINT NOT NULL,
108+
CLID INTEGER NOT NULL,
109+
PRIMARY KEY (CounterID, EventDate, UserID, EventTime, WatchID)
110+
)
111+
USING columnar;

hydra/install.sh

+59
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
#!/bin/bash
2+
set -euo pipefail
3+
IFS=$'\n\t'
4+
5+
config_file="/etc/postgresql/14/main/conf.d/hydra.conf"
6+
7+
write_config_file() {
8+
# config for a c6a.4xlarge
9+
cat >${config_file} << CONF
10+
max_worker_processes = 32
11+
max_parallel_workers = 16
12+
work_mem = 64MB
13+
shared_buffers = 8GB
14+
effective_cache_size = 24GB
15+
effective_io_concurrency = 100
16+
hash_mem_multiplier = 8
17+
shared_preload_libraries = 'columnar'
18+
columnar.min_parallel_processes = 16
19+
CONF
20+
}
21+
22+
if [ ! ${EUID} -eq 0 ]; then
23+
echo "Please run as root or with sudo"
24+
exit 1
25+
fi
26+
27+
# already ran this setup file
28+
if [ -f "$config_file" ]; then
29+
# rewrite the file with any tweaks
30+
write_config_file
31+
service postgresql restart
32+
exit 0
33+
fi
34+
35+
export DEBIAN_FRONTEND=noninteractive
36+
37+
# install pg14 from pgdg, install build deps
38+
apt-get update
39+
apt-get install gnupg postgresql-common -y
40+
sh /usr/share/postgresql-common/pgdg/apt.postgresql.org.sh -y
41+
apt-get update
42+
apt-get upgrade -y
43+
apt-get install lsb-release gcc make libssl-dev autoconf pkg-config \
44+
postgresql-14 postgresql-server-dev-14 libcurl4-gnutls-dev \
45+
liblz4-dev libzstd-dev -y
46+
47+
# build and install hydra columnar extension
48+
if [ ! -d hydra ]; then
49+
git clone --depth 1 https://github.com/HydrasDB/hydra.git
50+
fi
51+
cd hydra/columnar
52+
./configure
53+
make
54+
make install
55+
cd ../..
56+
57+
write_config_file
58+
59+
service postgresql restart

hydra/parse.sh

+14
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
#!/bin/bash
2+
3+
# OS X: you need to use the gnu tools from homebrew
4+
GREP="grep"
5+
if command -v ggrep >/dev/null 2>&1; then
6+
grep="ggrep"
7+
fi
8+
SED="sed"
9+
if command -v gsed >/dev/null 2>&1; then
10+
sed="gsed"
11+
fi
12+
13+
$GREP -oP 'Time: \d+\.\d+ ms' | $SED -r -e 's/Time: ([0-9]+\.[0-9]+) ms/\1/' |
14+
awk '{ if (i % 3 == 0) { printf "[" }; printf $1 / 1000; if (i % 3 != 2) { printf "," } else { print "]," }; ++i; }'

hydra/queries.sql

+43
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
SELECT COUNT(*) FROM hits;
2+
SELECT COUNT(*) FROM hits WHERE AdvEngineID <> 0;
3+
SELECT SUM(AdvEngineID), COUNT(*), AVG(ResolutionWidth) FROM hits;
4+
SELECT AVG(UserID) FROM hits;
5+
SELECT COUNT(DISTINCT UserID) FROM hits;
6+
SELECT COUNT(DISTINCT SearchPhrase) FROM hits;
7+
SELECT MIN(EventDate), MAX(EventDate) FROM hits;
8+
SELECT AdvEngineID, COUNT(*) FROM hits WHERE AdvEngineID <> 0 GROUP BY AdvEngineID ORDER BY COUNT(*) DESC;
9+
SELECT RegionID, COUNT(DISTINCT UserID) AS u FROM hits GROUP BY RegionID ORDER BY u DESC LIMIT 10;
10+
SELECT RegionID, SUM(AdvEngineID), COUNT(*) AS c, AVG(ResolutionWidth), COUNT(DISTINCT UserID) FROM hits GROUP BY RegionID ORDER BY c DESC LIMIT 10;
11+
SELECT MobilePhoneModel, COUNT(DISTINCT UserID) AS u FROM hits WHERE MobilePhoneModel <> '' GROUP BY MobilePhoneModel ORDER BY u DESC LIMIT 10;
12+
SELECT MobilePhone, MobilePhoneModel, COUNT(DISTINCT UserID) AS u FROM hits WHERE MobilePhoneModel <> '' GROUP BY MobilePhone, MobilePhoneModel ORDER BY u DESC LIMIT 10;
13+
SELECT SearchPhrase, COUNT(*) AS c FROM hits WHERE SearchPhrase <> '' GROUP BY SearchPhrase ORDER BY c DESC LIMIT 10;
14+
SELECT SearchPhrase, COUNT(DISTINCT UserID) AS u FROM hits WHERE SearchPhrase <> '' GROUP BY SearchPhrase ORDER BY u DESC LIMIT 10;
15+
SELECT SearchEngineID, SearchPhrase, COUNT(*) AS c FROM hits WHERE SearchPhrase <> '' GROUP BY SearchEngineID, SearchPhrase ORDER BY c DESC LIMIT 10;
16+
SELECT UserID, COUNT(*) FROM hits GROUP BY UserID ORDER BY COUNT(*) DESC LIMIT 10;
17+
SELECT UserID, SearchPhrase, COUNT(*) FROM hits GROUP BY UserID, SearchPhrase ORDER BY COUNT(*) DESC LIMIT 10;
18+
SELECT UserID, SearchPhrase, COUNT(*) FROM hits GROUP BY UserID, SearchPhrase LIMIT 10;
19+
SELECT UserID, extract(minute FROM EventTime) AS m, SearchPhrase, COUNT(*) FROM hits GROUP BY UserID, m, SearchPhrase ORDER BY COUNT(*) DESC LIMIT 10;
20+
SELECT UserID FROM hits WHERE UserID = 435090932899640449;
21+
SELECT COUNT(*) FROM hits WHERE URL LIKE '%google%';
22+
SELECT SearchPhrase, MIN(URL), COUNT(*) AS c FROM hits WHERE URL LIKE '%google%' AND SearchPhrase <> '' GROUP BY SearchPhrase ORDER BY c DESC LIMIT 10;
23+
SELECT SearchPhrase, MIN(URL), MIN(Title), COUNT(*) AS c, COUNT(DISTINCT UserID) FROM hits WHERE Title LIKE '%Google%' AND URL NOT LIKE '%.google.%' AND SearchPhrase <> '' GROUP BY SearchPhrase ORDER BY c DESC LIMIT 10;
24+
SELECT * FROM hits WHERE URL LIKE '%google%' ORDER BY EventTime LIMIT 10;
25+
SELECT SearchPhrase FROM hits WHERE SearchPhrase <> '' ORDER BY EventTime LIMIT 10;
26+
SELECT SearchPhrase FROM hits WHERE SearchPhrase <> '' ORDER BY SearchPhrase LIMIT 10;
27+
SELECT SearchPhrase FROM hits WHERE SearchPhrase <> '' ORDER BY EventTime, SearchPhrase LIMIT 10;
28+
SELECT CounterID, AVG(length(URL)) AS l, COUNT(*) AS c FROM hits WHERE URL <> '' GROUP BY CounterID HAVING COUNT(*) > 100000 ORDER BY l DESC LIMIT 25;
29+
SELECT REGEXP_REPLACE(Referer, '^https?://(?:www\.)?([^/]+)/.*$', '\1') AS k, AVG(length(Referer)) AS l, COUNT(*) AS c, MIN(Referer) FROM hits WHERE Referer <> '' GROUP BY k HAVING COUNT(*) > 100000 ORDER BY l DESC LIMIT 25;
30+
SELECT SUM(ResolutionWidth), SUM(ResolutionWidth + 1), SUM(ResolutionWidth + 2), SUM(ResolutionWidth + 3), SUM(ResolutionWidth + 4), SUM(ResolutionWidth + 5), SUM(ResolutionWidth + 6), SUM(ResolutionWidth + 7), SUM(ResolutionWidth + 8), SUM(ResolutionWidth + 9), SUM(ResolutionWidth + 10), SUM(ResolutionWidth + 11), SUM(ResolutionWidth + 12), SUM(ResolutionWidth + 13), SUM(ResolutionWidth + 14), SUM(ResolutionWidth + 15), SUM(ResolutionWidth + 16), SUM(ResolutionWidth + 17), SUM(ResolutionWidth + 18), SUM(ResolutionWidth + 19), SUM(ResolutionWidth + 20), SUM(ResolutionWidth + 21), SUM(ResolutionWidth + 22), SUM(ResolutionWidth + 23), SUM(ResolutionWidth + 24), SUM(ResolutionWidth + 25), SUM(ResolutionWidth + 26), SUM(ResolutionWidth + 27), SUM(ResolutionWidth + 28), SUM(ResolutionWidth + 29), SUM(ResolutionWidth + 30), SUM(ResolutionWidth + 31), SUM(ResolutionWidth + 32), SUM(ResolutionWidth + 33), SUM(ResolutionWidth + 34), SUM(ResolutionWidth + 35), SUM(ResolutionWidth + 36), SUM(ResolutionWidth + 37), SUM(ResolutionWidth + 38), SUM(ResolutionWidth + 39), SUM(ResolutionWidth + 40), SUM(ResolutionWidth + 41), SUM(ResolutionWidth + 42), SUM(ResolutionWidth + 43), SUM(ResolutionWidth + 44), SUM(ResolutionWidth + 45), SUM(ResolutionWidth + 46), SUM(ResolutionWidth + 47), SUM(ResolutionWidth + 48), SUM(ResolutionWidth + 49), SUM(ResolutionWidth + 50), SUM(ResolutionWidth + 51), SUM(ResolutionWidth + 52), SUM(ResolutionWidth + 53), SUM(ResolutionWidth + 54), SUM(ResolutionWidth + 55), SUM(ResolutionWidth + 56), SUM(ResolutionWidth + 57), SUM(ResolutionWidth + 58), SUM(ResolutionWidth + 59), SUM(ResolutionWidth + 60), SUM(ResolutionWidth + 61), SUM(ResolutionWidth + 62), SUM(ResolutionWidth + 63), SUM(ResolutionWidth + 64), SUM(ResolutionWidth + 65), SUM(ResolutionWidth + 66), SUM(ResolutionWidth + 67), SUM(ResolutionWidth + 68), SUM(ResolutionWidth + 69), SUM(ResolutionWidth + 70), SUM(ResolutionWidth + 71), SUM(ResolutionWidth + 72), SUM(ResolutionWidth + 73), SUM(ResolutionWidth + 74), SUM(ResolutionWidth + 75), SUM(ResolutionWidth + 76), SUM(ResolutionWidth + 77), SUM(ResolutionWidth + 78), SUM(ResolutionWidth + 79), SUM(ResolutionWidth + 80), SUM(ResolutionWidth + 81), SUM(ResolutionWidth + 82), SUM(ResolutionWidth + 83), SUM(ResolutionWidth + 84), SUM(ResolutionWidth + 85), SUM(ResolutionWidth + 86), SUM(ResolutionWidth + 87), SUM(ResolutionWidth + 88), SUM(ResolutionWidth + 89) FROM hits;
31+
SELECT SearchEngineID, ClientIP, COUNT(*) AS c, SUM(IsRefresh), AVG(ResolutionWidth) FROM hits WHERE SearchPhrase <> '' GROUP BY SearchEngineID, ClientIP ORDER BY c DESC LIMIT 10;
32+
SELECT WatchID, ClientIP, COUNT(*) AS c, SUM(IsRefresh), AVG(ResolutionWidth) FROM hits WHERE SearchPhrase <> '' GROUP BY WatchID, ClientIP ORDER BY c DESC LIMIT 10;
33+
SELECT WatchID, ClientIP, COUNT(*) AS c, SUM(IsRefresh), AVG(ResolutionWidth) FROM hits GROUP BY WatchID, ClientIP ORDER BY c DESC LIMIT 10;
34+
SELECT URL, COUNT(*) AS c FROM hits GROUP BY URL ORDER BY c DESC LIMIT 10;
35+
SELECT 1, URL, COUNT(*) AS c FROM hits GROUP BY 1, URL ORDER BY c DESC LIMIT 10;
36+
SELECT ClientIP, ClientIP - 1, ClientIP - 2, ClientIP - 3, COUNT(*) AS c FROM hits GROUP BY ClientIP, ClientIP - 1, ClientIP - 2, ClientIP - 3 ORDER BY c DESC LIMIT 10;
37+
SELECT URL, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-01' AND EventDate <= '2013-07-31' AND DontCountHits = 0 AND IsRefresh = 0 AND URL <> '' GROUP BY URL ORDER BY PageViews DESC LIMIT 10;
38+
SELECT Title, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-01' AND EventDate <= '2013-07-31' AND DontCountHits = 0 AND IsRefresh = 0 AND Title <> '' GROUP BY Title ORDER BY PageViews DESC LIMIT 10;
39+
SELECT URL, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-01' AND EventDate <= '2013-07-31' AND IsRefresh = 0 AND IsLink <> 0 AND IsDownload = 0 GROUP BY URL ORDER BY PageViews DESC LIMIT 10 OFFSET 1000;
40+
SELECT TraficSourceID, SearchEngineID, AdvEngineID, CASE WHEN (SearchEngineID = 0 AND AdvEngineID = 0) THEN Referer ELSE '' END AS Src, URL AS Dst, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-01' AND EventDate <= '2013-07-31' AND IsRefresh = 0 GROUP BY TraficSourceID, SearchEngineID, AdvEngineID, Src, Dst ORDER BY PageViews DESC LIMIT 10 OFFSET 1000;
41+
SELECT URLHash, EventDate, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-01' AND EventDate <= '2013-07-31' AND IsRefresh = 0 AND TraficSourceID IN (-1, 6) AND RefererHash = 3594120000172545465 GROUP BY URLHash, EventDate ORDER BY PageViews DESC LIMIT 10 OFFSET 100;
42+
SELECT WindowClientWidth, WindowClientHeight, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-01' AND EventDate <= '2013-07-31' AND IsRefresh = 0 AND DontCountHits = 0 AND URLHash = 2868770270353813622 GROUP BY WindowClientWidth, WindowClientHeight ORDER BY PageViews DESC LIMIT 10 OFFSET 10000;
43+
SELECT DATE_TRUNC('minute', EventTime) AS M, COUNT(*) AS PageViews FROM hits WHERE CounterID = 62 AND EventDate >= '2013-07-14' AND EventDate <= '2013-07-15' AND IsRefresh = 0 AND DontCountHits = 0 GROUP BY DATE_TRUNC('minute', EventTime) ORDER BY DATE_TRUNC('minute', EventTime) LIMIT 10 OFFSET 1000;

hydra/results/c6a.4xlarge.json

+59
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
{
2+
"system": "Hydra",
3+
"date": "2022-12-09",
4+
"machine": "c6a.4xlarge, 500gb gp2",
5+
"cluster_size": 1,
6+
"comment": "",
7+
"tags": [
8+
"C",
9+
"PostgreSQL compatible",
10+
"column-oriented"
11+
],
12+
"load_time": 1320,
13+
"data_size": 18979994590,
14+
"result": [
15+
[0.740694,0.559759,0.554923],
16+
[0.301194,0.177796,0.177315],
17+
[1.02766,0.932874,0.93086],
18+
[0.822004,0.670304,0.669193],
19+
[22.1797,21.4226,21.1139],
20+
[36.6104,32.6343,33.2646],
21+
[0.86711,0.726068,0.717364],
22+
[0.197655,0.183667,0.179238],
23+
[27.4706,26.7764,26.5041],
24+
[27.5853,26.3914,26.6962],
25+
[3.35359,3.32823,2.5907],
26+
[2.94602,2.74354,2.62606],
27+
[6.87809,6.25172,6.33486],
28+
[12.325,10.0007,10.5973],
29+
[9.19494,8.12375,8.15671],
30+
[9.00219,9.03757,9.06412],
31+
[29.8696,30.932,29.5041],
32+
[4.37935,4.27177,4.22549],
33+
[39.0721,38.0603,38.0578],
34+
[0.136752,0.097382,0.094568],
35+
[5.25151,2.64213,2.63089],
36+
[2.83423,2.82903,2.83144],
37+
[4.15824,3.49945,3.47109],
38+
[29.7921,19.2574,19.4905],
39+
[1.95286,0.997379,0.994311],
40+
[1.02292,0.781007,0.775684],
41+
[1.23559,1.0049,0.99849],
42+
[4.3043,4.12738,4.12725],
43+
[46.2241,45.5508,45.5717],
44+
[8.13096,7.45358,7.50328],
45+
[10.1521,10.1498,9.63454],
46+
[19.2246,17.6757,17.6227],
47+
[144.626,145.754,147.718],
48+
[25.2833,25.5076,24.6359],
49+
[26.0226,28.9469,27.4574],
50+
[9.45768,8.53303,8.51915],
51+
[0.972488,0.863001,0.858721],
52+
[0.469013,0.488229,0.452213],
53+
[0.144778,0.118679,0.116987],
54+
[1.91039,1.81155,1.98042],
55+
[0.122169,0.116007,0.120359],
56+
[0.142668,0.124877,0.108149],
57+
[0.185689,0.17577,0.171818]
58+
]
59+
}

hydra/run.sh

+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
#!/bin/bash
2+
3+
TRIES=3
4+
5+
cat queries.sql | while read query; do
6+
sync
7+
echo 3 | sudo tee /proc/sys/vm/drop_caches
8+
9+
echo "$query";
10+
for i in $(seq 1 $TRIES); do
11+
sudo -u postgres psql test -t -c '\timing' -c "$query" | grep 'Time'
12+
done;
13+
done;

0 commit comments

Comments
 (0)