Trino
Integrate with Trino for ad-hoc queries with Full SQL
Start running Trino Image with pre-built Trino Pinot connector.
Kubernetes

1. Install Pinot

Run below command to install Pinot using HelmCharts.
1
helm repo add pinot https://raw.githubusercontent.com/apache/pinot/master/kubernetes/helm
2
kubectl create ns pinot-quickstart
3
helm install pinot pinot/pinot -n pinot-quickstart --set cluster.name=pinot
Copied!
You can create an example table by running the command below, if you are under pinot binary directory
Before PR https://github.com/trinodb/trino/pull/7630 got merged, Change the Pinot table name to all lower cases for table conf/schema and ingestion job spec
1
bin/pinot-admin.sh BootstrapTable -dir examples/batch/airlineStats
Copied!

2. Install Trino

Run below command to add Trino Helm repo and fetch default helm config file:
1
helm repo add trino https://trinodb.github.io/charts/
2
helm inspect values trino/trino > /tmp/trino.yaml
Copied!
Edit /tmp/trino.yaml file to add your pinot catalog:
Here, since pinot is deployed at namespace pinot-quickstart, so the controller url is pinot-controller.pinot-quickstart:9000
1
additionalCatalogs:
2
pinot: |
3
connector.name=pinot
4
pinot.controller-urls=pinot-controller.pinot-quickstart:9000
Copied!
Install Trino HelmCharts with config file:
1
helm create ns trino-quickstart
2
helm install my-trino trino/trino --version 0.2.0 --values /tmp/trino.yaml -n trino-quickstart
Copied!

3. Connecting to Trino

Download Trino Client.
1
curl -L https://repo1.maven.org/maven2/io/trino/trino-cli/363/trino-cli-363-executable.jar -o /tmp/trino && chmod +x /tmp/trino
Copied!
Port forward Trino service to your local if it's not already exposed.
1
export POD_NAME=$(kubectl get pods --namespace trino-quickstart -l "app=trino,release=my-trino,component=coordinator" -o jsonpath="{.items[0].metadata.name}")
2
echo "Visit http://127.0.0.1:8080 to use your application"
3
kubectl port-forward $POD_NAME 8080:8080 --namespace trino-quickstart
Copied!
Use Trino console client to connect to Trino service
1
/tmp/trino --server localhost:8080 --catalog pinot --schema default
Copied!
Then write your own queries:
1
trino:default> show tables;
2
Table
3
---------------
4
airlinestats
5
baseballstats
6
(2 rows)
7
8
Query 20211022_214646_00003_gmppt, FINISHED, 3 nodes
9
Splits: 36 total, 36 done (100.00%)
10
0.44 [2 rows, 59B] [4 rows/s, 133B/s]
Copied!
1
trino:default> select count(*) as flights_from_ca_to_ny from airlinestats where originstate='CA' and deststate='NY';
2
flights_from_ca_to_ny
3
-----------------------
4
68
5
(1 row)
6
7
Query 20211022_215024_00007_gmppt, FINISHED, 1 node
8
Splits: 17 total, 17 done (100.00%)
9
2.14 [1 rows, 9B] [0 rows/s, 4B/s]
Copied!
1
trino:default> select * from airlinestats limit 1;
2
flightnum | origin | quarter | lateaircraftdelay | divactualelapsedtime | divwheelsons | divwheelsoffs | airtime | arrdel15 | divtotalgtimes | deptimeblk | destcitymarketid | divairportseqids | dayssinceepoch | deptime | month | crselapsedtime | deststatename | carrier | destairportid | distance | arrtimeblk | divarrdelay | securitydelay | longestaddgtime | originwac | wheelsoff | destairportseqid | uniquecarrier | divreacheddest | diverted | actualelapsedtime | airlineid
3
-----------+--------+---------+-------------------+----------------------+--------------+---------------+-------------+-------------+----------------+------------+------------------+--------------------+----------------+---------+-------+----------------+---------------+---------+---------------+----------+------------+-------------+---------------+-----------------+-----------+-----------+------------------+---------------+----------------+----------+-------------------+-----------
4
24 | SFO | 1 | -2147483648 | 1968 | [1339, 2310] | [1908, 1758] | -2147483648 | -2147483648 | [121, 50] | 0700-0759 | 31703 | [1319801, 1072102] | 16075 | 723 | 1 | 335 | New York | AA | 12478 | 2586 | 1500-1559 | 1651 | -2147483648 | -2147483648 | 91 | 737 | 1247802 | AA | 1 | 1 | -2147483648 | 19805
5
(1 row)
6
7
Query 20211022_215050_00008_gmppt, FINISHED, 2 nodes
8
Splits: 48 total, 19 done (39.58%)
9
1.90 [2 rows, 1.65KB] [1 rows/s, 887B/s]
Copied!
Meanwhile you can access Trino Cluster UI to see query stats.
Trino Cluster UI
(Disclaimer: Trino is a third-party software that is not part of the Apache Software Foundation).
Last modified 1mo ago
Copy link