다음을 통해 공유


Go용 Databricks SDK

이 문서에서는 Databricks SDK for Go사용하여 Azure Databricks 작업을 자동화하고 개발을 가속화하는 방법에 대해 알아봅니다. 이 문서에서는 Go README, API 참조예제에 대한 Databricks SDK를 보완합니다.

참고 항목

이 기능은 베타 버전이며 프로덕션 환경에서도 사용할 수 있습니다.

베타 기간 동안 Databricks는 코드가 종속되는 특정 부 버전의 Databricks SDK for Go에 대한 종속성을 프로젝트 go.mod 파일에서 고정하는 것이 좋습니다. 종속성 고정에 대한 자세한 내용은 종속성 관리를 참조 하세요.

시작하기 전에

Go용 Databricks SDK를 사용하기 전에 개발 머신은 다음 요건을 충족해야 합니다.

  • Go 설치
  • Azure Databricks 인증 구성

Go용 Databricks SDK 시작

  1. Go가 이미 설치된 개발 머신에서 기존 Go 코드 프로젝트가 이미 생성되고 Azure Databricks 인증이 구성된 상태에서 go.mod 명령을 실행하여 Go 코드의 종속성을 추적하는 go mod init 파일을 만듭니다. 예를 들면 다음과 같습니다.

    go mod init sample
    
  2. CHANGELOG에 나열된 대로 최신 버전의 Databricks SDK for Go 패키지로 대체 go mod edit -require 하여 명령을 실행 0.8.0 하여 Databricks SDK for Go 패키지에 종속됩니다.

    go mod edit -require github.com/databricks/databricks-sdk-go@v0.8.0
    

    이제 go.mod 파일이 다음과 비슷할 것입니다.

    module sample
    
    go 1.18
    
    require github.com/databricks/databricks-sdk-go v0.8.0
    
  3. 프로젝트 내에서 Go용 Databricks SDK를 가져오는 Go 코드 파일을 만듭니다. 다음 예제에서는 다음 내용이 포함된 main.go라는 파일에서 Azure Databricks 작업 영역의 모든 클러스터를 나열합니다.

    package main
    
    import (
      "context"
    
      "github.com/databricks/databricks-sdk-go"
      "github.com/databricks/databricks-sdk-go/service/compute"
    )
    
    func main() {
      w := databricks.Must(databricks.NewWorkspaceClient())
      all, err := w.Clusters.ListAll(context.Background(), compute.ListClustersRequest{})
      if err != nil {
        panic(err)
      }
      for _, c := range all {
        println(c.ClusterName)
      }
    }
    
  4. go mod tidy 명령을 실행하여 누락된 모듈 종속성을 추가합니다.

    go mod tidy
    

    참고 항목

    go: warning: "all" matched no packages오류가 발생하면 Go용 Databricks SDK를 가져오는 Go 코드 파일을 추가하는 것을 잊어버렸습니다.

  5. main 명령을 실행하여 go mod vendor 모듈에서 패키지의 빌드 및 테스트를 지원하는 데 필요한 모든 패키지의 복사본을 가져옵니다.

    go mod vendor
    
  6. Azure Databricks 인증을 위한 개발 머신을 설정합니다.

  7. main.go 명령을 실행하여 go run라는 파일을 가정한 Go 코드 파일을 실행합니다.

    go run main.go
    

    참고 항목

    이전 *databricks.Config 호출에서 w := databricks.Must(databricks.NewWorkspaceClient())를 인수로 설정하지 않음으로써 Go용 Databricks SDK는 Azure Databricks 인증을 수행하기 위해 기본 프로세스를 사용합니다. 이 기본 동작을 재정의하려면 Azure Databricks 계정 또는 작업 영역을 사용하여 Go용 Databricks SDK 인증을 참조하세요.

Go용 Databricks SDK 업데이트

go 프로젝트를 업데이트하여 CHANGELOG나열된 대로 Go용 Databricks SDK 패키지 중 하나를 사용하려면 다음을 수행합니다.

  1. 프로젝트의 루트에서 go get 명령을 실행하고, 업데이트를 수행할 -u 플래그를 지정하고, Databricks SDK for Go 패키지의 이름과 대상 버전 번호를 제공합니다. 예를 들어 버전 0.12.0업데이트하려면 다음 명령을 실행합니다.

    go get -u github.com/databricks/databricks-sdk-go@v0.12.0
    
  2. go mod tidy 명령을 실행하여 누락되고 오래된 모듈 종속성을 추가하고 업데이트합니다.

    go mod tidy
    
  3. 명령을 실행하여 모듈에서 패키지의 빌드 및 테스트를 지원하는 데 필요한 모든 신규 및 업데이트된 패키지 main 의 복사본을 go mod vendor 가져옵니다.

    go mod vendor
    

