0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

DatabricksアカウントコンソールでのSSOのセットアップ

Last updated at Posted at 2023-07-13

Set up SSO for your Databricks account console | Databricks on AWS [2023/6/20時点]の翻訳です。

本書は抄訳であり内容の正確性を保証するものではありません。正確な内容に関しては原文を参照ください。

あなたの組織のアイデンティティプロバイダーを用いてアカウントコンソールへの認証にシングルサインオン(SSO)を活用します。アカウントコンソールは、ワークスペース作成、委任されたAWSアクセス資格情報、AWSストレージ設定、顧客管理VPC(オプション)を含む、お使いのDatabricksアカウントレベルの設定を管理する場所となります。

アカウントコンソールのSSOでは、SAML 2.0あるいはOpenID Connect (OIDC)をサポートしています。お使いのアイデンティティプロバイダー(IdP)は、少なくともいずれかのプロトコルをサポートしている必要があります。お使いのIdPでOIDCとSAML 2.0の両方をサポートしているのであれば、アカウントコンソールの認証にはOIDCを使うことをお勧めします。

アカウントでSSOを有効化すると、すべてのユーザーに対して、アカウントコンソールへのログインにはSSOを使うことが要求されます。アカウントオーナーのみはユーザー名(メールアドレス)とパスワードを用いてログインすることができます。

SSO認証を用いたアカウントコンソールの挙動は、ユーザーがDatabricksアカウントのadminロールを持っているかどうかによって変化します。

  • adminロールがある場合、ユーザーはワークスペースやワークスペースリソースの作成や変更のようなアカウントコンソールのアカウント管理者向け機能にアクセスできます。
  • adminロールがない場合、ユーザーはログインできるワークスペース一覧やワークスペースへのリンクの参照のような非管理者のアクションに限定されます。

注意
アカウントレベルのSSOを使うには、アカウントはE2バージョンのDatabricksプラットフォームである必要があります。アカウントタイプがわからない場合には、Databricks担当者にお問い合わせください。

統合ログイン

2023/6/21以降にDatabricksアカウントが作成されたのであれば、あなたのアカウントで統合ログインが有効になっています。統合ログインによって、アカウントとすべてのDatabricksワークスペースで使用される一つのSSO設定を管理することができます。アカウントでSSOが有効化されると、新規・既存のすべてのワークスベースでアカウントレベルのSSO設定が用いられ、アカウント管理者、ワークスペース管理者を含むすべてのユーザーはSSOを用いてDatabricksにサインインしなくてはなりません。ワークスペースレベルで個別にSSOを管理することはできません。

2023/6/21以前にアカウントが作成されている場合、アカウントで統合ログインは有効化されていません。これは、アカウントのSSOとワークスペースごとのSSOは個別に管理しなくてはならないことを意味します。アカウントとワークスペースで同じアイデンティティプロバイダーを設定しなくてはなりません。

プレビュー
2023/6/21以前に作成されたアカウントの統合ログインはプライベートプレビューです。アクセスするにはDatabricks担当者にお問い合わせください。

アカウントコンソールSSOアプリケーションの例

以下のアイデンティティプロバイダーでのSSOの設定方法に関しては、手順を参照することができます:

OIDCやSAML 2.0をサポートしているいかなるアイデンティティプロバイダーではプロセスは同様なものとなります。お使いのアイデンティティプロバイダーが上に列挙されていない場合には、以下のOIDCSAMLの手順に従ってください。アカウントコンソールの認証にはOICDを使うことをお勧めします。

OIDCを用いたアカウントシングルサインオン認証の有効化

警告!
シングルサインオンのテストの過程でDatabricksからロックアウトされないように、別のブラウザウィンドウでアカウントコンソールを開いたままにしておくことをお勧めします。

  1. アカウントオーナーあるいはアカウント管理者として、アカウントコンソールにログインし、サイドバーのSettingsをクリックします。

  2. Single sign-onタブをクリックします。

  3. このタブの上部にあるドロップダウンから、OpenID Connectを選択します。

  4. Single sign-onタブで、Databricks Redirect URIの値をメモしておきます。

  5. お使いのアイデンティティプロバイダーに移動し、新たにクライアントアプリケーション(web)を作成し、アイデンティティプロバイダーの設定インタフェースの適切なフィールドにDatabricks Redirect URIを入力します。

    お使いのアイデンティティプロバイダーでは、このプロセスのガイドに関するドキュメントを提供しているに違いありません。

  6. このアプリケーション向けにアイデンティティプロバイダーが生成したクライアントID、クライアントシークレット、OpenIDイシュアーURLをコピーしておきます。

    • クライアントIDは、お使いのアイデンティティプロバイダーであなたが作成したDatabricksアプリケーションのユニークなIDです。これは時には、アプリケーションIDと呼ばれます。
    • クライアントシークレットは、作成したDatabricksアプリケーション向けに生成されたシークレットあるいはパスワードです。これは、アイデンティティプロバイダーでDatabricksを認証する際に使用されます。
    • OpenIDイシュアーURLは、お使いのアイデンティティプロバイダーのOpenID設定ドキュメントを発見できるURLです。このOpenID設定ドキュメントは{issuer-url}/.well-known/openid-configurationで発見できるべきです。

    例については、アカウントコンソールSSOアプリケーションの例をご覧ください。

  7. DatabricksアカウントコンソールのSingle sign-onタブに戻り、Client IDClient secretOpenID issuer URLフィールドにアイデンティティプロバイダーアプリケーションでコピーした値を入力します。

  8. Saveをクリックします。

  9. SSO設定が適切に動作していることをテストするためにTest SSOをクリックします。

  10. お使いのアカウントでシングルサインオンを有効化するために、Enable SSOをクリックします。

  11. SSOを用いてアカウントコンソールログインをテストします。

