Amazon SageMaker Lakehouse allows a unified, open, and safe lakehouse platform in your present information lakes and warehouses. Its unified information structure helps information evaluation, enterprise intelligence, machine studying, and generative AI purposes, which may now make the most of a single authoritative copy of knowledge. With SageMaker Lakehouse, you get one of the best of each worlds—the pliability to make use of price efficient Amazon Easy Storage Service (Amazon S3) storage with the scalable compute of an information lake, together with the efficiency, reliability and SQL capabilities sometimes related to an information warehouse.
SageMaker Lakehouse allows interoperability by offering open supply Apache Iceberg REST APIs to entry information within the lakehouse. Prospects can now use their alternative of instruments and a variety of AWS companies similar to Amazon Redshift, Amazon EMR, Amazon Athena and Amazon SageMaker, along with third-party analytics engines which can be appropriate with Apache Iceberg REST specs to question their information in-place.
Lastly, SageMaker Lakehouse now gives safe and fine-grained entry controls on information in each information warehouses and information lakes. With useful resource permission controls from AWS Lake Formation built-in into the AWS Glue Information Catalog, SageMaker Lakehouse lets prospects securely outline and share entry to a single authoritative copy of knowledge throughout their whole group.
Organizations managing workloads in AWS analytics and Databricks can now use this open and safe lakehouse functionality to unify coverage administration and oversight of their information lake in Amazon S3. On this publish, we are going to present you the way Databricks on AWS common objective compute can combine with the AWS Glue Iceberg REST Catalog for metadata entry and use Lake Formation for information entry. To maintain the setup on this publish easy, the Glue Iceberg REST Catalog and Databricks cluster share the identical AWS account.
Resolution overview
On this publish, we present how tables cataloged in Information Catalog and saved on Amazon S3 may be consumed from Databricks compute utilizing Glue Iceberg REST Catalog with information entry secured utilizing Lake Formation. We are going to present you the way the cluster may be configured to work together with Glue Iceberg REST Catalog, use a pocket book to entry the info utilizing Lake Formation momentary vended credentials, and run evaluation to derive insights.
The next determine exhibits the structure described within the previous paragraph.

Conditions
To comply with together with the answer introduced on this publish, you want the next AWS conditions:
- Entry to the Lake Formation information lake administrator in your AWS account. A Lake Formation information lake administrator is an IAM principal that may register Amazon S3 places, entry the Information Catalog, grant Lake Formation permissions to different customers, and examine AWS CloudTrail See Create an information lake administrator for extra data.
- Allow full desk entry for exterior engines to entry information in Lake Formation.
- Signal into Lake Formation console as an IAM administrator and select Administration within the navigation pane.
- Select Software integration settings and choose Enable exterior engines to entry information in Amazon S3 places with full desk entry.
- Select Save.

- An present AWS Glue database and tables. For this publish, we are going to use an AWS Glue database named
icebergdemodb, which comprises an Iceberg desk named individual and information is saved in an S3 common objective bucket namedicebergdemodatalake.

- A user-defined IAM position that Lake Formation assumes when accessing the info within the above S3 location to vend scoped credentials. Comply with the directions offered in Necessities for roles used to register places. For this publish, we are going to use the IAM position
LakeFormationRegistrationRole.
Along with the AWS conditions, you want entry to Databricks Workspace (on AWS) and the power to create a cluster with No isolation shared entry mode.
Arrange an occasion profile position. For directions on how one can create and arrange the position, see Handle occasion profiles in Databricks. Create buyer managed coverage named: dataplane-glue-lf-policy with under insurance policies and fasten the identical to the occasion profile position:
For this publish, we are going to use an occasion profile position (databricks-dataplane-instance-profile-role), which might be hooked up to the beforehand created cluster.
Register the Amazon S3 location as the info lake location
Registering an Amazon S3 location with Lake Formation gives an IAM position with learn/write permissions to the S3 location. On this case, you might be required to register the icebergdemodatalake bucket location utilizing the LakeFormationRegistrationRole IAM position.
After the situation is registered, Lake Formation assumes the LakeFormationRegistrationRole position when it grants momentary credentials to the built-in AWS companies/third-party analytics engines which can be appropriate(prerequisite Step 2) that entry information in that S3 bucket location.
To register the Amazon S3 location as the info lake location, full the next steps:
- Sign up to the AWS Administration Console for Lake Formation as the info lake administrator .
- Within the navigation pane, select Information lake places underneath Administration.
- Select Register location.
- For Amazon S3 path, enter
s3://icebergdemodatalake. - For IAM position, choose LakeFormationRegistrationRole.
- For Permission mode, choose Lake Formation.
- Select Register location.