Azure Databricks 계정 또는 작업 영역을 사용하여 Go용 Databricks SDK 인증

Databricks SDK for Go는 인증에 대한 통합되고 일관된 아키텍처 및 프로그래밍 방식인 Databricks 클라이언트 통합 인증 표준을 구현합니다. 이 방법을 사용하면 Azure Databricks를 사용하여 보다 중앙 집중화하고 예측 가능하게 인증을 설정하고 자동화할 수 있습니다. 이를 통해 Databricks 인증을 한 번 구성한 다음, 추가 인증 구성 변경 없이 여러 Databricks 도구 및 SDK에서 해당 구성을 사용할 수 있습니다. Go의 전체 코드 예제를 비롯한 자세한 내용은 Databricks 클라이언트 통합 인증을 참조하세요.

Databricks SDK for Go를 사용하여 Databricks 인증을 초기화하는 데 사용할 수 있는 코딩 패턴 중 일부는 다음과 같습니다.

  • 다음 중 하나를 수행하여 Databricks 기본 인증을 사용합니다.

    • 대상 Databricks 인증 유형에 필요한 필드를 사용하여 사용자 지정 Databricks 구성 프로필을 만들거나 식별합니다. 그런 다음 DATABRICKS_CONFIG_PROFILE 환경 변수를 사용자 지정 구성 프로필의 이름으로 설정합니다.
    • 대상 Databricks 인증 유형에 필요한 환경 변수를 설정합니다.

    그런 다음, 다음과 같이 Databricks 기본 인증을 사용하여 WorkspaceClient 개체를 인스턴스화합니다.

    import (
      "github.com/databricks/databricks-sdk-go"
    )
    // ...
    w := databricks.Must(databricks.NewWorkspaceClient())
    
  • Azure Databricks 개인용 액세스 토큰과 같은 중요한 정보를 코드에 노출할 위험이 있으므로 필수 필드를 하드 코딩하는 것은 지원되지만 권장되지는 않습니다. 다음 예제에서는 Databricks 토큰 인증에 대한 Azure Databricks 호스트 및 액세스 토큰 값을 하드 코드합니다.

    import (
      "github.com/databricks/databricks-sdk-go"
      "github.com/databricks/databricks-sdk-go/config"
    )
    // ...
    w := databricks.Must(databricks.NewWorkspaceClient(&databricks.Config{
      Host:  "https://...",
      Token: "...",
    }))
    

Go 추가 정보용 Databricks SDK의 인증참조하세요.

예제

다음 코드 예제에서는 Databricks SDK for Go를 사용하여 클러스터를 만들고 삭제하고, 작업을 실행하고, 계정 사용자를 나열하는 방법을 보여 줍니다. 이러한 코드 예제에서는 Go용 Azure Databricks의 기본 Azure Databricks 인증 프로세스를 사용합니다.

추가 코드 예제는 GitHub의 Go용 Databricks SDK 리포지토리의 예제 폴더를 참조하세요.

클러스터 생성

이 코드 예제에서는 사용 가능한 최신 Databricks LTS(런타임 장기 지원) 버전과 로컬 디스크를 사용하여 사용 가능한 가장 작은 클러스터 노드 형식을 사용하여 클러스터를 만듭니다. 이 클러스터에는 하나의 작업자가 있으며 클러스터는 15분의 유휴 시간 후에 자동으로 종료됩니다. CreateAndWait 메서드 호출을 사용하면 새 클러스터가 작업 영역에서 실행될 때까지 코드가 일시 중지됩니다.

package main

import (
  "context"
  "fmt"

  "github.com/databricks/databricks-sdk-go"
  "github.com/databricks/databricks-sdk-go/service/compute"
)

