databricks-cdk is an open source library that allows you to deploy Databricks workspace and resources on AWS using the AWS Cloud Development Kit (CDK) version 2 and TypeScript.
- AWS CLI
- Node.js
- AWS CDK v2
- Databricks account
- AWS Systems Manager (SSM) parameters:
/databricks/deploy/client-id
/databricks/deploy/client-secret
(secure parameter)/databricks/account-id
(not AWS account ID)
To install databricks-cdk, you can use npm:
npm install databricks-cdk
Here's an example of how you can use databricks-cdk to deploy a Databricks workspace:
Initialize your AWS CDK project:
cdk init
Import the DatabricksDeployLambda class into your AWS CDK app:
import {Construct} from "constructs";
import {Stack, StackProps} from "aws-cdk-lib";
import {DatabricksDeployLambda} from "databricks-cdk";
Create a Simple stack containing the DatabricksDeployLambda, and a Databricks Workspace and User.
export class SimpleStack extends Stack {
constructor(scope: Construct, id: string, props: StackProps) {
super(scope, id, props);
const deployLambda = new DatabricksDeployLambda(this, "DeployLambda", {
region: this.region,
accountId: this.account
});
const credentials = deployLambda.createCredential(this, "Credentials", {
credentialsName: "credentials-name",
roleArn: "role-arn",
});
const storageConfig = deployLambda.createStorageConfig(this, "StorageConfig", {
storageConfigName: "storage-config-name",
bucketName: "bucket-name",
});
const workspace = deployLambda.createWorkspace(this, "Workspace", {
workspaceName: "databricks-workspace",
awsRegion: this.region,
credentialsId: credentials.credentialsId(),
storageConfigurationId: storageConfig.storageConfigId(),
});
deployLambda.createUser(this, "UserTest", {
workspaceUrl: workspace.workspaceUrl(),
userName: "test@test.com",
});
}
}
Create an instance of the SimpleStack class:
const app = new SimpleStack(app, "databricks-cdk");
Deploy the stack to your AWS account:
cdk deploy
Note: The AWS SSM parameters /databricks/deploy/client-id
, /databricks/deploy/client-secret
, and /databricks/account-id
are required for the deployment to succeed.
/databricks/deploy/client-id
is the client-id of service principal that is account admin and workspace admin/databricks/deploy/client-secret
is the client-secret of service principal that is account admin and workspace admin/databricks/account-id
is the id of your databricks account
See also the simple-workspace and multi-stack examples in examples
We welcome contributions to databricks-cdk! If you'd like to contribute, please follow these steps:
- Fork the repository.
- Create a branch for your feature or bug fix.
- Make your changes.
- Test your changes thoroughly.
- Submit a pull request.
- databricks-cdk is licensed under the MIT License. See LICENSE for more information