Grant database and desk permissions to the IAM position used inside Databricks
Grant DESCRIBE permission on the icebergdemodb database to the Databricks IAM occasion position.
- Sign up to the Lake Formation console as the info lake administrator.
- Within the navigation pane, select Information lake permissions and select Grant.
- Within the Ideas part, choose IAM customers and roles and select databricks-dataplane-instance-profile-role.
- Within the LF-Tags or catalog sources part, choose Named Information Catalog sources. Select
<accountid>for Catalogs and icebergdemodb for Databases. - Choose DESCRIBE for Database permissions.
- Select Grant.
Grant SELECT and DESCRIBE permissions on the individual desk within the icebergdemodb database to the Databricks IAM occasion position.
- Within the navigation pane, select Information lake permissions and select Grant.
- Within the Ideas part, choose IAM customers and roles and select databricks-dataplane-instance-profile-role.
- Within the LF-Tags or catalog sources part, choose Named Information Catalog sources. Select
<accountid>for Catalogs, icebergdemodb for Databases and individual for desk. - Choose SUPER for Desk permissions.
- Select Grant.
Grant information location permissions on the bucket to the Databricks IAM occasion position.
- Within the Lake Formation console navigation pane, select Information Areas, after which select Grant.
- For IAM customers and roles, select databricks-dataplane-instance-profile-role.
- For Storage places, choose the s3://icebergdemodatalake.
- Select Grant.
Databricks workspace
Create a cluster and configure it to attach with a Glue Iceberg REST Catalog endpoint. For this publish, we are going to use a Databricks cluster with runtime model 15.4 LTS (contains Apache Spark 3.5.0, Scala 2.12).
- In Databricks console, select Compute within the navigation pane.
- Create a cluster with runtime model 15.4 LTS, entry mode as ‘No isolation shared‘ and select
databricks-dataplane-instance-profile-roleas occasion profile position underneath Configuration part.
- Develop the Superior choices part. Within the Spark part, for Spark Config embody the next particulars:
- Within the Cluster part, for Libraries embody the next jars:
org.apache.iceberg-spark-runtime-3.5_2.12:1.6.1software program.amazon.awssdk:bundle:2.29.5

Create a pocket book for analyzing information managed in Information Catalog:
- Within the workspace browser, create a brand new pocket book and fasten it to the cluster created above.
- Run the next instructions within the pocket book cell to question the info.



- Additional modify the info within the S3 information lake utilizing the AWS Glue Iceberg REST Catalog.

This exhibits you can now analyze information in a Databricks cluster utilizing an AWS Glue Iceberg REST Catalog endpoint with Lake Formation managing the info entry.
Clear up
To wash up the sources used on this publish and keep away from potential fees:
- Delete the cluster created in Databricks.
- Delete the IAM roles created for this publish.
- Delete the sources created in Information Catalog.
- Empty after which delete the S3 bucket.
Conclusion
On this publish, we’ve confirmed you how one can handle a dataset centrally in AWS Glue Information Catalog and make it accessible to Databricks compute utilizing the Iceberg REST Catalog API. The answer additionally lets you use Databricks to make use of present entry management mechanisms with Lake Formation, which is used to handle metadata entry and allow underlying Amazon S3 storage entry utilizing credential merchandising.
Strive the characteristic and share your suggestions within the feedback.
Concerning the authors
Srividya Parthasarathy is a Senior Huge Information Architect on the AWS Lake Formation crew. She works with the product crew and prospects to construct strong options and options for his or her analytical information platform. She enjoys constructing information mesh options and sharing them with the neighborhood.
Venkatavaradhan (Venkat) Viswanathan is a International Accomplice Options Architect at Amazon Net Companies. Venkat is a Know-how Technique Chief in Information, AI, ML, generative AI, and Superior Analytics. Venkat is a International SME for Databricks and helps AWS prospects design, construct, safe, and optimize Databricks workloads on AWS.
Pratik Das is a Senior Product Supervisor with AWS Lake Formation. He’s captivated with all issues information and works with prospects to know their necessities and construct pleasant experiences. He has a background in constructing data-driven options and machine studying methods.