func main() {
  const clusterName            = "my-cluster"
  const autoTerminationMinutes = 15
  const numWorkers             = 1

  w   := databricks.Must(databricks.NewWorkspaceClient())
  ctx := context.Background()

  // Get the full list of available Spark versions to choose from.
  sparkVersions, err := w.Clusters.SparkVersions(ctx)

  if err != nil {
    panic(err)
  }

  // Choose the latest Long Term Support (LTS) version.
  latestLTS, err := sparkVersions.Select(compute.SparkVersionRequest{
    Latest:          true,
    LongTermSupport: true,
  })

  if err != nil {
    panic(err)
  }

  // Get the list of available cluster node types to choose from.
  nodeTypes, err := w.Clusters.ListNodeTypes(ctx)

  if err != nil {
    panic(err)
  }

  // Choose the smallest available cluster node type.
  smallestWithLocalDisk, err := nodeTypes.Smallest(clusters.NodeTypeRequest{
    LocalDisk: true,
  })

  if err != nil {
    panic(err)
  }

  fmt.Println("Now attempting to create the cluster, please wait...")

  runningCluster, err := w.Clusters.CreateAndWait(ctx, compute.CreateCluster{
    ClusterName:            clusterName,
    SparkVersion:           latestLTS,
    NodeTypeId:             smallestWithLocalDisk,
    AutoterminationMinutes: autoTerminationMinutes,
    NumWorkers:             numWorkers,
  })

  if err != nil {
    panic(err)
  }

  switch runningCluster.State {
  case compute.StateRunning:
    fmt.Printf("The cluster is now ready at %s#setting/clusters/%s/configuration\n",
      w.Config.Host,
      runningCluster.ClusterId,
    )
  default:
    fmt.Printf("Cluster is not running or failed to create. %s", runningCluster.StateMessage)
  }

  // Output:
  //
  // Now attempting to create the cluster, please wait...
  // The cluster is now ready at <workspace-host>#setting/clusters/<cluster-id>/configuration
}

클러스터 영구 삭제

이 코드 예제에서는 작업 영역에서 지정된 클러스터 ID를 사용하여 클러스터를 영구적으로 삭제합니다.

package main

import (
  "context"

  "github.com/databricks/databricks-sdk-go"
  "github.com/databricks/databricks-sdk-go/service/clusters"
)

func main() {
  // Replace with your cluster's ID.
  const clusterId = "1234-567890-ab123cd4"

  w   := databricks.Must(databricks.NewWorkspaceClient())
  ctx := context.Background()

  err := w.Clusters.PermanentDelete(ctx, compute.PermanentDeleteCluster{
    ClusterId: clusterId,
  })

  if err != nil {
    panic(err)
  }
}

작업 실행

이 코드 예제에서는 지정된 클러스터에서 지정된 Notebook을 실행하는 Azure Databricks 작업을 만듭니다. 코드가 실행되면 터미널의 사용자로부터 기존 Notebook의 경로, 기존 클러스터 ID 및 관련 작업 설정을 가져옵니다. RunNowAndWait 메서드 호출을 사용하면 작업 영역에서 새 작업이 실행될 때까지 코드가 일시 중지됩니다.

package main

import (
  "bufio"
  "context"
  "fmt"
  "os"
  "strings"

  "github.com/databricks/databricks-sdk-go"
  "github.com/databricks/databricks-sdk-go/service/jobs"
)

func main() {
  w   := databricks.Must(databricks.NewWorkspaceClient())
  ctx := context.Background()

  nt := jobs.NotebookTask{
    NotebookPath: askFor("Workspace path of the notebook to run:"),
  }

  jobToRun, err := w.Jobs.Create(ctx, jobs.CreateJob{
    Name: askFor("Some short name for the job:"),
    Tasks: []jobs.JobTaskSettings{
      {
        Description:       askFor("Some short description for the job:"),
        TaskKey:           askFor("Some key to apply to the job's tasks:"),
        ExistingClusterId: askFor("ID of the existing cluster in the workspace to run the job on:"),
        NotebookTask:      &nt,
      },
    },
  })

  if err != nil {
    panic(err)
  }

  fmt.Printf("Now attempting to run the job at %s/#job/%d, please wait...\n",
    w.Config.Host,
    jobToRun.JobId,
  )

  runningJob, err := w.Jobs.RunNow(ctx, jobs.RunNow{
    JobId: jobToRun.JobId,
  })

  if err != nil {
    panic(err)
  }

  jobRun, err := runningJob.Get()

  if err != nil {
    panic(err)
  }

  fmt.Printf("View the job run results at %s/#job/%d/run/%d\n",
    w.Config.Host,
    jobRun.JobId,
    jobRun.RunId,
  )

  // Output:
  //
  // Now attempting to run the job at <workspace-host>/#job/<job-id>, please wait...
  // View the job run results at <workspace-host>/#job/<job-id>/run/<run-id>
}

