1. LeanXcale Glue integration
This document is a practical guide on how to connect Glue with LeanXcale using LeanXcale’s JDBC driver.
Glue offers several connections mode: JDBC, Athena and Spark. At the moment of writing this guide, only JDBC connection is available.
1.1. Upload JDBC driver to S3
Glue needs to have access to the particular JDBC driver, so it is required to upload it to S3.
The driver can be downloaded from LeanXcale Drivers page.
Make sure that the uploaded driver has public access, or the right permissions to be available for the Glue role. It may also be required to set public the bucket containing the driver. |
1.2. Create IAM Role for Glue jobs
You need to create a role which has permission to read from this S3 bucket, write to a destination S3 bucket and run AWS Glue jobs. A possible configuration can be the following:
data:image/s3,"s3://crabby-images/6d4ca/6d4caa3a19001698fe163c9985f1ea6dc2374b9c" alt="glue-role"
1.3. Create connector
First of all, you will need to create a custom connector.
data:image/s3,"s3://crabby-images/d783d/d783dd723648b18d09c7a60770045bb67a92ae7f" alt="glue-custom-conector"
Configure the following points:
-
Connector S3 URL: Enter the S3 location where the LeanXcale’s JDBC driver was uploaded.
-
Name: Enter a name for you connector.
-
Connector type: Choose JDBC.
-
Class name: Set com.leanxcale.client.Driver
-
JDBC URL base: jdbc:leanxcale://<your LX isntance address\>:1522/<your db\>
-
URL parameter delimiter: Use semicolon.
Now, click Create connector.
1.4. Create connection
After creating the connector now it is time for creating a connection. In the connectors page having selected the connector, choose Create connection.
data:image/s3,"s3://crabby-images/08435/0843534cd255bdf10cf2237b93aa7e26c0fc2631" alt="glue-create-connection"
Configure the following fields for the connection:
-
Connection credential type: Choose default.
-
AWS Secret: Here, you will need to create a secret in the AWS Secrets Manager and select it here. Our example is the following.
data:image/s3,"s3://crabby-images/86c6b/86c6baee60f48cbed914419b1df2e967e0635f34" alt="create-secret"
Now choose a name and enter an optional description and after creation, select this secret in the connection’s selector.
-
Additional URL parameters: Here we will add the user and password also, setting it up in the following way:
data:image/s3,"s3://crabby-images/936c4/936c47674141d5b7002a3b2cf0eff322b9844021" alt="additional-parameter"
Choose Create connection.
1.5. Create a Job
With the connector and the connection already setup, we can now create a Glue job to interact with our Lx instance. This will be a basic example on reading an storing data from one table to another using LX for both operations.
The setup consists of two tables already created in LX with only one field.
The SQL to recreate the scenario is the following:
CREATE TABLE Persons (
ID int NOT NULL,
PRIMARY KEY (ID));
CREATE TABLE Persons2 (
ID2 int NOT NULL,
PRIMARY KEY (ID2));
INSERT INTO Persons (ID) values (1);
INSERT INTO Persons (ID) values (2);
INSERT INTO Persons (ID) values (3);
INSERT INTO Persons (ID) values (4);
INSERT INTO Persons (ID) values (5);
INSERT INTO Persons (ID) values (6);
INSERT INTO Persons (ID) values (7);
INSERT INTO Persons (ID) values (8);
INSERT INTO Persons (ID) values (9);
INSERT INTO Persons (ID) values (10);
INSERT INTO Persons (ID) values (11);
INSERT INTO Persons (ID) values (12);
select * from Persons;
From the connectors → connection dashboard, choose Create job.
data:image/s3,"s3://crabby-images/83a66/83a66db85caf3cf95729732745787d6ce5584a14" alt="glue-con-create-job"
The visual representation of the job has the following structure:
data:image/s3,"s3://crabby-images/77d52/77d5295e5ad0c7a0b4a863f2430621baf4204794" alt="job-visual"
1.6. Job Details
Time for configuring the Glue job:
-
IAM Role: Select here the role previously created with the right permissions (permission over the S3 JDBC driver).
-
For the rest options, we configure them as following.
data:image/s3,"s3://crabby-images/2271f/2271fbe1e96b358b0c7fe5323675f9752b869306" alt="job-details"
Execution congifuration can be adapted according to requirements. For this case, they are dimensioned for onyl a functional test.
Once the Job Details have been configured, we can go on and configure the different nodes on the job from the Visual panel.
1.7. Data source configuration
For the configuration of the data source, we add a source node and configure it as following.
data:image/s3,"s3://crabby-images/822a6/822a6bacdc8c60e7dabd238f13fdd37888e89bff" alt="source-1"
We could also select the write a query option and, for example, select all the fields from the table by using select * from Persons.
Also, you need to configure manually the schema the node outputs, as it will be used for the following nodes. In this case, it is just a single int field named ID.
data:image/s3,"s3://crabby-images/aca4c/aca4c6e2df1f81297124c28b0214eec3df8a13f7" alt="schema"
We can add more fields to the output schema by clicking on add root key.
1.8. Mapping configuration
For the example, we are going to select the contents of Persons.ID and place them on Persons2.ID2. For configuring the Mapping transformation we only need the configure the parent node and the transformation required, as well as the output schema.
data:image/s3,"s3://crabby-images/78e48/78e48457626d26b2494dad85931b353727ff08f1" alt="mapping-properties"
data:image/s3,"s3://crabby-images/cad92/cad9259b801ceae90aecb4571d47221a1d402ab4" alt="mapping-transform"
data:image/s3,"s3://crabby-images/a208f/a208f8dfa960748377b718dc5c05237b742e47d6" alt="mapping-schema"
1.9. Data target configuration
For the data target, we choose to save the data back in LeanXcale in the Persons2 table, so the configuration would as follows:
data:image/s3,"s3://crabby-images/5b5af/5b5affd44ba535e5882edd22f7a6326a016053d7" alt="target-properties-2"
data:image/s3,"s3://crabby-images/7810a/7810a68c1bf302014a92e0158228378bee3d9c4f" alt="target-schema"
After this configuration we should be able to run the job and access the logs in the Runs panel and check in LeanXcale instance that the data is moved correctly.