Skip to content

pixelsdb/pixels-trino

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pixels-trino

The Pixels connector for Trino.

Compatibility

Pixels integration (connector & event listener) is currently compatible with Trino 466. Other Trino versions that are compatible with the Connector SPI in Trino 466 should also work well with Pixels.

Build

This project can be opened as a maven project in Intellij and built using maven.

Note that Trino 466 requires Java 23.0.0+, thus this project should be built by JDK 23 (Azul Zulu JDK 23.0.1+11 is tested).

Pixels is the parent of this project, therefore use mvn install to install Pixels modules into your local maven repository, before building this project.

After building pixels-trino, find the following zip files in the build target directories:

  • pixels-trino-listener-*.zip, this is the event listener plugin for Trino.
  • pixels-trino-connector-*.zip, this is the connector for Trino.

They will be used in the following steps.

Use Pixels in Trino

Follow the instructions in Pixels Installation to install Pixels and other components except Trino. After that, follow this document to install Trino and use it to query Pixels. Ensure Java 23 is in use as it is required by Trino 466.

Install Trino

Download and install Trino 466 following the instructions in Trino Docs.

Here, we install Trino to ~/opt/trino-server-466 and create a link for it:

cd ~/opt; ln -s trino-server-466 trino-server

Then download trino-cli into ~/opt/trino-server/bin/ and give the executable permission to it.

Install Pixels Connector

There are two important directories in the home of trino-server: etc and plugin. To install Pixels connector, decompress pixels-trino-connector-*.zip into the plugin directory. The etc directory contains the configuration files of Trino. In addition to the configurations mentioned in the official docs, create the catalog config file named pixels.properties for Pixels in the etc/catalog directory, with the following content:

connector.name=pixels

# serverless config
# it can be on, off, auto, or session
cloud.function.switch=off
clean.intermediate.result=true

Note that etc/catalog/pixels.proterties under Trino's home is different from PIXELS_HOME/pixels.properties. In Trino, Pixels can push projections, filters, joins, and aggregations into serverless computing services (e.g., AWS Lambda). This feature is named Pixels-Turbo and can be turned on by setting cloud.function.switch to auto (adaptively enabled) or on (always enabled). Turn it off to only use Trino workers for query processing. We can also set it to session so that this switch can be dynamically turned on or off by the session properties pixels.cloud_function_enabled. This allows pixels-server choosing whether to execute the query with cloud functions enabled.

Append the following two lines into etc/jvm.config:

--add-opens=java.base/sun.nio.ch=ALL-UNNAMED
--add-opens=java.base/java.nio=ALL-UNNAMED

Thus, pixels can reflect internal or low-level classes to improve performance. This is only needed for Java 9+.

Install Pixels Event Listener*

Pixels event listener is optional. It is used to collect the query completion information for performance evaluations. To install the event listener, decompress pixels-trino-listener-*.zip into the plugin directory.

Create the listener config file named event-listener.properties in the etc directory, with the following content:

event-listener.name=pixels-event-listener
enabled=true
listened.user.prefix=none
listened.schema=pixels
listened.query.type=SELECT
log.dir=/home/ubuntu/opt/pixels/listener/

log-dir should point to an existing directory where the listener logs will appear.

Run Queries

Start Pixels + Trino following the instructions in Starting Pixels + Trino. Then, you can test the query performance following TPC-H Evaluation.