// Get job settings from the user.
func askFor(prompt string) string {
  var s string
  r := bufio.NewReader(os.Stdin)
  for {
    fmt.Fprint(os.Stdout, prompt+" ")
    s, _ = r.ReadString('\n')
    if s != "" {
      break
    }
  }
  return strings.TrimSpace(s)
}

Unity 카탈로그 볼륨에서 파일 관리

이 코드 예제에서는 Unity 카탈로그 볼륨액세스하기 위해 WorkspaceClient 내의 files 기능에 대한 다양한 호출을 보여 줍니다.

package main

import (
  "context"
  "io"
  "os"

  "github.com/databricks/databricks-sdk-go"
  "github.com/databricks/databricks-sdk-go/service/files"
)

func main() {
  w := databricks.Must(databricks.NewWorkspaceClient())

  catalog          := "main"
  schema           := "default"
  volume           := "my-volume"
  volumePath       := "/Volumes/" + catalog + "/" + schema + "/" + volume // /Volumes/main/default/my-volume
  volumeFolder     := "my-folder"
  volumeFolderPath := volumePath + "/" + volumeFolder // /Volumes/main/default/my-volume/my-folder
  volumeFile       := "data.csv"
  volumeFilePath   := volumeFolderPath + "/" + volumeFile // /Volumes/main/default/my-volume/my-folder/data.csv
  uploadFilePath   := "./data.csv"

  // Create an empty folder in a volume.
  err := w.Files.CreateDirectory(
    context.Background(),
    files.CreateDirectoryRequest{DirectoryPath: volumeFolderPath},
  )
  if err != nil {
    panic(err)
  }

  // Upload a file to a volume.
  fileUpload, err := os.Open(uploadFilePath)
  if err != nil {
    panic(err)
  }
  defer fileUpload.Close()

  w.Files.Upload(
    context.Background(),
    files.UploadRequest{
      Contents:  fileUpload,
      FilePath:  volumeFilePath,
      Overwrite: true,
    },
  )

  // List the contents of a volume.
  items := w.Files.ListDirectoryContents(
    context.Background(),
    files.ListDirectoryContentsRequest{DirectoryPath: volumePath},
  )

  for {
    if items.HasNext(context.Background()) {
      item, err := items.Next(context.Background())
      if err != nil {
        break
      }
      println(item.Path)

    } else {
      break
    }
  }

  // List the contents of a folder in a volume.
  itemsFolder := w.Files.ListDirectoryContents(
    context.Background(),
    files.ListDirectoryContentsRequest{DirectoryPath: volumeFolderPath},
  )

  for {
    if itemsFolder.HasNext(context.Background()) {
      item, err := itemsFolder.Next(context.Background())
      if err != nil {
        break
      }
      println(item.Path)
    } else {
      break
    }
  }

  // Print the contents of a file in a volume.
  file, err := w.Files.DownloadByFilePath(
    context.Background(),
    volumeFilePath,
  )
  if err != nil {
    panic(err)
  }

  bufDownload := make([]byte, file.ContentLength)

  for {
    file, err := file.Contents.Read(bufDownload)
    if err != nil && err != io.EOF {
      panic(err)
    }
    if file == 0 {
      break
    }

    println(string(bufDownload[:file]))
  }

  // Delete a file from a volume.
  w.Files.DeleteByFilePath(
    context.Background(),
    volumeFilePath,
  )

  // Delete a folder from a volume.
  w.Files.DeleteDirectory(
    context.Background(),
    files.DeleteDirectoryRequest{
      DirectoryPath: volumeFolderPath,
    },
  )
}

계정 사용자 나열

이 코드 예제에서는 Azure Databricks 계정 내에서 사용 가능한 사용자를 나열합니다.

package main

import (
  "context"

  "github.com/databricks/databricks-sdk-go"
  "github.com/databricks/databricks-sdk-go/service/iam"
)

func main() {
  a := databricks.Must(databricks.NewAccountClient())
  all, err := a.Users.ListAll(context.Background(), iam.ListAccountUsersRequest{})
  if err != nil {
    panic(err)
  }
  for _, u := range all {
    println(u.UserName)
  }
}

추가 리소스

자세한 내용은 다음을 참조하세요.