SAMLを用いたアカウントシングルサインオン認証の有効化

以下の手順では、アカウントオーナー以外のアカウントコンソールユーザーを認証するために、どのようにSAML 2.0を使うのかを説明します。お使いのIdPでOIDCとSAML 2.0の両方をサポートしているのであれば、アカウントコンソールの認証にはOIDCを使うことをお勧めします。

警告!
シングルサインオンのテストの過程でDatabricksからロックアウトされないように、別のブラウザウィンドウでアカウントコンソールを開いたままにしておくことをお勧めします。

  1. アカウントコンソールのSSOページにアクセスし、SAML URLをコピーします:

    1. アカウントオーナーあるいはアカウント管理者として、アカウントコンソールにログインし、サイドバーのSettingsをクリックします。
    2. Single sign-onタブをクリックします。
    3. このタブの上部にあるドロップダウンから、SAML 2.0を選択します。
    4. Databricks SAML URLフィールドの値をコピーしておきます。後のステップでこのDatabricks SAML URLが必要になります。
  2. 別のブラウザウィンドウあるいはタブで、お使いのアイデンティティプロバイダーでDatabricksアプリケーションを作成します。

    1. アイデンティティプロバイダー(IdP)にアクセスします。
    2. 新たなクライアントアプリケーション(web)を作成します。
      • 必要であればお使いのアイデンティティプロバイダーのドキュメントを活用します。
      • (リダイレクトURLと呼ばれることもある)SAML URLフィールドには、DatabricksページでコピーしたDatabricksのSAML URLを使用します。
    3. 新たに作成したDatabricksアプリケーションから以下のオブジェクトとフィールドをコピーします:
      • x.509証明書: Databricksとアイデンティティプロバイダーの間のコミュニケーションを保護するためにアイデンティティプロバイダーから提供されるデジタル証明書。
      • お使いのアイデンティティプロバイダーのシングルサインオン(SSO)URL: これは、お使いのアイデンティティプロバイダーを用いたシングルサインオンを起動するURLです。また、これは時にはSAMLエンドポイントとも呼ばれます。
      • アイデンティティプロバイダーのイシュアー: これは、お使いのSAMLアイデンティティプロバイダーに対するユニークなIDです。これは時には、エンティティIDやイシュアーURLとも呼ばれます。

    例については、アカウントコンソールSSOアプリケーションの例をご覧ください。

  3. お使いのアイデンティティプロバイダーを使用するようにDatabricksアカウントを設定します。

    1. DatabricksアカウントコンソールのSSOページを表示しているブラウザタブあるいはウィンドウに戻ります。
    2. アイデンティティプロバイダーアプリケーションから以下のフィールドの値を入力、貼り付けします: シングルサインオンURL、アイデンティティプロバイダーのID、x.509証明書。
    3. Saveをクリックします。
    4. SSO設定が適切に動作していることをテストするためにTest SSOをクリックします。
    5. お使いのアカウントでシングルサインオンを有効化するために、Enable SSOをクリックします。
    6. SSOを用いてアカウントコンソールログインをテストします。

アカウントサインインのプロセス

統合ログインが有効化され、アカウントレベルのSSOが有効化されると、アカウントのサインインページとワークスペースのサインインページで、シングルサインオンのオプションが表示されるようになります。挙動は以下の通りとなります:

  • 管理者を含むすべてのユーザーは、DatabricksアカウントやワークスペースにはSSOを用いてサインインしなくてはなりません。ユーザー名やパスワードを用いてサインインすることはできません。

  • アカウント管理者は、アカウントレベルのREST API呼び出しにユーザー名とパスワードを使用することができます。

  • すべてのユーザーはワークスペースレベルのREST API呼び出しでユーザー名とパスワードを使うことができます。

    注意
    アカウントが2023/6/21以降に作成されており、ワークスペースのAPIユーザーのユーザー名とパスワードによる認証を制限する必要がある場合には、Databricks担当者にお問い合わせください。

統合ログインが無効化され、アカウントレベルのSSOが有効化されると、アカウントのサインインページでシングルサインオンのオプションが表示されるようになります。デフォルトの挙動は以下の通りです:

  • アカウントオーナーを除き、ユーザーを含む全ユーザーは、SSOを用いてDatabricksアカウントにサインインしなくてはなりません。アカウントオーナーはユーザー名とパスワードでサインインすることができます。
  • アカウント管理者は、アカウントレベルのREST API呼び出しにユーザー名とパスワードを使用することができます。

統合ログインが無効化されると、ワークスペースレベルのSSOは個別に設定しなくてはなりません。デフォルトのワークスペースサインインプロセスについては、ワークスペースサインインのプロセスをご覧ください。

Databricksクイックスタートガイド

Databricksクイックスタートガイド

Databricks無料トライアル

Databricks無料トライアル

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?