This documentation outlines the steps required to deploy the Query Insights Extension with the desired backend for generating summaries of data from an Explore Query. It assumes a Looker Instance is available with a suitable LookML Model and Explore configured.
This section describes how to set up the LLM Integration for the Query Insights.
-
Clone or download a copy of this repository to your development machine. If you have a git ssh_config:
# cd ~/ Optional. your user directory is usually a good place to git clone to. git clone [email protected]:looker-open-source/looker-query-insights.git
If not:
# cd ~/ Optional. your user directory is usually a good place to git clone to. git clone https://github.com/looker-open-source/looker-query-insights.git
-
Install a backend using terraform by following the instructions
-
Save the backend details for use by the extension framework:
- The BigQuery example dataset
- If you're using the BigQuery backend, the model id that allows communication with Gemini
Important If you are not familiar with the Looker Extension Framework, please review this documentation first before moving forward.
-
From the Query Insights root directory (
cd
) to the Query Insights Extension folder. If deploying from Cloudshell, you should already be in this folder.cd query-insights-extension
-
Install the dependencies with NPM. Please follow the hyperlinked directions for installing node and npm on your machine. Skip this step if deploying from Cloud Shell method above. Additionally if you need to work across multiple Node versions,
nvm
can be used switch between and install different node versions.npm install
You may need to update your Node version or use a Node version manager to change your Node version.
-
Create a new BigQuery connection in Looker that will allow us to query Vertex AI (or reuse and existing BigQuery connection you have in Looker that can access the BQML model created in the Backend setup). You will use that in the VERTEX_BIGQUERY_LOOKER_CONNECTION_NAME below.
-
Ensure all the appropriate environment variables are set in the
.env
file. There is a .env-examples files in the looker-query-insights root, you can edit it and save as .env.Regardless of the backend, you're going to need:
VERTEX_BIGQUERY_LOOKER_CONNECTION_NAME=<This is the connection name in Looker with the BQ project that has access to the remote connection and model>
If you're using the BigQuery Backend replace the default:
VERTEX_BIGQUERY_MODEL_ID=<This is the model id that you want to use for prediction>
-
Start the development server (Skip this step if you aren't changing the UI code, and proceed to the next step then to deployment) IMPORTANT If you are running the extension from a VM or another remote machine, you will need to Port Forward to the machine where you are accessing the Looker Instance from (ie. If you are accessing Looker from your local machine, run the following command there.). Here's a boilerplate example for port forwarding the remote port 8080 to the local port 8080:
ssh username@host -L 3000:localhost:3000
.npm run start
Great! Your extension is now running and serving the JavaScript at https://localhost:3000/bundle.js.
-
Now log in to Looker and create a new project or use an existing project.
This is found under Develop => Manage LookML Projects => New LookML Project.
You'll want to select "Blank Project" as your "Starting Point". You'll now have a new project with no files.
- In your copy of the extension project you have a
manifest.lkml
file.
You can either drag & upload this file into your Looker project, or create a
manifest.lkml
with the same content. Change theid
,label
, orurl
as needed. Your manifest.lkml file should look like the below examples.application: query_insights { label: "Query Insights" # url: "https://localhost:3000/bundle.js" file: "bundle.js" mount_points: { dashboard_vis: yes dashboard_tile: yes standalone: no } entitlements: { core_api_methods: ["create_sql_query","run_sql_query","run_query","create_query"] navigation: yes use_embeds: yes use_iframes: yes new_window: yes new_window_external_urls: ["https://developers.generativeai.google/*"] local_storage: yes } }
- In your copy of the extension project you have a
-
Create a
model
LookML file in your project. The name doesn't matter. The model and connection won't be used, and in the future this step may be eliminated.- Add a connection in this model. It can be any connection, it doesn't matter which.
- Configure the model you created so that it has access to some connection.
-
Connect your new project to Git. You can do this multiple ways:
- Create a new repository on GitHub or a similar service, and follow the instructions to connect your project to Git
- A simpler but less powerful approach is to set up git with the "Bare" repository option which does not require connecting to an external Git Service.
-
Commit your changes and deploy your them to production through the Project UI.
-
Reload the page and in the left navigation panel click on the Application drop-down. You should see your extension in the list.
-
The extension will load the JavaScript from the
url
provided in theapplication
definition if running locally OR from thefile
specified if skipping the local development step. By default, this is https://localhost:3000/bundle.js forurl
andbundle.js
iffile
. If you change the port your server runs on in the package.json, you will need to also update it in the manifest.lkml. -
Refreshing the extension page will bring in any new code changes from the extension template, although some changes will hot reload.
The process above requires your local development server to be running to load the extension code. To allow other people to use the extension, a production build of the extension needs to be run. As the kitchensink uses code splitting to reduce the size of the initially loaded bundle, multiple JavaScript files are generated.
- In your extension project directory on your development machine, build the extension by running the command
npm run build
. - Drag and drop the
bundle.js
JavaScript file contained in thedist
directory into the Looker project interface. - Modify your
manifest.lkml
to usefile
instead ofurl
and point it at thebundle.js
file.
Note that the additional JavaScript files generated during the production build process do not have to be mentioned in the manifest. These files will be loaded dynamically by the extension as and when they are needed. Note that to utilize code splitting, the Looker server must be at version 7.21 or above.